UT for ProtocolRemovedCommand class 41/29341/6
authorLayth Al-Ani <lalani@inocybe.com>
Thu, 12 Nov 2015 20:49:16 +0000 (15:49 -0500)
committeradetalhouet <adetalhouet@inocybe.com>
Mon, 23 Nov 2015 22:34:10 +0000 (17:34 -0500)
Change-Id: Icd2b454b49b214735540c20281d6611071309947
Signed-off-by: Layth Al-Ani <lalani@inocybe.com>
Signed-off-by: adetalhouet <adetalhouet@inocybe.com>
southbound/southbound-impl/src/main/java/org/opendaylight/ovsdb/southbound/ovsdb/transact/ProtocolRemovedCommand.java
southbound/southbound-impl/src/test/java/org/opendaylight/ovsdb/southbound/ovsdb/transact/ProtocolRemovedCommandTest.java [new file with mode: 0644]

index 4ce25cd9158a1e50a8307c922e3e94f5969c52b0..3285327b1174c378a200a7782a41dfc78632aaa4 100644 (file)
@@ -34,14 +34,12 @@ public class ProtocolRemovedCommand extends AbstractTransactCommand {
 
     private static final Logger LOG = LoggerFactory.getLogger(ProtocolRemovedCommand.class);
     private Set<InstanceIdentifier<ProtocolEntry>> removed;
-    private Map<InstanceIdentifier<ProtocolEntry>, ProtocolEntry> operationalProtocolEntries;
     private Map<InstanceIdentifier<OvsdbBridgeAugmentation>, OvsdbBridgeAugmentation> updatedBridges;
 
     public ProtocolRemovedCommand(BridgeOperationalState state,
             AsyncDataChangeEvent<InstanceIdentifier<?>, DataObject> changes) {
         super(state, changes);
         removed = TransactUtils.extractRemoved(getChanges(),ProtocolEntry.class);
-        operationalProtocolEntries = TransactUtils.extractOriginal(getChanges(),ProtocolEntry.class);
         updatedBridges = TransactUtils.extractCreatedOrUpdatedOrRemoved(getChanges(),OvsdbBridgeAugmentation.class);
     }
 
diff --git a/southbound/southbound-impl/src/test/java/org/opendaylight/ovsdb/southbound/ovsdb/transact/ProtocolRemovedCommandTest.java b/southbound/southbound-impl/src/test/java/org/opendaylight/ovsdb/southbound/ovsdb/transact/ProtocolRemovedCommandTest.java
new file mode 100644 (file)
index 0000000..490490d
--- /dev/null
@@ -0,0 +1,114 @@
+/*
+ * Copyright (c) 2015 Inocybe Technologies. 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.ovsdb.southbound.ovsdb.transact;
+
+import static org.mockito.Matchers.any;
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.when;
+
+import java.lang.reflect.Field;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
+
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.mockito.Mock;
+import org.mockito.Mockito;
+import org.mockito.invocation.InvocationOnMock;
+import org.mockito.stubbing.Answer;
+import org.opendaylight.ovsdb.lib.notation.Column;
+import org.opendaylight.ovsdb.lib.notation.Mutator;
+import org.opendaylight.ovsdb.lib.operations.Mutate;
+import org.opendaylight.ovsdb.lib.operations.Operation;
+import org.opendaylight.ovsdb.lib.operations.Operations;
+import org.opendaylight.ovsdb.lib.operations.TransactionBuilder;
+import org.opendaylight.ovsdb.lib.schema.ColumnSchema;
+import org.opendaylight.ovsdb.lib.schema.DatabaseSchema;
+import org.opendaylight.ovsdb.lib.schema.GenericTableSchema;
+import org.opendaylight.ovsdb.lib.schema.typed.TyperUtils;
+import org.opendaylight.ovsdb.schema.openvswitch.Bridge;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbBridgeAugmentation;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbBridgeProtocolBase;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbBridgeProtocolOpenflow10;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.bridge.attributes.ProtocolEntry;
+import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
+import org.powermock.api.mockito.PowerMockito;
+import org.powermock.api.support.membermodification.MemberMatcher;
+import org.powermock.api.support.membermodification.MemberModifier;
+import org.powermock.core.classloader.annotations.PrepareForTest;
+import org.powermock.modules.junit4.PowerMockRunner;
+
+import com.google.common.base.Optional;
+
+@RunWith(PowerMockRunner.class)
+@PrepareForTest({InstanceIdentifier.class, TransactUtils.class, TyperUtils.class })
+public class ProtocolRemovedCommandTest {
+
+    private ProtocolRemovedCommand protocolRemovedCommand;
+
+    private Set<InstanceIdentifier<ProtocolEntry>> removed = new HashSet<>();
+    @Mock private Map<InstanceIdentifier<OvsdbBridgeAugmentation>, OvsdbBridgeAugmentation> updatedBridges;
+
+    @SuppressWarnings("unchecked")
+    @Test
+    public void testExecute() throws Exception {
+        protocolRemovedCommand = mock(ProtocolRemovedCommand.class, Mockito.CALLS_REAL_METHODS);
+
+        PowerMockito.suppress(MemberMatcher.methodsDeclaredIn(InstanceIdentifier.class));
+
+        ProtocolEntry protocol = mock(ProtocolEntry.class);
+        when(protocol.getProtocol()).thenAnswer(new Answer<Class<? extends OvsdbBridgeProtocolBase>>() {
+            public Class<? extends OvsdbBridgeProtocolBase> answer(
+                    InvocationOnMock invocation) throws Throwable {
+                return OvsdbBridgeProtocolOpenflow10.class;
+            }
+        });
+        Optional<ProtocolEntry> operationalProtocolEntryOptional = mock(Optional.class);
+        when(operationalProtocolEntryOptional.isPresent()).thenReturn(true);
+        when(operationalProtocolEntryOptional.get()).thenReturn(protocol);
+
+        BridgeOperationalState bridgeOpState = mock(BridgeOperationalState.class);
+        when(bridgeOpState.getProtocolEntry(any(InstanceIdentifier.class))).thenReturn(operationalProtocolEntryOptional);
+
+        MemberModifier.suppress(MemberMatcher.method(ProtocolUpdateCommand.class, "getOperationalState"));
+        when(protocolRemovedCommand.getOperationalState()).thenReturn(bridgeOpState);
+
+        InstanceIdentifier<ProtocolEntry> protocolIid = mock(InstanceIdentifier.class);
+        removed.add(protocolIid);
+        MemberModifier.field(ProtocolRemovedCommand.class,"removed").set(protocolRemovedCommand, removed);
+
+        MemberModifier.field(ProtocolRemovedCommand.class,"updatedBridges").set(protocolRemovedCommand, updatedBridges);
+        when(updatedBridges.get(any(InstanceIdentifier.class))).thenReturn(mock(OvsdbBridgeAugmentation.class));
+
+        Operations op = (Operations) setField("op");
+        Mutate<GenericTableSchema> mutate = mock(Mutate.class);
+        when(op.mutate(any(Bridge.class))).thenReturn(mutate);
+        Column<GenericTableSchema, Set<String>> column = mock(Column.class);
+        Bridge bridge = mock(Bridge.class);
+        when(bridge.getProtocolsColumn()).thenReturn(column);
+        when(column.getSchema()).thenReturn(mock(ColumnSchema.class));
+        when(column.getData()).thenReturn(new HashSet<String>());
+        when(mutate.addMutation(any(ColumnSchema.class), any(Mutator.class), any(Set.class))).thenReturn(mutate);
+
+        PowerMockito.mockStatic(TyperUtils.class);
+        when(TyperUtils.getTypedRowWrapper(any(DatabaseSchema.class), any(Class.class))).thenReturn(bridge);
+
+        TransactionBuilder transaction = mock(TransactionBuilder.class);
+        protocolRemovedCommand.execute(transaction);
+        Mockito.verify(transaction).add(any(Operation.class));
+    }
+
+    private Object setField(String fieldName) throws Exception {
+        Field field = Operations.class.getDeclaredField(fieldName);
+        field.setAccessible(true);
+        field.set(field.get(Operations.class), mock(Operations.class));
+        return field.get(Operations.class);
+    }
+}