2 * Copyright © 2021 Nokia, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.transportpce.tapi.connectivity;
10 import static org.junit.jupiter.api.Assertions.assertEquals;
11 import static org.junit.jupiter.api.Assertions.assertTrue;
12 import static org.mockito.ArgumentMatchers.any;
13 import static org.mockito.Mockito.when;
15 import com.google.common.util.concurrent.Futures;
16 import com.google.common.util.concurrent.ListenableFuture;
17 import com.google.common.util.concurrent.ListeningExecutorService;
18 import com.google.common.util.concurrent.MoreExecutors;
19 import java.util.HashMap;
20 import java.util.concurrent.CountDownLatch;
21 import java.util.concurrent.ExecutionException;
22 import java.util.concurrent.Executors;
23 import org.junit.jupiter.api.BeforeEach;
24 import org.junit.jupiter.api.Test;
25 import org.junit.jupiter.api.extension.ExtendWith;
26 import org.mockito.Mock;
27 import org.mockito.junit.jupiter.MockitoExtension;
28 import org.opendaylight.mdsal.binding.api.NotificationPublishService;
29 import org.opendaylight.transportpce.common.InstanceIdentifiers;
30 import org.opendaylight.transportpce.common.network.NetworkTransactionImpl;
31 import org.opendaylight.transportpce.common.network.NetworkTransactionService;
32 import org.opendaylight.transportpce.pce.service.PathComputationService;
33 import org.opendaylight.transportpce.renderer.provisiondevice.RendererServiceOperations;
34 import org.opendaylight.transportpce.servicehandler.impl.ServicehandlerImpl;
35 import org.opendaylight.transportpce.servicehandler.listeners.NetworkModelListenerImpl;
36 import org.opendaylight.transportpce.servicehandler.listeners.PceListenerImpl;
37 import org.opendaylight.transportpce.servicehandler.listeners.RendererListenerImpl;
38 import org.opendaylight.transportpce.servicehandler.service.ServiceDataStoreOperations;
39 import org.opendaylight.transportpce.servicehandler.service.ServiceDataStoreOperationsImpl;
40 import org.opendaylight.transportpce.tapi.listeners.TapiPceListenerImpl;
41 import org.opendaylight.transportpce.tapi.listeners.TapiRendererListenerImpl;
42 import org.opendaylight.transportpce.tapi.listeners.TapiServiceHandlerListenerImpl;
43 import org.opendaylight.transportpce.tapi.topology.TopologyUtils;
44 import org.opendaylight.transportpce.tapi.utils.TapiConnectivityDataUtils;
45 import org.opendaylight.transportpce.tapi.utils.TapiContext;
46 import org.opendaylight.transportpce.tapi.utils.TapiInitialORMapping;
47 import org.opendaylight.transportpce.tapi.utils.TapiLink;
48 import org.opendaylight.transportpce.tapi.utils.TapiTopologyDataUtils;
49 import org.opendaylight.transportpce.test.AbstractTest;
50 import org.opendaylight.transportpce.test.utils.TopologyDataUtils;
51 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.OrgOpenroadmServiceService;
52 import org.opendaylight.yang.gen.v1.http.org.openroadm.service.rev211210.ServiceCreateInput;
53 import org.opendaylight.yang.gen.v1.urn.onf.otcc.yang.tapi.connectivity.rev181210.CreateConnectivityServiceInput;
54 import org.opendaylight.yang.gen.v1.urn.onf.otcc.yang.tapi.connectivity.rev181210.CreateConnectivityServiceInputBuilder;
55 import org.opendaylight.yang.gen.v1.urn.onf.otcc.yang.tapi.connectivity.rev181210.CreateConnectivityServiceOutput;
56 import org.opendaylight.yang.gen.v1.urn.onf.otcc.yang.tapi.connectivity.rev181210.DeleteConnectivityServiceInput;
57 import org.opendaylight.yang.gen.v1.urn.onf.otcc.yang.tapi.connectivity.rev181210.DeleteConnectivityServiceInputBuilder;
58 import org.opendaylight.yang.gen.v1.urn.onf.otcc.yang.tapi.connectivity.rev181210.DeleteConnectivityServiceOutput;
59 import org.opendaylight.yangtools.yang.common.ErrorType;
60 import org.opendaylight.yangtools.yang.common.RpcResult;
61 import org.slf4j.Logger;
62 import org.slf4j.LoggerFactory;
64 @ExtendWith(MockitoExtension.class)
65 public class TapiConnectivityImplTest extends AbstractTest {
68 private PathComputationService pathComputationService;
70 private RendererServiceOperations rendererServiceOperations;
72 private NotificationPublishService notificationPublishService;
74 private TapiPceListenerImpl tapipceListenerImpl;
76 private TapiRendererListenerImpl tapirendererListenerImpl;
78 private TapiServiceHandlerListenerImpl tapiserviceHandlerListenerImpl;
80 private PceListenerImpl pceListenerImpl;
82 private RendererListenerImpl rendererListenerImpl;
84 private NetworkModelListenerImpl networkModelListenerImpl;
86 private static final Logger LOG = LoggerFactory.getLogger(TapiConnectivityImplTest.class);
87 private static ServiceDataStoreOperations serviceDataStoreOperations;
88 private static TapiContext tapiContext;
89 private static TopologyUtils topologyUtils;
90 private static ConnectivityUtils connectivityUtils;
91 private static TapiInitialORMapping tapiInitialORMapping;
92 private static NetworkTransactionService networkTransactionService;
93 private static TapiLink tapilink;
94 private ListeningExecutorService executorService;
95 private CountDownLatch endSignal;
96 private static final int NUM_THREADS = 5;
99 void setUp() throws InterruptedException, ExecutionException {
100 executorService = MoreExecutors.listeningDecorator(Executors.newFixedThreadPool(NUM_THREADS));
101 endSignal = new CountDownLatch(1);
102 // Need to have datastore populated to enable the mapping from TAPI to OR
103 TopologyDataUtils.writeTopologyFromFileToDatastore(getDataStoreContextUtil(),
104 TapiTopologyDataUtils.OPENROADM_TOPOLOGY_FILE, InstanceIdentifiers.OVERLAY_NETWORK_II);
105 TopologyDataUtils.writeTopologyFromFileToDatastore(getDataStoreContextUtil(),
106 TapiTopologyDataUtils.OPENROADM_NETWORK_FILE, InstanceIdentifiers.UNDERLAY_NETWORK_II);
107 TopologyDataUtils.writeTopologyFromFileToDatastore(getDataStoreContextUtil(),
108 TapiTopologyDataUtils.OTN_TOPOLOGY_FILE, InstanceIdentifiers.OTN_NETWORK_II);
109 TopologyDataUtils.writePortmappingFromFileToDatastore(getDataStoreContextUtil(),
110 TapiTopologyDataUtils.PORTMAPPING_FILE);
112 networkTransactionService = new NetworkTransactionImpl(getDataBroker());
113 tapilink = new TapiLink(networkTransactionService);
114 serviceDataStoreOperations = new ServiceDataStoreOperationsImpl(getDataStoreContextUtil().getDataBroker());
115 tapiContext = new TapiContext(networkTransactionService);
116 topologyUtils = new TopologyUtils(networkTransactionService, getDataStoreContextUtil().getDataBroker(),
118 connectivityUtils = new ConnectivityUtils(serviceDataStoreOperations, new HashMap<>(), tapiContext,
119 networkTransactionService);
120 tapiInitialORMapping = new TapiInitialORMapping(topologyUtils, connectivityUtils,
121 tapiContext, serviceDataStoreOperations);
122 tapiInitialORMapping.performTopoInitialMapping();
123 LOG.info("setup done");
127 void createConnServiceShouldBeFailedWithEmptyInput() throws ExecutionException, InterruptedException {
128 OrgOpenroadmServiceService serviceHandler = new ServicehandlerImpl(getNewDataBroker(), pathComputationService,
129 rendererServiceOperations, notificationPublishService, pceListenerImpl, rendererListenerImpl,
130 networkModelListenerImpl, serviceDataStoreOperations);
132 TapiConnectivityImpl tapiConnectivity = new TapiConnectivityImpl(serviceHandler, tapiContext, connectivityUtils,
133 tapipceListenerImpl, tapirendererListenerImpl);
135 ListenableFuture<RpcResult<CreateConnectivityServiceOutput>> result =
136 tapiConnectivity.createConnectivityService(new CreateConnectivityServiceInputBuilder().build());
137 result.addListener(new Runnable() {
140 endSignal.countDown();
146 RpcResult<CreateConnectivityServiceOutput> rpcResult = result.get();
147 assertEquals(ErrorType.RPC, rpcResult.getErrors().get(0).getErrorType());
151 void createConnServiceShouldBeSuccessfulWhenPerformPCESuccessful()
152 throws ExecutionException, InterruptedException {
153 OrgOpenroadmServiceService serviceHandler = new ServicehandlerImpl(getNewDataBroker(), pathComputationService,
154 rendererServiceOperations, notificationPublishService, pceListenerImpl, rendererListenerImpl,
155 networkModelListenerImpl, serviceDataStoreOperations);
157 CreateConnectivityServiceInput input = TapiConnectivityDataUtils.buildConnServiceCreateInput();
158 when(pathComputationService.pathComputationRequest(any())).thenReturn(Futures.immediateFuture(any()));
160 TapiConnectivityImpl tapiConnectivity = new TapiConnectivityImpl(serviceHandler, tapiContext, connectivityUtils,
161 tapipceListenerImpl, tapirendererListenerImpl);
162 ListenableFuture<RpcResult<CreateConnectivityServiceOutput>> result =
163 tapiConnectivity.createConnectivityService(input);
164 result.addListener(new Runnable() {
167 endSignal.countDown();
173 RpcResult<CreateConnectivityServiceOutput> rpcResult = result.get();
174 assertTrue(rpcResult.isSuccessful());
178 void deleteConnServiceShouldBeFailedWithEmptyInput() throws ExecutionException, InterruptedException {
179 OrgOpenroadmServiceService serviceHandler = new ServicehandlerImpl(getNewDataBroker(), pathComputationService,
180 rendererServiceOperations, notificationPublishService, pceListenerImpl, rendererListenerImpl,
181 networkModelListenerImpl, serviceDataStoreOperations);
183 TapiConnectivityImpl tapiConnectivity = new TapiConnectivityImpl(serviceHandler, tapiContext, connectivityUtils,
184 tapipceListenerImpl, tapirendererListenerImpl);
186 ListenableFuture<RpcResult<DeleteConnectivityServiceOutput>> result =
187 tapiConnectivity.deleteConnectivityService(new DeleteConnectivityServiceInputBuilder().build());
188 result.addListener(new Runnable() {
191 endSignal.countDown();
197 RpcResult<DeleteConnectivityServiceOutput> rpcResult = result.get();
198 assertEquals(ErrorType.RPC, rpcResult.getErrors().get(0).getErrorType());
202 void deleteConnServiceShouldBeFailedWithNonExistService() throws ExecutionException, InterruptedException {
203 DeleteConnectivityServiceInput input = TapiConnectivityDataUtils.buildConnServiceDeleteInput1();
204 OrgOpenroadmServiceService serviceHandler = new ServicehandlerImpl(getNewDataBroker(), pathComputationService,
205 rendererServiceOperations, notificationPublishService, pceListenerImpl, rendererListenerImpl,
206 networkModelListenerImpl, serviceDataStoreOperations);
208 TapiConnectivityImpl tapiConnectivity = new TapiConnectivityImpl(serviceHandler, tapiContext, connectivityUtils,
209 tapipceListenerImpl, tapirendererListenerImpl);
210 ListenableFuture<RpcResult<DeleteConnectivityServiceOutput>> result =
211 tapiConnectivity.deleteConnectivityService(input);
212 result.addListener(new Runnable() {
215 endSignal.countDown();
221 RpcResult<DeleteConnectivityServiceOutput> rpcResult = result.get();
222 assertEquals(ErrorType.RPC, rpcResult.getErrors().get(0).getErrorType());
226 void deleteConnServiceShouldBeSuccessForExistingService() throws ExecutionException, InterruptedException {
227 when(rendererServiceOperations.serviceDelete(any(), any())).thenReturn(Futures.immediateFuture(any()));
229 OrgOpenroadmServiceService serviceHandler = new ServicehandlerImpl(getNewDataBroker(), pathComputationService,
230 rendererServiceOperations, notificationPublishService, pceListenerImpl, rendererListenerImpl,
231 networkModelListenerImpl, serviceDataStoreOperations);
233 TapiConnectivityImpl tapiConnectivity = new TapiConnectivityImpl(serviceHandler, tapiContext, connectivityUtils,
234 tapipceListenerImpl, tapirendererListenerImpl);
236 ServiceCreateInput createInput = TapiConnectivityDataUtils.buildServiceCreateInput();
237 serviceDataStoreOperations.createService(createInput);
238 tapiContext.updateConnectivityContext(TapiConnectivityDataUtils.createConnService(), new HashMap<>());
240 DeleteConnectivityServiceInput input = TapiConnectivityDataUtils.buildConnServiceDeleteInput();
241 ListenableFuture<RpcResult<DeleteConnectivityServiceOutput>> result =
242 tapiConnectivity.deleteConnectivityService(input);
243 result.addListener(new Runnable() {
246 endSignal.countDown();
252 RpcResult<DeleteConnectivityServiceOutput> rpcResult = result.get();
253 assertTrue(rpcResult.isSuccessful());