Decompose RPC implementation classes
[openflowplugin.git] / openflowplugin-impl / src / test / java / org / opendaylight / openflowplugin / impl / statistics / services / direct / singlelayer / QueueDirectStatisticsServiceTest.java
1 /*
2  * Copyright (c) 2017 Pantheon Technologies s.r.o. and others.  All rights reserved.
3  *
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
7  */
8 package org.opendaylight.openflowplugin.impl.statistics.services.direct.singlelayer;
9
10 import static org.junit.Assert.assertEquals;
11 import static org.junit.Assert.assertTrue;
12 import static org.mockito.ArgumentMatchers.any;
13 import static org.mockito.ArgumentMatchers.eq;
14 import static org.mockito.Mockito.lenient;
15 import static org.mockito.Mockito.mock;
16 import static org.mockito.Mockito.verify;
17 import static org.mockito.Mockito.when;
18
19 import java.util.List;
20 import java.util.Map;
21 import org.junit.Test;
22 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
23 import org.opendaylight.openflowplugin.api.openflow.device.Xid;
24 import org.opendaylight.openflowplugin.impl.statistics.services.direct.AbstractDirectStatisticsServiceTest;
25 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Counter64;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetQueueStatisticsInput;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetQueueStatisticsOutput;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.queue.rev130925.QueueId;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeConnectorId;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.multipart.types.rev170112.MultipartReplyBuilder;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.multipart.types.rev170112.MultipartRequest;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.multipart.reply.multipart.reply.body.MultipartReplyQueueStatsBuilder;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.multipart.request.multipart.request.body.MultipartRequestQueueStats;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.queue.id.and.statistics.map.QueueIdAndStatisticsMap;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.queue.id.and.statistics.map.QueueIdAndStatisticsMapBuilder;
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.queue.id.and.statistics.map.QueueIdAndStatisticsMapKey;
38 import org.opendaylight.yangtools.yang.binding.util.BindingMap;
39 import org.opendaylight.yangtools.yang.common.Uint32;
40 import org.opendaylight.yangtools.yang.common.Uint64;
41
42 public class QueueDirectStatisticsServiceTest extends AbstractDirectStatisticsServiceTest {
43     private SingleGetQueueStatistics service;
44
45     @Override
46     public void setUp() {
47         service = new SingleGetQueueStatistics(requestContextStack, deviceContext, convertorManager,
48             multipartWriterProvider);
49     }
50
51     @Override
52     public void testBuildRequestBody() {
53         final var input = mock(GetQueueStatisticsInput.class);
54
55         lenient().when(input.getNode()).thenReturn(createNodeRef(NODE_ID));
56         when(input.getQueueId()).thenReturn(new QueueId(Uint32.ONE));
57         when(input.getNodeConnectorId()).thenReturn(nodeConnectorId);
58
59         final var body = (MultipartRequestQueueStats) ((MultipartRequest) service
60             .buildRequest(new Xid(Uint32.valueOf(42L)), input))
61             .getMultipartRequestBody();
62
63         assertEquals(nodeConnectorId, body.getNodeConnectorId());
64         assertEquals(Uint32.ONE, body.getQueueId().getValue());
65     }
66
67     @Override
68     public void testBuildReply() {
69         final var output = service.buildReply(List.of(new MultipartReplyBuilder()
70             .setMultipartReplyBody(new MultipartReplyQueueStatsBuilder()
71                 .setQueueIdAndStatisticsMap(BindingMap.of(new QueueIdAndStatisticsMapBuilder()
72                     .setQueueId(new QueueId(Uint32.ONE))
73                     .setNodeConnectorId(new NodeConnectorId(PORT_NO.toString()))
74                     .setTransmittedBytes(new Counter64(Uint64.ONE))
75                     .setTransmissionErrors(new Counter64(Uint64.ONE))
76                     .setTransmittedBytes(new Counter64(Uint64.ONE))
77                     .build()))
78                 .build())
79             .build()), true);
80         assertTrue(output.nonnullQueueIdAndStatisticsMap().size() > 0);
81
82         final var map = output.nonnullQueueIdAndStatisticsMap().values().iterator().next();
83         assertEquals(map.getQueueId().getValue(), Uint32.ONE);
84         assertEquals(map.getNodeConnectorId().getValue(), PORT_NO.toString());
85     }
86
87     @Test
88     public void testStoreStatisticsBarePortNo() {
89         final QueueIdAndStatisticsMap map = mock(QueueIdAndStatisticsMap.class);
90         when(map.getQueueId()).thenReturn(new QueueId(Uint32.ONE));
91         when(map.getNodeConnectorId()).thenReturn(new NodeConnectorId("1"));
92         when(map.key()).thenReturn(
93             new QueueIdAndStatisticsMapKey(new NodeConnectorId("1"), new QueueId(Uint32.ONE)));
94
95         final GetQueueStatisticsOutput output = mock(GetQueueStatisticsOutput.class);
96         Map<QueueIdAndStatisticsMapKey, QueueIdAndStatisticsMap> stats = BindingMap.of(map);
97         when(output.nonnullQueueIdAndStatisticsMap()).thenReturn(stats);
98
99         multipartWriterProvider.lookup(MultipartType.OFPMPQUEUE).orElseThrow().write(output, true);
100         verify(deviceContext).writeToTransactionWithParentsSlow(eq(LogicalDatastoreType.OPERATIONAL), any(), any());
101     }
102
103     @Override
104     public void testStoreStatistics() {
105         final QueueIdAndStatisticsMap map = mock(QueueIdAndStatisticsMap.class);
106         when(map.getQueueId()).thenReturn(new QueueId(Uint32.ONE));
107         when(map.getNodeConnectorId()).thenReturn(new NodeConnectorId("openflow:1:1"));
108         when(map.key()).thenReturn(
109             new QueueIdAndStatisticsMapKey(new NodeConnectorId("openflow:1:1"), new QueueId(Uint32.ONE)));
110
111         final Map<QueueIdAndStatisticsMapKey, QueueIdAndStatisticsMap> maps = BindingMap.of(map);
112         final GetQueueStatisticsOutput output = mock(GetQueueStatisticsOutput.class);
113         when(output.nonnullQueueIdAndStatisticsMap()).thenReturn(maps);
114
115         multipartWriterProvider.lookup(MultipartType.OFPMPQUEUE).orElseThrow().write(output, true);
116         verify(deviceContext).writeToTransactionWithParentsSlow(eq(LogicalDatastoreType.OPERATIONAL), any(), any());
117     }
118 }