2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Copyright (C) 2017 Amdocs
8 * =============================================================================
9 * Licensed under the Apache License, Version 2.0 (the "License");
10 * you may not use this file except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
21 * ECOMP is a trademark and service mark of AT&T Intellectual Property.
22 * ============LICENSE_END=========================================================
25 package org.openecomp.appc;
27 import java.util.concurrent.ExecutorService;
28 import java.util.concurrent.Executors;
30 import org.junit.After;
31 import org.junit.Ignore;
32 import org.junit.Test;
33 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
34 import org.opendaylight.controller.md.sal.binding.test.AbstractDataBrokerTest;
35 import org.opendaylight.controller.sal.binding.api.NotificationProviderService;
36 import org.opendaylight.controller.sal.binding.api.RpcProviderRegistry;
37 import org.openecomp.appc.provider.AppcProvider;
40 * Defines a unit test class which tests the provider. This class leverages the AbstractDataBrokerTest class which
41 * starts a real MD-SAL implementation to use inside of your unit tests. This is not an exhaustive test, but rather is
42 * used to illustrate how one can leverage the AbstractDataBrokerTest to test MD-SAL providers/listeners.
44 public class AppcProviderTest extends AbstractDataBrokerTest {
46 private ExecutorService threadPool = Executors.newSingleThreadExecutor();
47 private AppcProvider provider;
48 private DataBroker dataBroker;
51 * The @Before annotation is defined in the AbstractDataBrokerTest class. The method setupWithDataBroker is invoked
52 * from inside the @Before method and is used to initialize the databroker with objects for a test runs. In our case
53 * we use this oportunity to create an instance of our provider and initialize it (which registers it as a listener
54 * etc). This method runs before every @Test method below.
57 protected void setupWithDataBroker(DataBroker dataBroker) {
58 super.setupWithDataBroker(dataBroker);
60 this.dataBroker = dataBroker;
61 NotificationProviderService nps = null;
62 RpcProviderRegistry registry = null;
64 provider = new AppcProvider(dataBroker, nps, registry);
68 * Shuts down our provider, testing close code. @After runs after every @Test method below.
71 public void stop() throws Exception {
72 if (provider != null) {
78 * This validates that when a task is created, the run count is initialized to 0
82 public void sampleUnitTest() {
83 // This is where you add your unit testing. You can access "DataBroker" as
84 // needed to create items etc.
85 // This a "Real" data broker.