OPNFLWPLUG-1032: Neon-MRI: Bump odlparent, yangtools, mdsal
[openflowplugin.git] / openflowplugin-impl / src / test / java / org / opendaylight / openflowplugin / impl / statistics / services / direct / multilayer / 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
9 package org.opendaylight.openflowplugin.impl.statistics.services.direct.multilayer;
10
11 import static org.junit.Assert.assertEquals;
12 import static org.junit.Assert.assertTrue;
13 import static org.mockito.ArgumentMatchers.any;
14 import static org.mockito.ArgumentMatchers.eq;
15 import static org.mockito.Mockito.lenient;
16 import static org.mockito.Mockito.mock;
17 import static org.mockito.Mockito.verify;
18 import static org.mockito.Mockito.when;
19
20 import java.math.BigInteger;
21 import java.util.Collections;
22 import java.util.List;
23 import org.junit.Test;
24 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
25 import org.opendaylight.openflowplugin.api.openflow.device.Xid;
26 import org.opendaylight.openflowplugin.impl.statistics.services.direct.AbstractDirectStatisticsServiceTest;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetQueueStatisticsInput;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetQueueStatisticsOutput;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.queue.rev130925.QueueId;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeConnectorId;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReply;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartRequestInput;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.MultipartReplyQueueCase;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.queue._case.MultipartReplyQueue;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.reply.multipart.reply.body.multipart.reply.queue._case.multipart.reply.queue.QueueStats;
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.MultipartRequestQueueCase;
38 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.multipart.request.multipart.request.body.multipart.request.queue._case.MultipartRequestQueue;
39 import org.opendaylight.yang.gen.v1.urn.opendaylight.queue.statistics.rev131216.queue.id.and.statistics.map.QueueIdAndStatisticsMap;
40
41 public class QueueDirectStatisticsServiceTest extends AbstractDirectStatisticsServiceTest {
42     static final Long QUEUE_NO = 1L;
43     private QueueDirectStatisticsService service;
44
45     @Override
46     public void setUp() throws Exception {
47         service = new QueueDirectStatisticsService(requestContextStack,
48                                                    deviceContext,
49                                                    convertorManager,
50                                                    multipartWriterProvider);
51     }
52
53     @Override
54     public void testBuildRequestBody() throws Exception {
55         final GetQueueStatisticsInput input = mock(GetQueueStatisticsInput.class);
56
57         lenient().when(input.getNode()).thenReturn(createNodeRef(NODE_ID));
58         when(input.getQueueId()).thenReturn(new QueueId(QUEUE_NO));
59         when(input.getNodeConnectorId()).thenReturn(new NodeConnectorId(NODE_ID + ":" + PORT_NO));
60
61         final MultipartRequestQueueCase body = (MultipartRequestQueueCase) ((MultipartRequestInput) service
62             .buildRequest(new Xid(42L), input))
63             .getMultipartRequestBody();
64
65         final MultipartRequestQueue queue = body.getMultipartRequestQueue();
66
67         assertEquals(PORT_NO, queue.getPortNo());
68         assertEquals(QUEUE_NO, queue.getQueueId());
69     }
70
71     @Override
72     public void testBuildReply() throws Exception {
73         final MultipartReply reply = mock(MultipartReply.class);
74         final MultipartReplyQueueCase queueCase = mock(MultipartReplyQueueCase.class);
75         final MultipartReplyQueue queue = mock(MultipartReplyQueue.class);
76         final QueueStats queueStat = mock(QueueStats.class);
77         final List<QueueStats> queueStats = Collections.singletonList(queueStat);
78         final List<MultipartReply> input = Collections.singletonList(reply);
79
80         when(queue.getQueueStats()).thenReturn(queueStats);
81         when(queueCase.getMultipartReplyQueue()).thenReturn(queue);
82         when(reply.getMultipartReplyBody()).thenReturn(queueCase);
83
84         when(queueStat.getPortNo()).thenReturn(PORT_NO);
85         when(queueStat.getQueueId()).thenReturn(QUEUE_NO);
86         when(queueStat.getTxBytes()).thenReturn(BigInteger.ONE);
87         when(queueStat.getTxErrors()).thenReturn(BigInteger.ONE);
88         when(queueStat.getTxPackets()).thenReturn(BigInteger.ONE);
89
90         final GetQueueStatisticsOutput output = service.buildReply(input, true);
91         assertTrue(output.getQueueIdAndStatisticsMap().size() > 0);
92
93         final QueueIdAndStatisticsMap map = output.getQueueIdAndStatisticsMap().get(0);
94         assertEquals(map.getQueueId().getValue(), QUEUE_NO);
95         assertEquals(map.getNodeConnectorId(), nodeConnectorId);
96     }
97
98     @Test
99     public void testStoreStatisticsBarePortNo() throws Exception {
100         final QueueIdAndStatisticsMap map = mock(QueueIdAndStatisticsMap.class);
101         when(map.getQueueId()).thenReturn(new QueueId(QUEUE_NO));
102         when(map.getNodeConnectorId()).thenReturn(new NodeConnectorId("1"));
103
104         final List<QueueIdAndStatisticsMap> maps = Collections.singletonList(map);
105         final GetQueueStatisticsOutput output = mock(GetQueueStatisticsOutput.class);
106         when(output.getQueueIdAndStatisticsMap()).thenReturn(maps);
107
108         multipartWriterProvider.lookup(MultipartType.OFPMPQUEUE).get().write(output, true);
109         verify(deviceContext).writeToTransactionWithParentsSlow(eq(LogicalDatastoreType.OPERATIONAL), any(), any());
110     }
111
112     @Override
113     public void testStoreStatistics() throws Exception {
114         final QueueIdAndStatisticsMap map = mock(QueueIdAndStatisticsMap.class);
115         when(map.getQueueId()).thenReturn(new QueueId(QUEUE_NO));
116         when(map.getNodeConnectorId()).thenReturn(new NodeConnectorId("openflow:1:1"));
117
118         final List<QueueIdAndStatisticsMap> maps = Collections.singletonList(map);
119         final GetQueueStatisticsOutput output = mock(GetQueueStatisticsOutput.class);
120         when(output.getQueueIdAndStatisticsMap()).thenReturn(maps);
121
122         multipartWriterProvider.lookup(MultipartType.OFPMPQUEUE).get().write(output, true);
123         verify(deviceContext).writeToTransactionWithParentsSlow(eq(LogicalDatastoreType.OPERATIONAL), any(), any());
124     }
125 }