config.initAllSetters();
List<RequiredInterface> required = config.getRequiredInterfaces();
assertEquals(1, required.size());
- assertEquals("value", required.get(0).getName());
+ assertEquals("setValue.0", required.get(0).getName());
ProvidedInterface provided = new DefaultProvidedInterface("janse",
String.class);
required.get(0).setProvider(provided);
- provided.publish("hello", _scope);
+ scope.publishInterface(provided, "hello");
X5 obj = new X5();
assertNull(obj.getValue());
- config.inject(_scope, obj);
+ config.inject(scope, obj);
assertEquals("hello", obj.getValue());
}
}
});
assertEquals(2, required.size());
- assertEquals("value", required.get(0).getName());
- assertEquals("xyz", required.get(1).getName());
+ assertEquals("setValue.0", required.get(0).getName());
+ assertEquals("setXyz.0", required.get(1).getName());
ProvidedInterface providedString = new DefaultProvidedInterface(
"janse", String.class);
assertTrue(required.get(0).implementedBy(providedString));
required.get(0).setProvider(providedString);
- providedString.publish("hello", _scope);
+ scope.publishInterface(providedString, "hello");
ProvidedInterface providedInt = new DefaultProvidedInterface("xxx",
Integer.class);
assertTrue(required.get(1).implementedBy(providedInt));
required.get(1).setProvider(providedInt);
- providedInt.publish(100, _scope);
+ scope.publishInterface(providedInt, 100);
X5 obj = new X5();
assertNull(obj.getValue());
assertNull(obj.getXyz());
- config.inject(_scope, obj);
+ config.inject(scope, obj);
assertEquals("hello", obj.getValue());
assertEquals(100, obj.getXyz().intValue());
}
}
});
assertEquals(3, required.size());
- assertEquals("flag", required.get(0).getName());
- assertEquals("value", required.get(1).getName());
- assertEquals("xyz", required.get(2).getName());
+ assertEquals("setFlag.0", required.get(0).getName());
+ assertEquals("setValue.0", required.get(1).getName());
+ assertEquals("setXyz.0", required.get(2).getName());
ProvidedInterface providedBoolean = new DefaultProvidedInterface(
"janse", Boolean.class);
assertTrue(required.get(0).implementedBy(providedBoolean));
required.get(0).setProvider(providedBoolean);
- providedBoolean.publish(true, _scope);
+ scope.publishInterface(providedBoolean, true);
ProvidedInterface providedString = new DefaultProvidedInterface(
"janse", String.class);
assertTrue(required.get(1).implementedBy(providedString));
required.get(1).setProvider(providedString);
- providedString.publish("hello", _scope);
+ scope.publishInterface(providedString, "hello");
ProvidedInterface providedInt = new DefaultProvidedInterface("xxx",
Integer.class);
assertTrue(required.get(2).implementedBy(providedInt));
required.get(2).setProvider(providedInt);
- providedInt.publish(100, _scope);
+ scope.publishInterface(providedInt, 100);
X9 obj = new X9();
assertNull(obj.getValue());
assertNull(obj.getXyz());
assertFalse(obj.isFlag());
- config.inject(_scope, obj);
+ config.inject(scope, obj);
assertEquals("hello", obj.getValue());
assertEquals(100, obj.getXyz().intValue());
assertTrue(obj.isFlag());
List<RequiredInterface> required = config.getRequiredInterfaces();
Collections.sort(required, new RequiredInterfaceComparator());
assertEquals(2, required.size());
- assertEquals("host", required.get(0).getName());
- assertEquals("port", required.get(1).getName());
+ assertEquals("setHost.0", required.get(0).getName());
+ assertEquals("setPort.0", required.get(1).getName());
ProvidedInterface provided0 = new DefaultProvidedInterface("janse",
String.class);
required.get(0).setProvider(provided0);
- provided0.publish("hello", _scope);
+ scope.publishInterface(provided0, "hello");
ProvidedInterface provided1 = new DefaultProvidedInterface("port",
Integer.class);
required.get(1).setProvider(provided1);
- provided1.publish(10, _scope);
+ scope.publishInterface(provided1, 10);
X6 obj = new X6();
assertNull(obj.getHost());
assertNull(obj.getPort());
- config.inject(_scope, obj);
+ config.inject(scope, obj);
assertEquals("hello", obj.getHost());
assertEquals(10, obj.getPort().intValue());
}
final SetterConfiguration config = new SetterConfiguration(X5.class).initAllSetters();
List<RequiredInterface> required = config.getRequiredInterfaces();
assertEquals(1, required.size());
- assertEquals("value", required.get(0).getName());
+ assertEquals("setValue.0", required.get(0).getName());
ProvidedInterface provided = new DefaultProvidedInterface("janse",
String.class);
required.get(0).setProvider(provided);
- provided.publish("hello", _scope);
+ scope.publishInterface(provided, "hello");
final X6 obj = new X6();
AssertionUtils.assertException(new AssertionUtils.ErroneousCode() {
@Override
public void run() throws Exception {
- config.inject(_scope, obj);
+ config.inject(scope, obj);
}
}, IllegalArgumentException.class);
}
public void testSetExplicitValue() {
SetterConfiguration config = new SetterConfiguration(X5.class).initAllSetters();
- config.values("value").setValue(0, "bladibla");
+ config.values("setValue").setValue(0, "bladibla");
List<RequiredInterface> required = config.getRequiredInterfaces();
assertEquals(0, required.size());
X5 obj = new X5();
assertNull(obj.getValue());
- config.inject(_scope, obj);
+ config.inject(scope, obj);
assertEquals("bladibla", obj.getValue());
}
assertNull(obj.getHost());
assertNull(obj.getPort());
- config.inject(_scope, obj);
+ config.inject(scope, obj);
assertNull(obj.getHost());
assertNull(obj.getPort());
public void testAddByName() {
SetterConfiguration config = new SetterConfiguration(X6.class);
- config.clear().add("host");
+ config.clear().add("setHost");
List<RequiredInterface> required = config.getRequiredInterfaces();
Collections.sort(required, new RequiredInterfaceComparator());
assertEquals(1, required.size());
- assertEquals("host", required.get(0).getName());
+ assertEquals("setHost.0", required.get(0).getName());
ProvidedInterface provided0 = new DefaultProvidedInterface("janse",
String.class);
required.get(0).setProvider(provided0);
- provided0.publish("hello", _scope);
+ scope.publishInterface(provided0, "hello");
X6 obj = new X6();
assertNull(obj.getHost());
assertNull(obj.getPort());
- config.inject(_scope, obj);
+ config.inject(scope, obj);
assertEquals("hello", obj.getHost());
assertNull(obj.getPort());
}
public void testAddByType() {
SetterConfiguration config = new SetterConfiguration(X6.class);
- config.clear().add(String.class);
+ config.clear().addSetter(String.class);
List<RequiredInterface> required = config.getRequiredInterfaces();
Collections.sort(required, new RequiredInterfaceComparator());
assertEquals(1, required.size());
- assertEquals("host", required.get(0).getName());
+ assertEquals("setHost.0", required.get(0).getName());
ProvidedInterface provided0 = new DefaultProvidedInterface("janse",
String.class);
required.get(0).setProvider(provided0);
- provided0.publish("hello", _scope);
+ scope.publishInterface(provided0, "hello");
X6 obj = new X6();
assertNull(obj.getHost());
assertNull(obj.getPort());
- config.inject(_scope, obj);
+ config.inject(scope, obj);
assertEquals("hello", obj.getHost());
assertNull(obj.getPort());
}
config.setNonPublic(true);
config.clear();
- config.add("xyz");
+ config.add("setXyz");
assertEquals(1, config.getRequiredInterfaces().size());
}
AssertionUtils.assertException(new AssertionUtils.ErroneousCode() {
@Override
public void run() throws Exception {
- config.add(DataSource.class);
+ config.addSetter(DataSource.class);
}
}, IllegalArgumentException.class);
}
AssertionUtils.assertException(new AssertionUtils.ErroneousCode() {
@Override
public void run() throws Exception {
- config.add(String.class);
+ config.addSetter(String.class);
}
}, IllegalArgumentException.class);
}
public void testRemove() {
SetterConfiguration config = new SetterConfiguration(X6.class).initAllSetters();
- config.remove("port");
+ config.remove("setPort");
List<RequiredInterface> required = config.getRequiredInterfaces();
Collections.sort(required, new RequiredInterfaceComparator());
assertEquals(1, required.size());
- assertEquals("host", required.get(0).getName());
+ assertEquals("setHost.0", required.get(0).getName());
ProvidedInterface provided0 = new DefaultProvidedInterface("janse",
String.class);
required.get(0).setProvider(provided0);
- provided0.publish("hello", _scope);
+ scope.publishInterface(provided0, "hello");
X6 obj = new X6();
assertNull(obj.getHost());
assertNull(obj.getPort());
- config.inject(_scope, obj);
+ config.inject(scope, obj);
assertEquals("hello", obj.getHost());
assertNull(obj.getPort());
}
+
+ public void testRemoveByMethodObject() throws NoSuchMethodException {
+ SetterConfiguration config = new SetterConfiguration(X6.class).initAllSetters();
+ config.remove(X6.class.getMethod("setPort", Integer.class));
+ List<RequiredInterface> required = config.getRequiredInterfaces();
+ Collections.sort(required, new RequiredInterfaceComparator());
+ assertEquals(1, required.size());
+ assertEquals("setHost.0", required.get(0).getName());
+
+ ProvidedInterface provided0 = new DefaultProvidedInterface("janse",
+ String.class);
+ required.get(0).setProvider(provided0);
+ scope.publishInterface(provided0, "hello");
+
+ X6 obj = new X6();
+ assertNull(obj.getHost());
+ assertNull(obj.getPort());
+
+ config.inject(scope, obj);
+ assertEquals("hello", obj.getHost());
+ assertNull(obj.getPort());
+ }
public void testRemoveNonExisting() {
final SetterConfiguration config = new SetterConfiguration(X6.class);