X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=renderer%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Ftransportpce%2Frenderer%2Fprovisiondevice%2FRendererServiceOperationsImplTest.java;h=4eeea0a5fb91a9f9e9d0f0033a5c599e515cacae;hb=b1b3bafd549bb501937cea5c976d5344608b6ed3;hp=006a002bf1023e8d4308ccc7c675b6a3b2b9e869;hpb=810038f95e82b0564c11ad5ba0f3f2813bc04a48;p=transportpce.git diff --git a/renderer/src/test/java/org/opendaylight/transportpce/renderer/provisiondevice/RendererServiceOperationsImplTest.java b/renderer/src/test/java/org/opendaylight/transportpce/renderer/provisiondevice/RendererServiceOperationsImplTest.java index 006a002bf..4eeea0a5f 100644 --- a/renderer/src/test/java/org/opendaylight/transportpce/renderer/provisiondevice/RendererServiceOperationsImplTest.java +++ b/renderer/src/test/java/org/opendaylight/transportpce/renderer/provisiondevice/RendererServiceOperationsImplTest.java @@ -5,168 +5,278 @@ * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ - package org.opendaylight.transportpce.renderer.provisiondevice; -import com.google.common.util.concurrent.ListeningExecutorService; -import com.google.common.util.concurrent.MoreExecutors; -import java.util.concurrent.Executors; -import org.junit.Assert; -import org.junit.Before; -import org.junit.Test; -import org.opendaylight.controller.md.sal.binding.api.MountPoint; -import org.opendaylight.controller.md.sal.binding.api.MountPointService; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.mockito.ArgumentMatchers.any; +import static org.mockito.ArgumentMatchers.eq; +import static org.mockito.Mockito.doReturn; +import static org.mockito.Mockito.when; + +import java.util.ArrayList; +import java.util.List; +import java.util.concurrent.ExecutionException; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Disabled; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.ExtendWith; +import org.mockito.Mock; +import org.mockito.junit.jupiter.MockitoExtension; +import org.opendaylight.mdsal.binding.api.DataBroker; +import org.opendaylight.mdsal.binding.api.NotificationPublishService; +import org.opendaylight.mdsal.binding.api.RpcService; import org.opendaylight.transportpce.common.ResponseCodes; -import org.opendaylight.transportpce.common.crossconnect.CrossConnect; -import org.opendaylight.transportpce.common.crossconnect.CrossConnectImpl; -import org.opendaylight.transportpce.common.device.DeviceTransactionManager; -import org.opendaylight.transportpce.common.device.DeviceTransactionManagerImpl; +import org.opendaylight.transportpce.common.StringConstants; import org.opendaylight.transportpce.common.mapping.PortMapping; -import org.opendaylight.transportpce.common.mapping.PortMappingImpl; -import org.opendaylight.transportpce.common.openroadminterfaces.OpenRoadmInterfaces; -import org.opendaylight.transportpce.common.openroadminterfaces.OpenRoadmInterfacesImpl; -import org.opendaylight.transportpce.renderer.NetworkModelWavelengthService; -import org.opendaylight.transportpce.renderer.NetworkModelWavelengthServiceImpl; -import org.opendaylight.transportpce.renderer.openroadminterface.OpenRoadmInterfaceFactory; -import org.opendaylight.transportpce.renderer.stub.MountPointServiceStub; -import org.opendaylight.transportpce.renderer.stub.MountPointStub; -import org.opendaylight.transportpce.renderer.stub.OlmServiceStub; -import org.opendaylight.transportpce.renderer.utils.MountPointUtils; +import org.opendaylight.transportpce.common.openroadminterfaces.OpenRoadmInterfaceException; +import org.opendaylight.transportpce.renderer.provisiondevice.notification.NotificationSender; +import org.opendaylight.transportpce.renderer.utils.NotificationPublishServiceMock; import org.opendaylight.transportpce.renderer.utils.ServiceDataUtils; -import org.opendaylight.transportpce.test.AbstractTest; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev170426.ServiceImplementationRequestInput; -import org.opendaylight.yang.gen.v1.http.org.transportpce.b.c._interface.servicepath.rev170426.ServiceImplementationRequestOutput; -import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.olm.rev170418.OlmService; - +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.device.renderer.rev211004.RendererRollbackInputBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.device.renderer.rev211004.RendererRollbackOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.device.renderer.rev211004.ServicePathOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.GetPm; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.GetPmInput; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.GetPmInputBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.GetPmOutput; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.GetPmOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.ServicePowerSetup; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.ServicePowerSetupOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.ServicePowerTurndown; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.ServicePowerTurndownOutputBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.get.pm.output.Measurements; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.olm.rev210618.get.pm.output.MeasurementsBuilder; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915.ServiceImplementationRequestInput; +import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.renderer.rev210915.ServiceImplementationRequestOutput; +import org.opendaylight.yang.gen.v1.http.org.openroadm.resource.types.rev161014.ResourceTypeEnum; +import org.opendaylight.yang.gen.v1.http.org.transportpce.common.types.rev220926.PmGranularity; +import org.opendaylight.yang.gen.v1.http.org.transportpce.common.types.rev220926.olm.get.pm.input.ResourceIdentifierBuilder; +import org.opendaylight.yangtools.yang.common.RpcResultBuilder; +@ExtendWith(MockitoExtension.class) +public class RendererServiceOperationsImplTest { -public class RendererServiceOperationsImplTest extends AbstractTest { - - private static final int NUMBER_OF_THREADS = 4; - private MountPointService mountPointService; - private DeviceTransactionManager deviceTransactionManager; - private RendererServiceOperationsImpl rendererServiceOperations; - private OpenRoadmInterfaces openRoadmInterfaces; + @Mock private DeviceRendererService deviceRenderer; + @Mock + private OtnDeviceRendererService otnDeviceRendererService; + @Mock + private DataBroker dataBroker; + @Mock private PortMapping portMapping; - private OpenRoadmInterfaceFactory openRoadmInterfaceFactory; - private CrossConnect crossConnect; - private OlmService olmService; - private ListeningExecutorService executor; - private NetworkModelWavelengthService networkModelWavelengthService; - - private void setMountPoint(MountPoint mountPoint) { - this.mountPointService = new MountPointServiceStub(mountPoint); - this.deviceTransactionManager = new DeviceTransactionManagerImpl(this.mountPointService, 3000); - this.openRoadmInterfaces = new OpenRoadmInterfacesImpl(this.deviceTransactionManager); - this.portMapping = new PortMappingImpl(this.getDataBroker(), this.deviceTransactionManager, - openRoadmInterfaces); - this.openRoadmInterfaceFactory = new OpenRoadmInterfaceFactory(portMapping, - openRoadmInterfaces); - this.crossConnect = new CrossConnectImpl(this.deviceTransactionManager); - this.deviceRenderer = new DeviceRendererServiceImpl(this.getDataBroker(), - this.deviceTransactionManager, openRoadmInterfaceFactory, openRoadmInterfaces, crossConnect, portMapping); + @Mock + private RpcService rpcService; + @Mock + private ServicePowerSetup servicePowerSetup; + @Mock + private ServicePowerTurndown servicePowerTurndown; + @Mock + private GetPm getPm; + private RendererServiceOperationsImpl rendererServiceOperations; + + + @BeforeEach + void setUp() throws OpenRoadmInterfaceException { + NotificationPublishService notificationPublishService = new NotificationPublishServiceMock(); + this.rendererServiceOperations = new RendererServiceOperationsImpl(deviceRenderer, otnDeviceRendererService, + dataBroker, new NotificationSender(notificationPublishService), portMapping, rpcService); } - @Before - public void setUp() { - setMountPoint(new MountPointStub(getDataBroker())); - this.olmService = new OlmServiceStub(); - this.executor = MoreExecutors.listeningDecorator(Executors.newFixedThreadPool(NUMBER_OF_THREADS)); - this.networkModelWavelengthService = new NetworkModelWavelengthServiceImpl(getDataBroker()); - this.rendererServiceOperations = new RendererServiceOperationsImpl(this.deviceRenderer, this.olmService, - getDataBroker(), this.networkModelWavelengthService); + @Test + void serviceImplementationTerminationPointAsResourceTtp() throws InterruptedException, ExecutionException { + ServiceImplementationRequestInput input = ServiceDataUtils + .buildServiceImplementationRequestInputTerminationPointResource(StringConstants.TTP_TOKEN); + when(deviceRenderer.setupServicePath(any(), any(), any())) + .thenReturn(new ServicePathOutputBuilder().setResult("success").setSuccess(true).build()); + when(rpcService.getRpc(ServicePowerSetup.class)).thenReturn(servicePowerSetup); + when(rpcService.getRpc(ServicePowerTurndown.class)).thenReturn(servicePowerTurndown); + when(rpcService.getRpc(GetPm.class)).thenReturn(getPm); + doReturn(RpcResultBuilder + .success(new ServicePowerSetupOutputBuilder().setResult(ResponseCodes.SUCCESS_RESULT).build()) + .buildFuture()).when(servicePowerSetup).invoke(any()); + doReturn(RpcResultBuilder.success(new GetPmOutputBuilder().setNodeId("node id").build()).buildFuture()) + .when(getPm).invoke(any()); + ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input, false) + .get(); + assertEquals(ResponseCodes.RESPONSE_OK, result.getConfigurationResponseCommon().getResponseCode()); } + @Test + void serviceImplementationTerminationPointAsResourceTtp2() throws InterruptedException, ExecutionException { + ServiceImplementationRequestInput input = ServiceDataUtils + .buildServiceImplementationRequestInputTerminationPointResource(StringConstants.TTP_TOKEN); + ServicePathOutputBuilder mockOutputBuilder = new ServicePathOutputBuilder().setResult("success") + .setSuccess(true); + doReturn(mockOutputBuilder.build()).when(this.deviceRenderer).setupServicePath(any(), any(), any()); + when(rpcService.getRpc(ServicePowerSetup.class)).thenReturn(servicePowerSetup); + doReturn(RpcResultBuilder.failed().buildFuture()).when(servicePowerSetup).invoke(any()); + ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input, false) + .get(); + assertEquals(ResponseCodes.RESPONSE_FAILED, result.getConfigurationResponseCommon().getResponseCode()); + } @Test - public void serviceImplementationTerminationPointAsResourceTtp() { + void serviceImplementationTerminationPointAsResourceNoMapping() throws InterruptedException, ExecutionException { + // when no mapping available, 100GE between transponders must be implemented - ServiceImplementationRequestInput input = ServiceDataUtils - .buildServiceImplementationRequestInputTerminationPointResource(OpenRoadmInterfacesImpl.TTP_TOKEN); - writePortMapping(input, OpenRoadmInterfacesImpl.TTP_TOKEN); - ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input); - Assert.assertEquals(ResponseCodes.RESPONSE_OK, result.getConfigurationResponseCommon().getResponseCode()); + when(deviceRenderer.setupServicePath(any(), any(), any())) + .thenReturn(new ServicePathOutputBuilder().setResult("success").setSuccess(true).build()); + when(rpcService.getRpc(ServicePowerSetup.class)).thenReturn(servicePowerSetup); + when(rpcService.getRpc(ServicePowerTurndown.class)).thenReturn(servicePowerTurndown); + when(rpcService.getRpc(GetPm.class)).thenReturn(getPm); + doReturn(RpcResultBuilder + .success(new ServicePowerSetupOutputBuilder().setResult(ResponseCodes.SUCCESS_RESULT).build()) + .buildFuture()).when(servicePowerSetup).invoke(any()); + doReturn(RpcResultBuilder.success(new GetPmOutputBuilder().setNodeId("node id").build()).buildFuture()) + .when(getPm).invoke(any()); + + String[] interfaceTokens = { StringConstants.NETWORK_TOKEN, StringConstants.CLIENT_TOKEN, + StringConstants.TTP_TOKEN, StringConstants.PP_TOKEN }; + for (String tpToken : interfaceTokens) { + ServiceImplementationRequestInput input = ServiceDataUtils + .buildServiceImplementationRequestInputTerminationPointResource(tpToken); + ServiceImplementationRequestOutput result = this.rendererServiceOperations + .serviceImplementation(input, false).get(); + assertEquals(ResponseCodes.RESPONSE_OK, result.getConfigurationResponseCommon().getResponseCode()); + } } @Test - public void serviceImplementationTerminationPointAsResourcePp() { + void serviceImplementationRollbackAllNecessary() throws InterruptedException, ExecutionException { + ServiceImplementationRequestInput input = ServiceDataUtils + .buildServiceImplementationRequestInputTerminationPointResource(StringConstants.NETWORK_TOKEN); + when(deviceRenderer.setupServicePath(any(), any())) + .thenReturn(new ServicePathOutputBuilder().setResult("success").setSuccess(true).build()); + when(rpcService.getRpc(ServicePowerSetup.class)).thenReturn(servicePowerSetup); + when(rpcService.getRpc(ServicePowerTurndown.class)).thenReturn(servicePowerTurndown); + doReturn(RpcResultBuilder + .success(new ServicePowerSetupOutputBuilder().setResult(ResponseCodes.RESPONSE_FAILED).build()) + .buildFuture()).when(servicePowerSetup).invoke(any()); + doReturn(RpcResultBuilder + .success(new ServicePowerTurndownOutputBuilder().setResult(ResponseCodes.SUCCESS_RESULT).build()) + .buildFuture()).when(servicePowerTurndown).invoke(any()); + when(deviceRenderer.rendererRollback(new RendererRollbackInputBuilder().build())) + .thenReturn(new RendererRollbackOutputBuilder().setSuccess(true).build()); + ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input, false) + .get(); + assertEquals(ResponseCodes.RESPONSE_FAILED, result.getConfigurationResponseCommon().getResponseCode()); + } + @Disabled("Disabled until we understand the author objective...") + @Test + void serviceImplementationServiceInActive() throws InterruptedException, ExecutionException { ServiceImplementationRequestInput input = ServiceDataUtils - .buildServiceImplementationRequestInputTerminationPointResource(OpenRoadmInterfacesImpl.PP_TOKEN); - writePortMapping(input, OpenRoadmInterfacesImpl.PP_TOKEN); - ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input); - Assert.assertEquals(ResponseCodes.RESPONSE_OK, result.getConfigurationResponseCommon().getResponseCode()); + .buildServiceImplementationRequestInputTerminationPointResource(StringConstants.NETWORK_TOKEN); + List measurementsList = new ArrayList(); + measurementsList.add(new MeasurementsBuilder().setPmparameterName("FECUncorrectableBlocks") + .setPmparameterValue("1").build()); + GetPmOutput getPmOutput = new GetPmOutputBuilder().setNodeId("node1").setMeasurements(measurementsList).build(); + doReturn(RpcResultBuilder.success(getPmOutput).buildFuture()).when(getPm).invoke(any()); + ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input, false) + .get(); + assertEquals(ResponseCodes.RESPONSE_FAILED, result.getConfigurationResponseCommon().getResponseCode()); + } + + @Disabled("Disabled until we understand the author objective...") + @Test + void serviceImplementationServiceInActive3() throws InterruptedException, ExecutionException { + when(rpcService.getRpc(ServicePowerSetup.class)).thenReturn(servicePowerSetup); + List measurementsList = new ArrayList(); + measurementsList.add(new MeasurementsBuilder().setPmparameterName("FECUncorrectableBlocks") + .setPmparameterValue("1").build()); + GetPmOutput getPmOutput = new GetPmOutputBuilder().setNodeId("node1").setMeasurements(measurementsList).build(); + GetPmOutput getPmOutput2 = new GetPmOutputBuilder().setNodeId("node1").setMeasurements(new ArrayList<>()) + .build(); + GetPmInput getPmInputZ = createGetPmInput("XPONDER-2-3", StringConstants.NETWORK_TOKEN); + GetPmInput getPmInputA = createGetPmInput("XPONDER-1-2", StringConstants.NETWORK_TOKEN); + + when(getPm.invoke(eq(getPmInputZ))).thenReturn(RpcResultBuilder.success(getPmOutput2).buildFuture()); + when(getPm.invoke(eq(getPmInputA))).thenReturn(RpcResultBuilder.success(getPmOutput).buildFuture()); + ServicePathOutputBuilder mockOutputBuilder = new ServicePathOutputBuilder().setResult("success") + .setSuccess(true); + doReturn(mockOutputBuilder.build()).when(this.deviceRenderer).setupServicePath(any(), any(), any()); + ServiceImplementationRequestInput input = ServiceDataUtils + .buildServiceImplementationRequestInputTerminationPointResource(StringConstants.NETWORK_TOKEN); + ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input, false) + .get(); + assertEquals(ResponseCodes.RESPONSE_FAILED, result.getConfigurationResponseCommon().getResponseCode()); } -// @Test -// public void serviceImplementationTerminationPointAsResourceNetwork() { -// -// ServiceImplementationRequestInput input = ServiceDataUtils -// .buildServiceImplementationRequestInputTerminationPointResource(OpenRoadmInterfacesImpl.NETWORK_TOKEN); -// writePortMapping(input, OpenRoadmInterfacesImpl.NETWORK_TOKEN); -// ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input); -// Assert.assertEquals(ResponseCodes.RESPONSE_OK, result.getConfigurationResponseCommon().getResponseCode()); -// -// } -// -// @Test -// public void serviceImplementationTerminationPointAsResourceClient() { -// ServiceImplementationRequestInput input = ServiceDataUtils -// .buildServiceImplementationRequestInputTerminationPointResource(OpenRoadmInterfacesImpl.CLIENT_TOKEN); -// writePortMapping(input, OpenRoadmInterfacesImpl.CLIENT_TOKEN); -// ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input); -// Assert.assertEquals(ResponseCodes.RESPONSE_OK, result.getConfigurationResponseCommon().getResponseCode()); -// } -// -// @Test -// public void serviceImplementationTerminationPointAsResourceNoMapping() { -// String[] interfaceTokens = { -// OpenRoadmInterfacesImpl.NETWORK_TOKEN, -// OpenRoadmInterfacesImpl.CLIENT_TOKEN, -// OpenRoadmInterfacesImpl.TTP_TOKEN, -// OpenRoadmInterfacesImpl.PP_TOKEN -// }; -// for (String tpToken : interfaceTokens) { -// ServiceImplementationRequestInput input = ServiceDataUtils -// .buildServiceImplementationRequestInputTerminationPointResource(tpToken); -// ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input); -// Assert.assertEquals(ResponseCodes.RESPONSE_FAILED, -// result.getConfigurationResponseCommon().getResponseCode()); -// } -// } - - private void writePortMapping(ServiceImplementationRequestInput input, String tpToken) { - MountPointUtils.writeMapping( - input.getServiceAEnd().getNodeId(), - input.getServiceAEnd().getNodeId() + "-" + tpToken, - this.deviceTransactionManager - ); - MountPointUtils.writeMapping( - input.getServiceZEnd().getNodeId(), - input.getServiceZEnd().getNodeId() + "-" + tpToken, - this.deviceTransactionManager - ); + @Test + void serviceImplementationServiceActive() throws InterruptedException, ExecutionException { + ServiceImplementationRequestInput input = ServiceDataUtils + .buildServiceImplementationRequestInputTerminationPointResource(StringConstants.NETWORK_TOKEN); + when(deviceRenderer.setupServicePath(any(), any(), any())) + .thenReturn(new ServicePathOutputBuilder().setResult("success").setSuccess(true).build()); + + when(rpcService.getRpc(ServicePowerSetup.class)).thenReturn(servicePowerSetup); + when(rpcService.getRpc(ServicePowerTurndown.class)).thenReturn(servicePowerTurndown); + when(rpcService.getRpc(GetPm.class)).thenReturn(getPm); + doReturn(RpcResultBuilder + .success(new ServicePowerSetupOutputBuilder().setResult(ResponseCodes.SUCCESS_RESULT).build()) + .buildFuture()).when(servicePowerSetup).invoke(any()); + GetPmOutput getPmOutput1 = null; + when(getPm.invoke(any())).thenReturn(RpcResultBuilder.success(getPmOutput1).buildFuture()); + ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input, false) + .get(); + assertEquals(ResponseCodes.RESPONSE_OK, result.getConfigurationResponseCommon().getResponseCode()); } - /*@Test - public void serviceImplementationLinkAsResource() { - ServiceImplementationRequestInput input = ServiceDataUtils.buildServiceImplementationRequestInputLinkResource(); - ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input); - Assert.assertEquals(ResponseCodes.RESPONSE_OK, result.getConfigurationResponseCommon().getResponseCode()); - }*/ + @Test + void serviceImplementationServiceInActive4() throws InterruptedException, ExecutionException { + when(deviceRenderer.setupServicePath(any(), any(), any())) + .thenReturn(new ServicePathOutputBuilder().setResult("success").setSuccess(true).build()); - /*@Test - public void serviceImplementtionInvalidResource() { + when(rpcService.getRpc(ServicePowerSetup.class)).thenReturn(servicePowerSetup); + when(rpcService.getRpc(ServicePowerTurndown.class)).thenReturn(servicePowerTurndown); + when(rpcService.getRpc(GetPm.class)).thenReturn(getPm); + doReturn(RpcResultBuilder + .success(new ServicePowerSetupOutputBuilder().setResult(ResponseCodes.SUCCESS_RESULT).build()) + .buildFuture()).when(servicePowerSetup).invoke(any()); + + List measurementsList = new ArrayList(); + measurementsList.add( + new MeasurementsBuilder().setPmparameterName("preFECCorrectedErrors").setPmparameterValue("1").build()); + GetPmOutput getPmOutput = new GetPmOutputBuilder().setNodeId("node1").setMeasurements(measurementsList).build(); + when(getPm.invoke(any())).thenReturn(RpcResultBuilder.success(getPmOutput).buildFuture()); ServiceImplementationRequestInput input = ServiceDataUtils - .buildServiceImplementationRequestInputInvalidResource(); - ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input); - Assert.assertEquals(ResponseCodes.RESPONSE_FAILED, result.getConfigurationResponseCommon().getResponseCode()); + .buildServiceImplementationRequestInputTerminationPointResource(StringConstants.NETWORK_TOKEN); + ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input, false) + .get(); + assertEquals(ResponseCodes.RESPONSE_OK, result.getConfigurationResponseCommon().getResponseCode()); + } + + @Test + void serviceImplementationServiceInActive5() throws InterruptedException, ExecutionException { + when(deviceRenderer.setupServicePath(any(), any(), any())) + .thenReturn(new ServicePathOutputBuilder().setResult("success").setSuccess(true).build()); + when(rpcService.getRpc(ServicePowerSetup.class)).thenReturn(servicePowerSetup); + when(rpcService.getRpc(ServicePowerTurndown.class)).thenReturn(servicePowerTurndown); + when(rpcService.getRpc(GetPm.class)).thenReturn(getPm); + doReturn(RpcResultBuilder + .success(new ServicePowerSetupOutputBuilder().setResult(ResponseCodes.SUCCESS_RESULT).build()) + .buildFuture()).when(servicePowerSetup).invoke(any()); - }*/ + List measurementsList = new ArrayList(); + measurementsList.add(new MeasurementsBuilder().setPmparameterName("preFECCorrectedErrors") + .setPmparameterValue("112000000000d").build()); + GetPmOutput getPmOutput = new GetPmOutputBuilder().setNodeId("node1").setMeasurements(measurementsList).build(); + when(getPm.invoke(any())).thenReturn(RpcResultBuilder.success(getPmOutput).buildFuture()); -} + ServiceImplementationRequestInput input = ServiceDataUtils + .buildServiceImplementationRequestInputTerminationPointResource(StringConstants.NETWORK_TOKEN); + ServiceImplementationRequestOutput result = this.rendererServiceOperations.serviceImplementation(input, false) + .get(); + assertEquals(ResponseCodes.RESPONSE_FAILED, result.getConfigurationResponseCommon().getResponseCode()); + } + + private GetPmInput createGetPmInput(String nodeId, String tp) { + return new GetPmInputBuilder().setNodeId(nodeId).setGranularity(PmGranularity._15min) + .setResourceIdentifier(new ResourceIdentifierBuilder().setResourceName(tp + "-OTU").build()) + .setResourceType(ResourceTypeEnum.Interface).build(); + } +} \ No newline at end of file