2 * Copyright (c) 2015 Cisco Systems, 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.openflowplugin.impl.statistics.services;
10 import static org.mockito.ArgumentMatchers.any;
11 import static org.mockito.ArgumentMatchers.eq;
13 import com.google.common.util.concurrent.FutureCallback;
14 import java.util.Collections;
15 import java.util.concurrent.Future;
16 import java.util.concurrent.atomic.AtomicLong;
17 import org.junit.After;
18 import org.junit.Assert;
19 import org.junit.Test;
20 import org.mockito.ArgumentCaptor;
21 import org.mockito.ArgumentMatchers;
22 import org.mockito.Captor;
23 import org.mockito.Mockito;
24 import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.queue.rev130925.QueueId;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeConnectorId;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReplyMessageBuilder;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartRequestInput;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.MultipartReplyQueueCaseBuilder;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.queue._case.MultipartReplyQueueBuilder;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.queue._case.multipart.reply.queue.QueueStatsBuilder;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromAllPortsInputBuilder;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromAllPortsOutput;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromGivenPortInputBuilder;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetAllQueuesStatisticsFromGivenPortOutput;
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetQueueStatisticsFromGivenPortInputBuilder;
38 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.GetQueueStatisticsFromGivenPortOutput;
39 import org.opendaylight.yangtools.yang.common.RpcResult;
40 import org.opendaylight.yangtools.yang.common.RpcResultBuilder;
41 import org.opendaylight.yangtools.yang.common.Uint32;
42 import org.opendaylight.yangtools.yang.common.Uint64;
45 * Test for {@link OpendaylightQueueStatisticsServiceImpl}.
47 public class OpendaylightQueueStatisticsServiceImplTest extends AbstractSingleStatsServiceTest {
50 private ArgumentCaptor<MultipartRequestInput> requestInput;
52 private OpendaylightQueueStatisticsServiceImpl queueStatisticsService;
56 queueStatisticsService = new OpendaylightQueueStatisticsServiceImpl(rqContextStack, deviceContext,
57 new AtomicLong(), notificationPublishService);
61 public void tearDown() {
62 Mockito.verify(notificationPublishService).offerNotification(ArgumentMatchers.any());
66 public void testGetAllQueuesStatisticsFromAllPorts() throws Exception {
67 Mockito.doAnswer(answerVoidToCallback).when(outboundQueueProvider)
68 .commitEntry(eq(Uint32.valueOf(42)), requestInput.capture(), any(FutureCallback.class));
70 GetAllQueuesStatisticsFromAllPortsInputBuilder input = new GetAllQueuesStatisticsFromAllPortsInputBuilder()
71 .setNode(createNodeRef("unitProt:123"));
73 rpcResult = buildQueueStatsReply();
75 final Future<RpcResult<GetAllQueuesStatisticsFromAllPortsOutput>> resultFuture
76 = queueStatisticsService.getAllQueuesStatisticsFromAllPorts(input.build());
78 Assert.assertTrue(resultFuture.isDone());
79 final RpcResult<GetAllQueuesStatisticsFromAllPortsOutput> rpcResult = resultFuture.get();
80 Assert.assertTrue(rpcResult.isSuccessful());
81 Assert.assertEquals(MultipartType.OFPMPQUEUE, requestInput.getValue().getType());
84 protected RpcResult<Object> buildQueueStatsReply() {
85 return RpcResultBuilder.<Object>success(Collections.singletonList(
86 new MultipartReplyMessageBuilder()
87 .setVersion(EncodeConstants.OF_VERSION_1_3)
88 .setMultipartReplyBody(new MultipartReplyQueueCaseBuilder()
89 .setMultipartReplyQueue(new MultipartReplyQueueBuilder()
90 .setQueueStats(Collections.singletonList(new QueueStatsBuilder()
91 .setDurationSec(Uint32.valueOf(41))
92 .setDurationNsec(Uint32.valueOf(42))
93 .setTxBytes(Uint64.valueOf(43))
94 .setTxErrors(Uint64.valueOf(44))
95 .setTxPackets(Uint64.valueOf(45))
96 .setPortNo(Uint32.valueOf(46))
97 .setQueueId(Uint32.valueOf(47))
106 public void testGetAllQueuesStatisticsFromGivenPort() throws Exception {
107 Mockito.doAnswer(answerVoidToCallback).when(outboundQueueProvider)
108 .commitEntry(eq(Uint32.valueOf(42)), requestInput.capture(), any(FutureCallback.class));
110 GetAllQueuesStatisticsFromGivenPortInputBuilder input = new GetAllQueuesStatisticsFromGivenPortInputBuilder()
111 .setNode(createNodeRef("unitProt:123"))
112 .setNodeConnectorId(new NodeConnectorId("unitProt:123:321"));
114 rpcResult = buildQueueStatsReply();
116 final Future<RpcResult<GetAllQueuesStatisticsFromGivenPortOutput>> resultFuture
117 = queueStatisticsService.getAllQueuesStatisticsFromGivenPort(input.build());
119 Assert.assertTrue(resultFuture.isDone());
120 final RpcResult<GetAllQueuesStatisticsFromGivenPortOutput> rpcResult = resultFuture.get();
121 Assert.assertTrue(rpcResult.isSuccessful());
122 Assert.assertEquals(MultipartType.OFPMPQUEUE, requestInput.getValue().getType());
126 public void testGetQueueStatisticsFromGivenPort() throws Exception {
127 Mockito.doAnswer(answerVoidToCallback).when(outboundQueueProvider)
128 .commitEntry(eq(Uint32.valueOf(42)), requestInput.capture(), any(FutureCallback.class));
130 GetQueueStatisticsFromGivenPortInputBuilder input = new GetQueueStatisticsFromGivenPortInputBuilder()
131 .setNode(createNodeRef("unitProt:123"))
132 .setNodeConnectorId(new NodeConnectorId("unitProt:123:321"))
133 .setQueueId(new QueueId(Uint32.valueOf(21)));
135 rpcResult = buildQueueStatsReply();
137 final Future<RpcResult<GetQueueStatisticsFromGivenPortOutput>> resultFuture
138 = queueStatisticsService.getQueueStatisticsFromGivenPort(input.build());
140 Assert.assertTrue(resultFuture.isDone());
141 final RpcResult<GetQueueStatisticsFromGivenPortOutput> rpcResult = resultFuture.get();
142 Assert.assertTrue(rpcResult.isSuccessful());
143 Assert.assertEquals(MultipartType.OFPMPQUEUE, requestInput.getValue().getType());