Update unit tests
[openflowplugin.git] / openflowplugin-impl / src / test / java / org / opendaylight / openflowplugin / impl / statistics / services / direct / singlelayer / FlowDirectStatisticsServiceTest.java
diff --git a/openflowplugin-impl/src/test/java/org/opendaylight/openflowplugin/impl/statistics/services/direct/singlelayer/FlowDirectStatisticsServiceTest.java b/openflowplugin-impl/src/test/java/org/opendaylight/openflowplugin/impl/statistics/services/direct/singlelayer/FlowDirectStatisticsServiceTest.java
new file mode 100644 (file)
index 0000000..0abec39
--- /dev/null
@@ -0,0 +1,115 @@
+/*
+ * Copyright (c) 2017 Pantheon Technologies s.r.o. and others.  All rights reserved.
+ *
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Public License v1.0 which accompanies this distribution,
+ * and is available at http://www.eclipse.org/legal/epl-v10.html
+ */
+
+package org.opendaylight.openflowplugin.impl.statistics.services.direct.singlelayer;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertTrue;
+import static org.mockito.Matchers.any;
+import static org.mockito.Matchers.eq;
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+
+import java.math.BigInteger;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.List;
+import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
+import org.opendaylight.openflowplugin.api.openflow.device.Xid;
+import org.opendaylight.openflowplugin.api.openflow.registry.flow.DeviceFlowRegistry;
+import org.opendaylight.openflowplugin.impl.registry.flow.FlowDescriptorFactory;
+import org.opendaylight.openflowplugin.impl.statistics.services.direct.AbstractDirectStatisticsServiceTest;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Counter32;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Counter64;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetFlowStatisticsInput;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.direct.statistics.rev160511.GetFlowStatisticsOutput;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.inventory.rev130819.FlowId;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.statistics.rev130819.FlowAndStatisticsMap;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.statistics.rev130819.flow.and.statistics.map.list.FlowAndStatisticsMapList;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.statistics.rev130819.flow.and.statistics.map.list.FlowAndStatisticsMapListBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.statistics.rev130819.multipart.reply.multipart.reply.body.MultipartReplyFlowStatsBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.rev131026.FlowModFlags;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.rev131026.flow.MatchBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.rev131026.multipart.request.multipart.request.body.MultipartRequestFlowStats;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.model.statistics.types.rev130925.duration.DurationBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.multipart.types.rev170112.MultipartReply;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.multipart.types.rev170112.MultipartReplyBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.multipart.types.rev170112.MultipartRequest;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.MultipartType;
+
+public class FlowDirectStatisticsServiceTest extends AbstractDirectStatisticsServiceTest {
+    static final Short TABLE_NO = 1;
+    private FlowDirectStatisticsService service;
+
+    @Override
+    public void setUp() throws Exception {
+        service = new FlowDirectStatisticsService(requestContextStack, deviceContext, convertorManager, multipartWriterProvider);
+        final DeviceFlowRegistry registry = mock(DeviceFlowRegistry.class);
+        when(registry.retrieveDescriptor(any())).thenReturn(FlowDescriptorFactory.create(TABLE_NO, new FlowId("1")));
+        when(deviceContext.getDeviceFlowRegistry()).thenReturn(registry);
+    }
+
+    @Override
+    public void testBuildRequestBody() throws Exception {
+        final GetFlowStatisticsInput input = mock(GetFlowStatisticsInput.class);
+
+        when(input.getNode()).thenReturn(createNodeRef(NODE_ID));
+        when(input.getTableId()).thenReturn(TABLE_NO);
+
+        final MultipartRequestFlowStats body = (MultipartRequestFlowStats) ((MultipartRequest) service
+            .buildRequest(new Xid(42L), input))
+            .getMultipartRequestBody();
+
+        assertEquals(TABLE_NO, body.getTableId());
+    }
+
+    @Override
+    public void testBuildReply() throws Exception {
+        final FlowAndStatisticsMapList flowStat = new FlowAndStatisticsMapListBuilder()
+                .setDuration(new DurationBuilder()
+                        .setSecond(new Counter32(1L))
+                        .setNanosecond(new Counter32(1L))
+                        .build())
+                .setTableId(TABLE_NO)
+                .setByteCount(new Counter64(BigInteger.ONE))
+                .setPacketCount(new Counter64(BigInteger.ONE))
+                .setFlags(new FlowModFlags(true, false, false, false, false))
+                .setMatch(new MatchBuilder().build())
+                .build();
+
+        final MultipartReply reply = new MultipartReplyBuilder()
+                .setMultipartReplyBody(new MultipartReplyFlowStatsBuilder()
+                        .setFlowAndStatisticsMapList(Collections.singletonList(flowStat))
+                        .build())
+                .build();
+
+        final List<MultipartReply> input = Collections.singletonList(reply);
+
+        final GetFlowStatisticsOutput output = service.buildReply(input, true);
+        assertTrue(output.getFlowAndStatisticsMapList().size() > 0);
+
+        final FlowAndStatisticsMap stats = output.getFlowAndStatisticsMapList().get(0);
+
+        assertEquals(stats.getTableId(), TABLE_NO);
+    }
+
+    @Override
+    public void testStoreStatistics() throws Exception {
+        final FlowAndStatisticsMapList stat = mock(FlowAndStatisticsMapList.class);
+        when(stat.getTableId()).thenReturn(TABLE_NO);
+        when(stat.getMatch()).thenReturn(new MatchBuilder().build());
+
+        final List<FlowAndStatisticsMapList> stats = Arrays.asList(stat);
+        final GetFlowStatisticsOutput output = mock(GetFlowStatisticsOutput.class);
+        when(output.getFlowAndStatisticsMapList()).thenReturn(stats);
+
+        multipartWriterProvider.lookup(MultipartType.OFPMPFLOW).get().write(output, true);
+        verify(deviceContext).writeToTransactionWithParentsSlow(eq(LogicalDatastoreType.OPERATIONAL), any(), any());
+    }
+}