X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;f=system%2Fgeneral%2Fsrc%2Ftest%2Fjava%2Forg%2Fwamblee%2Fsystem%2Fadapters%2FClassAdapterTest.java;h=f25d345917e111dd56c5b8570bbfd618451c8f85;hb=ea1f15ca41f5093232d4d4548a948c2cdce7ec42;hp=925f3ef9eb509cc5798ca49f135f50e8d5bd7377;hpb=9cd3686a90a0a75ef52ec190bcd445bc3a777e7e;p=utils diff --git a/system/general/src/test/java/org/wamblee/system/adapters/ClassAdapterTest.java b/system/general/src/test/java/org/wamblee/system/adapters/ClassAdapterTest.java index 925f3ef9..f25d3459 100644 --- a/system/general/src/test/java/org/wamblee/system/adapters/ClassAdapterTest.java +++ b/system/general/src/test/java/org/wamblee/system/adapters/ClassAdapterTest.java @@ -15,16 +15,18 @@ */ package org.wamblee.system.adapters; +import java.util.Collections; +import java.util.List; + import org.wamblee.system.core.Component; import org.wamblee.system.core.Container; -import org.wamblee.system.core.DefaultScope; +import org.wamblee.system.core.DefaultProvidedInterface; import org.wamblee.system.core.ProvidedInterface; import org.wamblee.system.core.RequiredInterface; +import org.wamblee.system.core.RequiredInterfaceComparator; import org.wamblee.system.core.Scope; import org.wamblee.test.AssertionUtils; -import junit.framework.TestCase; - public class ClassAdapterTest extends AdapterTestCase { @@ -44,9 +46,46 @@ public class ClassAdapterTest extends AdapterTestCase { AssertionUtils.assertEquals(new String[] { "x1(hello)", "x4(x1)" }, EVENT_TRACKER.getEvents(Thread.currentThread()).toArray()); - Object obj = scope.getRuntime(x1Adapter); - assertTrue(obj instanceof X1); - obj = scope.getRuntime(x4Adapter); - assertTrue(obj instanceof X4); + Object obj1 = scope.getRuntime(x1Adapter); + assertTrue(obj1 instanceof X1); + Object obj4 = scope.getRuntime(x4Adapter); + assertTrue(obj4 instanceof X4); + + X1 x1 = (X1) obj1; + X4 x4 = (X4) obj4; + + assertSame(x1, x4.getX1()); + } + + public void testConstructorAndSetterInjection() { + ClassConfiguration x1Config = new ClassConfiguration(X1.class); + x1Config.getConstructorConfig().getParameters().setValue(0, "hello"); + ClassConfiguration x4Config = new ClassConfiguration(X4.class); + ClassConfiguration x8Config = new ClassConfiguration(X8.class); + + ClassAdapter x1Adapter = new ClassAdapter("x1", x1Config); + ClassAdapter x4Adapter = new ClassAdapter("x4", x4Config); + ClassAdapter x8Adapter = new ClassAdapter("x8", x8Config); + + Container container = new Container("top", new Component[] { + x1Adapter, x4Adapter, x8Adapter + }, new ProvidedInterface[0], new RequiredInterface[0]); + + Scope scope = container.start(); + AssertionUtils.assertEquals(new String[] { "x1(hello)", "x4(x1)", "x8(x1)", "x8.setX4(x4)" }, + EVENT_TRACKER.getEvents(Thread.currentThread()).toArray()); + + Object obj1 = scope.getRuntime(x1Adapter); + assertTrue(obj1 instanceof X1); + Object obj4 = scope.getRuntime(x4Adapter); + assertTrue(obj4 instanceof X4); + Object obj8 = scope.getRuntime(x8Adapter); + + X1 x1 = (X1) obj1; + X4 x4 = (X4) obj4; + X8 x8 = (X8) obj8; + + assertSame(x4, x8.getX4()); + assertSame(x1, x8.getX1()); } }