- public static final String ODL = "org.opendaylight.controller";
- public static final String YANG = "org.opendaylight.yangtools";
- public static final String SAMPLE = "org.opendaylight.controller.samples";
-
- @Test
- public void properInitialized() throws Exception {
-
- Collection<ServiceReference<ToasterService>> references = ctx
- .getServiceReferences(ToasterService.class, null);
- assertEquals(2, references.size());
-
- consumer.createToast(WhiteBread.class, 5);
-
- }
-
- @Inject
- BindingAwareBroker broker;
-
- @Inject
- ToastConsumer consumer;
-
- @Inject
- BundleContext ctx;
-
- @Configuration
- public Option[] config() {
- return options(systemProperty("osgi.console").value("2401"),
- mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(),
- mavenBundle("org.slf4j", "log4j-over-slf4j")
- .versionAsInProject(),
- mavenBundle("ch.qos.logback", "logback-core")
- .versionAsInProject(),
- mavenBundle("ch.qos.logback", "logback-classic")
- .versionAsInProject(),
- mavenBundle(ODL, "sal-binding-api").versionAsInProject(),
- mavenBundle(ODL, "sal-binding-broker-impl")
- .versionAsInProject(), mavenBundle(ODL, "sal-common")
- .versionAsInProject(),
- mavenBundle(ODL, "sal-common-util").versionAsInProject(),
- mavenBundle(SAMPLE, "sample-toaster").versionAsInProject(),
- mavenBundle(SAMPLE, "sample-toaster-consumer")
- .versionAsInProject(),
- mavenBundle(SAMPLE, "sample-toaster-provider")
- .versionAsInProject(),
- mavenBundle(YANG, "yang-binding").versionAsInProject(),
- mavenBundle(YANG, "yang-common").versionAsInProject(),
- mavenBundle("com.google.guava", "guava").versionAsInProject(),
- junitBundles(), mavenBundle("org.javassist", "javassist")
- .versionAsInProject());
- }
+ @Inject
+ @Filter(timeout=60*1000)
+ KitchenService kitchenService;
+
+ @Configuration
+ public Option[] config() {
+ return options(systemProperty("osgi.console").value("2401"), mavenBundle("org.slf4j", "slf4j-api")
+ .versionAsInProject(), //
+ mavenBundle("org.slf4j", "log4j-over-slf4j").versionAsInProject(), //
+
+ systemProperty("logback.configurationFile").value(
+ "file:" + PathUtils.getBaseDir()
+ + "/src/test/resources/logback.xml"),
+ mavenBundle("ch.qos.logback", "logback-core").versionAsInProject(), //
+ mavenBundle("ch.qos.logback", "logback-classic").versionAsInProject(), //
+ systemProperty("osgi.bundles.defaultStartLevel").value("4"),
+ systemPackages("sun.nio.ch"),
+
+ toasterBundles(),
+ mdSalCoreBundles(),
+
+ bindingAwareSalBundles(),
+ configMinumumBundles(),
+ // BASE Models
+ baseModelBundles(),
+ flowCapableModelBundles(),
+
+ // Set fail if unresolved bundle present
+ systemProperty("pax.exam.osgi.unresolved.fail").value("true"),
+ junitAndMockitoBundles());
+ }
+
+ private Option toasterBundles() {
+ return new DefaultCompositeOption(
+ mavenBundle("org.opendaylight.controller.samples", "sample-toaster-provider").versionAsInProject(),
+ mavenBundle("org.opendaylight.controller.samples", "sample-toaster-consumer").versionAsInProject(),
+ mavenBundle("org.opendaylight.controller.samples", "sample-toaster").versionAsInProject(),
+ mavenBundle("org.openexi", "nagasena").versionAsInProject(),
+ mavenBundle("org.openexi", "nagasena-rta").versionAsInProject()
+ );
+ }
+
+ @Test
+ public void testToaster() throws Exception {
+
+ MBeanServer platformMBeanServer = ManagementFactory.getPlatformMBeanServer();
+ ObjectName providerOn = new ObjectName("org.opendaylight.controller:instanceName=toaster-provider-impl,type=RuntimeBean,moduleFactoryName=toaster-provider-impl");
+
+ long toastsMade = (long) platformMBeanServer.getAttribute(providerOn, "ToastsMade");
+ assertEquals(0, toastsMade);
+
+ boolean toasts = true;
+
+ // Make toasts using OSGi service
+ toasts &= kitchenService.makeBreakfast( EggsType.SCRAMBLED, HashBrown.class, 4);
+ toasts &= kitchenService.makeBreakfast( EggsType.POACHED, WhiteBread.class, 8 );
+
+ Assert.assertTrue("Not all toasts done by " + kitchenService, toasts);
+
+ // Verify toasts made count on provider via JMX/config-subsystem
+ toastsMade = (long) platformMBeanServer.getAttribute(providerOn, "ToastsMade");
+ assertEquals(2, toastsMade);
+ }