2 * Copyright (c) 2017 Pantheon Technologies s.r.o. 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.direct.multilayer;
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;
19 import java.util.Collections;
20 import java.util.List;
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.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsInput;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetNodeConnectorStatisticsOutput;
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.MultipartReply;
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.MultipartReplyPortStatsCase;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.port.stats._case.MultipartReplyPortStats;
32 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;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestPortStatsCase;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.port.stats._case.MultipartRequestPortStats;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMap;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.port.statistics.rev131214.node.connector.statistics.and.port.number.map.NodeConnectorStatisticsAndPortNumberMapKey;
37 import org.opendaylight.yangtools.yang.common.Uint32;
38 import org.opendaylight.yangtools.yang.common.Uint64;
40 public class NodeConnectorDirectStatisticsServiceTest extends AbstractDirectStatisticsServiceTest {
41 private PortDirectStatisticsService service;
45 service = new PortDirectStatisticsService(requestContextStack,
48 multipartWriterProvider);
52 public void testBuildRequestBody() {
53 final GetNodeConnectorStatisticsInput input = mock(GetNodeConnectorStatisticsInput.class);
55 lenient().when(input.getNode()).thenReturn(createNodeRef(NODE_ID));
56 when(input.getNodeConnectorId()).thenReturn(nodeConnectorId);
58 final MultipartRequestPortStatsCase body = (MultipartRequestPortStatsCase) ((MultipartRequestInput)service
59 .buildRequest(new Xid(Uint32.valueOf(42)), input))
60 .getMultipartRequestBody();
62 final MultipartRequestPortStats nodeConnector = body.getMultipartRequestPortStats();
64 assertEquals(PORT_NO, nodeConnector.getPortNo());
68 public void testBuildReply() {
69 final MultipartReply reply = mock(MultipartReply.class);
70 final MultipartReplyPortStatsCase nodeConnectorCase = mock(MultipartReplyPortStatsCase.class);
71 final MultipartReplyPortStats nodeConnector = mock(MultipartReplyPortStats.class);
72 final PortStats nodeConnectorStat = mock(PortStats.class);
73 final List<PortStats> nodeConnectorStats = Collections.singletonList(nodeConnectorStat);
74 final List<MultipartReply> input = Collections.singletonList(reply);
76 when(nodeConnector.getPortStats()).thenReturn(nodeConnectorStats);
77 when(nodeConnectorCase.getMultipartReplyPortStats()).thenReturn(nodeConnector);
78 when(reply.getMultipartReplyBody()).thenReturn(nodeConnectorCase);
80 when(nodeConnectorStat.getPortNo()).thenReturn(PORT_NO);
81 when(nodeConnectorStat.getTxBytes()).thenReturn(Uint64.ONE);
82 when(nodeConnectorStat.getCollisions()).thenReturn(Uint64.ONE);
83 when(nodeConnectorStat.getRxBytes()).thenReturn(Uint64.ONE);
84 when(nodeConnectorStat.getRxCrcErr()).thenReturn(Uint64.ONE);
85 when(nodeConnectorStat.getRxDropped()).thenReturn(Uint64.ONE);
86 when(nodeConnectorStat.getRxErrors()).thenReturn(Uint64.ONE);
87 when(nodeConnectorStat.getRxFrameErr()).thenReturn(Uint64.ONE);
88 when(nodeConnectorStat.getRxOverErr()).thenReturn(Uint64.ONE);
89 when(nodeConnectorStat.getRxPackets()).thenReturn(Uint64.ONE);
90 when(nodeConnectorStat.getTxDropped()).thenReturn(Uint64.ONE);
91 when(nodeConnectorStat.getTxErrors()).thenReturn(Uint64.ONE);
93 final GetNodeConnectorStatisticsOutput output = service.buildReply(input, true);
94 assertTrue(output.getNodeConnectorStatisticsAndPortNumberMap().size() > 0);
96 final NodeConnectorStatisticsAndPortNumberMap stats =
97 output.nonnullNodeConnectorStatisticsAndPortNumberMap().values().iterator().next();
99 assertEquals(stats.getNodeConnectorId(), nodeConnectorId);
103 public void testStoreStatistics() {
104 final NodeConnectorStatisticsAndPortNumberMap stat = mock(NodeConnectorStatisticsAndPortNumberMap.class);
105 when(stat.key()).thenReturn(new NodeConnectorStatisticsAndPortNumberMapKey(nodeConnectorId));
106 when(stat.getNodeConnectorId()).thenReturn(nodeConnectorId);
108 final Map<NodeConnectorStatisticsAndPortNumberMapKey, NodeConnectorStatisticsAndPortNumberMap> stats
109 = Collections.singletonMap(stat.key(), stat);
110 final GetNodeConnectorStatisticsOutput output = mock(GetNodeConnectorStatisticsOutput.class);
111 when(output.nonnullNodeConnectorStatisticsAndPortNumberMap()).thenReturn(stats);
113 multipartWriterProvider.lookup(MultipartType.OFPMPPORTSTATS).get().write(output, true);
114 verify(deviceContext).writeToTransactionWithParentsSlow(eq(LogicalDatastoreType.OPERATIONAL), any(), any());