Merge "Reduce logged messages during build and concentrate only on the ones needed...
[controller.git] / opendaylight / md-sal / samples / toaster-it / src / test / java / org / opendaylight / controller / sample / toaster / it / ToasterTest.java
1 package org.opendaylight.controller.sample.toaster.it;
2
3 import org.junit.Test;
4 import org.junit.runner.RunWith;
5 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker;
6 import org.opendaylight.controller.sample.toaster.provider.api.ToastConsumer;
7 import org.opendaylight.yang.gen.v1.http.netconfcentral.org.ns.toaster.rev091120.WhiteBread;
8 import org.ops4j.pax.exam.Configuration;
9 import org.ops4j.pax.exam.Option;
10 import org.ops4j.pax.exam.junit.PaxExam;
11 import org.osgi.framework.BundleContext;
12
13 import javax.inject.Inject;
14
15 import static org.junit.Assert.assertTrue;
16 import static org.ops4j.pax.exam.CoreOptions.junitBundles;
17 import static org.ops4j.pax.exam.CoreOptions.mavenBundle;
18 import static org.ops4j.pax.exam.CoreOptions.options;
19 import static org.ops4j.pax.exam.CoreOptions.systemProperty;
20 import org.ops4j.pax.exam.util.PathUtils;
21
22 @RunWith(PaxExam.class)
23 public class ToasterTest {
24
25     public static final String ODL = "org.opendaylight.controller";
26     public static final String YANG = "org.opendaylight.yangtools";
27     public static final String CONTROLLER = "org.opendaylight.controller";
28     public static final String YANGTOOLS = "org.opendaylight.yangtools";
29     
30     
31     public static final String SAMPLE = "org.opendaylight.controller.samples";
32
33     @Test
34     public void properInitialized() throws Exception {
35
36         Thread.sleep(500); // Waiting for services to get wired.
37
38         assertTrue(consumer.createToast(WhiteBread.class, 5));
39
40     }
41
42     @Inject
43     BindingAwareBroker broker;
44
45     @Inject
46     ToastConsumer consumer;
47
48     @Inject
49     BundleContext ctx;
50
51     @Configuration
52     public Option[] config() {
53         return options(systemProperty("osgi.console").value("2401"), 
54                 systemProperty("logback.configurationFile").value(
55                     "file:" + PathUtils.getBaseDir()
56                     + "/src/test/resources/logback.xml"),
57                 mavenBundle("org.slf4j", "slf4j-api").versionAsInProject(), //
58                 mavenBundle("org.slf4j", "log4j-over-slf4j").versionAsInProject(), //
59                 mavenBundle("ch.qos.logback", "logback-core").versionAsInProject(), //
60                 mavenBundle("ch.qos.logback", "logback-classic").versionAsInProject(), //
61                 
62                 mavenBundle(ODL, "sal-common").versionAsInProject(), //
63                 mavenBundle(ODL, "sal-common-api").versionAsInProject(),//
64                 mavenBundle(ODL, "sal-common-impl").versionAsInProject(), //
65                 mavenBundle(ODL, "sal-common-util").versionAsInProject(), //
66                 
67                 mavenBundle(ODL, "config-api").versionAsInProject(), //
68                 mavenBundle(ODL, "config-manager").versionAsInProject(), //
69                 mavenBundle("commons-io", "commons-io").versionAsInProject(),
70                 mavenBundle("org.apache.commons", "commons-lang3").versionAsInProject(),
71                 
72                 mavenBundle(CONTROLLER, "sal-binding-api").versionAsInProject(), //
73                 mavenBundle(CONTROLLER, "sal-binding-config").versionAsInProject(),
74                 mavenBundle(CONTROLLER, "sal-binding-broker-impl").versionAsInProject(), //
75                 mavenBundle("org.javassist", "javassist").versionAsInProject(), //
76                 mavenBundle(CONTROLLER, "sal-common-util").versionAsInProject(), //
77         
78                 mavenBundle(YANGTOOLS, "yang-data-api").versionAsInProject(), //
79                 mavenBundle(YANGTOOLS, "yang-data-impl").versionAsInProject(), //
80                 mavenBundle(YANGTOOLS, "yang-model-api").versionAsInProject(), //
81                 mavenBundle(YANGTOOLS, "yang-model-util").versionAsInProject(), //
82                 mavenBundle(YANGTOOLS, "yang-parser-api").versionAsInProject(),
83                 mavenBundle(YANGTOOLS, "yang-parser-impl").versionAsInProject(),
84                 
85                 
86                 mavenBundle(YANGTOOLS, "binding-generator-spi").versionAsInProject(), //
87                 mavenBundle(YANGTOOLS, "binding-model-api").versionAsInProject(), //
88                 mavenBundle(YANGTOOLS, "binding-generator-util").versionAsInProject(),
89                 mavenBundle(YANGTOOLS, "yang-parser-impl").versionAsInProject(),
90                 mavenBundle(YANGTOOLS, "binding-type-provider").versionAsInProject(),
91                 mavenBundle(YANGTOOLS, "binding-generator-api").versionAsInProject(),
92                 mavenBundle(YANGTOOLS, "binding-generator-spi").versionAsInProject(),
93                 mavenBundle(YANGTOOLS, "binding-generator-impl").versionAsInProject(),
94                 
95                 
96                 mavenBundle(CONTROLLER, "sal-core-api").versionAsInProject().update(), //
97                 mavenBundle(CONTROLLER, "sal-broker-impl").versionAsInProject(), //
98                 mavenBundle(CONTROLLER, "sal-core-spi").versionAsInProject().update(), //
99                 
100                 mavenBundle(YANGTOOLS + ".thirdparty", "antlr4-runtime-osgi-nohead").versionAsInProject(), //
101                 
102                 mavenBundle(SAMPLE, "sample-toaster").versionAsInProject(), //
103                 mavenBundle(SAMPLE, "sample-toaster-consumer").versionAsInProject(), //
104                 mavenBundle(SAMPLE, "sample-toaster-provider").versionAsInProject(), //
105                 mavenBundle(YANG, "concepts").versionAsInProject(),
106                 mavenBundle(YANG, "yang-binding").versionAsInProject(), //
107                 mavenBundle(YANG, "yang-common").versionAsInProject(), //
108                 mavenBundle(YANG+".thirdparty", "xtend-lib-osgi").versionAsInProject(),
109                 mavenBundle("com.google.guava", "guava").versionAsInProject(), //
110                 mavenBundle("org.javassist", "javassist").versionAsInProject(),
111                 junitBundles()
112                 );
113     }
114
115 }