/* * Copyright (c) 2015 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * 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.openflowplugin.impl.statistics.services; import com.google.common.util.concurrent.FutureCallback; import java.util.concurrent.Future; import org.junit.Assert; import org.junit.Test; import org.mockito.ArgumentCaptor; import org.mockito.Captor; import org.mockito.Matchers; import org.mockito.Mockito; import org.opendaylight.openflowplugin.api.openflow.device.RequestContext; import org.opendaylight.openflowplugin.impl.rpc.AbstractRequestContext; import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeConnectorId; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartRequestInput; import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetAllNodeConnectorsStatisticsInputBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetAllNodeConnectorsStatisticsOutput; import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetNodeConnectorStatisticsInputBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.GetNodeConnectorStatisticsOutput; import org.opendaylight.yangtools.yang.common.RpcResult; /** * Test for {@link OpendaylightPortStatisticsServiceImpl} */ public class OpendaylightPortStatisticsServiceImplTest extends AbstractStatsServiceTest { @Captor private ArgumentCaptor requestInput; private RequestContext rqContext; private OpendaylightPortStatisticsServiceImpl portStatisticsService; public void setUp() { portStatisticsService = new OpendaylightPortStatisticsServiceImpl(rqContextStack, deviceContext); rqContext = new AbstractRequestContext(42L) { @Override public void close() { //NOOP } }; Mockito.when(rqContextStack.createRequestContext()).thenReturn(rqContext); } @Test public void testGetAllNodeConnectorsStatistics() throws Exception { Mockito.doAnswer(answerVoidToCallback).when(outboundQueueProvider) .commitEntry(Matchers.eq(42L), requestInput.capture(), Matchers.any(FutureCallback.class)); GetAllNodeConnectorsStatisticsInputBuilder input = new GetAllNodeConnectorsStatisticsInputBuilder() .setNode(createNodeRef("unitProt:123")); final Future> resultFuture = portStatisticsService.getAllNodeConnectorsStatistics(input.build()); Assert.assertTrue(resultFuture.isDone()); final RpcResult rpcResult = resultFuture.get(); Assert.assertTrue(rpcResult.isSuccessful()); Assert.assertEquals(MultipartType.OFPMPPORTSTATS, requestInput.getValue().getType()); } @Test public void testGetNodeConnectorStatistics() throws Exception { Mockito.doAnswer(answerVoidToCallback).when(outboundQueueProvider) .commitEntry(Matchers.eq(42L), requestInput.capture(), Matchers.any(FutureCallback.class)); GetNodeConnectorStatisticsInputBuilder input = new GetNodeConnectorStatisticsInputBuilder() .setNode(createNodeRef("unitProt:123")) .setNodeConnectorId(new NodeConnectorId("unitProt:123:321")); final Future> resultFuture = portStatisticsService.getNodeConnectorStatistics(input.build()); Assert.assertTrue(resultFuture.isDone()); final RpcResult rpcResult = resultFuture.get(); Assert.assertTrue(rpcResult.isSuccessful()); Assert.assertEquals(MultipartType.OFPMPPORTSTATS, requestInput.getValue().getType()); } }