Decompose RPC implementation classes
[openflowplugin.git] / openflowplugin-impl / src / test / java / org / opendaylight / openflowplugin / impl / statistics / services / direct / multilayer / NodeConnectorDirectStatisticsServiceTest.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.multilayer;
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.opendaylight.mdsal.common.api.LogicalDatastoreType;
22 import org.opendaylight.openflowplugin.api.openflow.device.Xid;
23 import org.opendaylight.openflowplugin.impl.statistics.services.direct.AbstractDirectStatisticsServiceTest;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsInput;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsOutput;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReply;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartRequestInput;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.MultipartReplyPortStatsCase;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.port.stats._case.MultipartReplyPortStats;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.port.stats._case.multipart.reply.port.stats.PortStats;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestPortStatsCase;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.port.stats._case.MultipartRequestPortStats;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMap;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMapKey;
36 import org.opendaylight.yangtools.yang.binding.util.BindingMap;
37 import org.opendaylight.yangtools.yang.common.Uint32;
38 import org.opendaylight.yangtools.yang.common.Uint64;
39
40 public class NodeConnectorDirectStatisticsServiceTest extends AbstractDirectStatisticsServiceTest {
41     private MultiGetNodeConnectorStatistics service;
42
43     @Override
44     public void setUp() {
45         service = new MultiGetNodeConnectorStatistics(requestContextStack, deviceContext, convertorManager,
46             multipartWriterProvider);
47     }
48
49     @Override
50     public void testBuildRequestBody() {
51         final GetNodeConnectorStatisticsInput input = mock(GetNodeConnectorStatisticsInput.class);
52
53         lenient().when(input.getNode()).thenReturn(createNodeRef(NODE_ID));
54         when(input.getNodeConnectorId()).thenReturn(nodeConnectorId);
55
56         final MultipartRequestPortStatsCase body = (MultipartRequestPortStatsCase) ((MultipartRequestInput)service
57             .buildRequest(new Xid(Uint32.valueOf(42)), input))
58             .getMultipartRequestBody();
59
60         final MultipartRequestPortStats nodeConnector = body.getMultipartRequestPortStats();
61
62         assertEquals(PORT_NO, nodeConnector.getPortNo());
63     }
64
65     @Override
66     public void testBuildReply() {
67         final MultipartReply reply = mock(MultipartReply.class);
68         final MultipartReplyPortStatsCase nodeConnectorCase = mock(MultipartReplyPortStatsCase.class);
69         final MultipartReplyPortStats nodeConnector = mock(MultipartReplyPortStats.class);
70         final PortStats nodeConnectorStat = mock(PortStats.class);
71         final List<PortStats> nodeConnectorStats = List.of(nodeConnectorStat);
72         final List<MultipartReply> input = List.of(reply);
73
74         when(nodeConnector.getPortStats()).thenReturn(nodeConnectorStats);
75         when(nodeConnector.nonnullPortStats()).thenCallRealMethod();
76         when(nodeConnectorCase.getMultipartReplyPortStats()).thenReturn(nodeConnector);
77         when(reply.getMultipartReplyBody()).thenReturn(nodeConnectorCase);
78
79         when(nodeConnectorStat.getPortNo()).thenReturn(PORT_NO);
80         when(nodeConnectorStat.getTxBytes()).thenReturn(Uint64.ONE);
81         when(nodeConnectorStat.getCollisions()).thenReturn(Uint64.ONE);
82         when(nodeConnectorStat.getRxBytes()).thenReturn(Uint64.ONE);
83         when(nodeConnectorStat.getRxCrcErr()).thenReturn(Uint64.ONE);
84         when(nodeConnectorStat.getRxDropped()).thenReturn(Uint64.ONE);
85         when(nodeConnectorStat.getRxErrors()).thenReturn(Uint64.ONE);
86         when(nodeConnectorStat.getRxFrameErr()).thenReturn(Uint64.ONE);
87         when(nodeConnectorStat.getRxOverErr()).thenReturn(Uint64.ONE);
88         when(nodeConnectorStat.getRxPackets()).thenReturn(Uint64.ONE);
89         when(nodeConnectorStat.getTxDropped()).thenReturn(Uint64.ONE);
90         when(nodeConnectorStat.getTxErrors()).thenReturn(Uint64.ONE);
91
92         final GetNodeConnectorStatisticsOutput output = service.buildReply(input, true);
93         assertTrue(output.nonnullNodeConnectorStatisticsAndPortNumberMap().size() > 0);
94
95         final NodeConnectorStatisticsAndPortNumberMap stats =
96                 output.nonnullNodeConnectorStatisticsAndPortNumberMap().values().iterator().next();
97
98         assertEquals(stats.getNodeConnectorId(), nodeConnectorId);
99     }
100
101     @Override
102     public void testStoreStatistics() {
103         final NodeConnectorStatisticsAndPortNumberMap stat = mock(NodeConnectorStatisticsAndPortNumberMap.class);
104         when(stat.key()).thenReturn(new NodeConnectorStatisticsAndPortNumberMapKey(nodeConnectorId));
105         when(stat.getNodeConnectorId()).thenReturn(nodeConnectorId);
106
107         final Map<NodeConnectorStatisticsAndPortNumberMapKey, NodeConnectorStatisticsAndPortNumberMap> stats
108                 = BindingMap.of(stat);
109         final GetNodeConnectorStatisticsOutput output = mock(GetNodeConnectorStatisticsOutput.class);
110         when(output.nonnullNodeConnectorStatisticsAndPortNumberMap()).thenReturn(stats);
111
112         multipartWriterProvider.lookup(MultipartType.OFPMPPORTSTATS).orElseThrow().write(output, true);
113         verify(deviceContext).writeToTransactionWithParentsSlow(eq(LogicalDatastoreType.OPERATIONAL), any(), any());
114     }
115 }