}
@Test
public void testDelayOnProxiedCollectionDependency() {
String prov = "provider";
ComponentInstance provider1 = ipojoHelper.createComponentInstance("TEMPORAL-FooProvider", prov);
String prov2 = "provider2";
ComponentInstance provider2 = ipojoHelper.createComponentInstance("TEMPORAL-FooProvider", prov2);
String un = "under-1";
ComponentInstance under = ipojoHelper.createComponentInstance("TEMPORAL-NullableProxiedColCheckServiceProviderTimeout", un);
ServiceReference ref_fs = ipojoHelper.getServiceReferenceByName(FooService.class.getName(), prov);
assertNotNull("Check foo availability", ref_fs);
ServiceReference ref_cs = ipojoHelper.getServiceReferenceByName(CheckService.class.getName(), un);
assertNotNull("Check cs availability", ref_cs);
CheckService cs = (CheckService) osgiHelper.getServiceObject(ref_cs);
assertTrue("Check invocation", cs.check());
// Stop the providers.
provider1.stop();
provider2.stop();
ref_cs = ipojoHelper.getServiceReferenceByName(CheckService.class.getName(), un);
assertNotNull("Check cs availability - 2", ref_cs);
long begin = System.currentTimeMillis();
DelayedProvider dp = new DelayedProvider(provider1, 1500);
DelayedProvider dp2 = new DelayedProvider(provider2, 100);
dp.start();
dp2.start();
cs = (CheckService) osgiHelper.getServiceObject(ref_cs);
assertTrue("Check invocation - 2", cs.check());
long end = System.currentTimeMillis();
System.out.println("delay = " + (end - begin));
assertTrue("Assert min delay", (end - begin) >= 100);
assertTrue("Assert max delay", (end - begin) <= 1000);
dp.stop();
dp2.stop();
provider1.stop();
provider2.stop();
ref_cs = ipojoHelper.getServiceReferenceByName(CheckService.class.getName(), un);
assertNotNull("Check cs availability - 3", ref_cs);
cs = (CheckService) osgiHelper.getServiceObject(ref_cs);
assertFalse("Check invocation - 3", cs.check()); // Will return false as the contained nullable will return false to the foo method.
provider1.dispose();
provider2.dispose();
under.stop();
under.dispose();
}