Ditch use of SystemNotificationsListener
[openflowplugin.git] / openflowplugin-impl / src / test / java / org / opendaylight / openflowplugin / impl / device / listener / OpenflowProtocolListenerFullImplTest.java
index 5b985c1bd502758033cbaad1a50ccc1e0364fb58..2de02d448ef9364a17c4faca4a33493e5fa4df17 100644 (file)
-/**
+/*
  * Copyright (c) 2015 Cisco Systems, Inc. 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.device.listener;
 
-import static org.junit.Assert.fail;
+import static org.mockito.ArgumentMatchers.any;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.verifyNoMoreInteractions;
+import static org.mockito.Mockito.when;
+
+import com.google.common.util.concurrent.Futures;
+import java.net.InetSocketAddress;
+import org.junit.After;
 import org.junit.Before;
-import org.junit.Ignore;
 import org.junit.Test;
 import org.junit.runner.RunWith;
 import org.mockito.Mock;
-import org.mockito.Mockito;
-import org.mockito.runners.MockitoJUnitRunner;
+import org.mockito.junit.MockitoJUnitRunner;
 import org.opendaylight.openflowjava.protocol.api.connection.ConnectionAdapter;
-import org.opendaylight.openflowplugin.api.openflow.device.Xid;
+import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
 import org.opendaylight.openflowplugin.api.openflow.device.handlers.DeviceReplyProcessor;
-import org.opendaylight.openflowplugin.impl.connection.listener.OpenflowProtocolListenerInitialImpl;
-import org.opendaylight.openflowplugin.impl.connection.testutil.MsgGeneratorTestUtils;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReply;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReplyMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.EchoReplyInput;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.EchoRequestMessageBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ErrorMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ErrorMessageBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ExperimenterMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ExperimenterMessageBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.FlowRemovedMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.FlowRemovedMessageBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.HelloMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.HelloMessageBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.OpenflowProtocolListener;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.PacketInMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.PacketInMessageBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.PortStatusMessage;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.PortStatusMessageBuilder;
+import org.opendaylight.yangtools.yang.common.Uint32;
 
 /**
  * openflowplugin-impl
  * org.opendaylight.openflowplugin.impl.connection.listener
- * <p/>
- * test of {@link OpenflowProtocolListenerInitialImpl} - lightweight version, using basic ways (TDD)
+ * test of {@link OpenflowProtocolListenerFullImpl} - lightweight version, using basic ways (TDD).
  *
- * @author <a href="mailto:vdemcak@cisco.com">Vaclav Demcak</a>
- *         <p/>
- *         Created: Mar 26, 2015
+ * @author Vaclav Demcak
  */
 @RunWith(MockitoJUnitRunner.class)
 public class OpenflowProtocolListenerFullImplTest {
-
-
-    private OpenflowProtocolListenerFullImpl ofProtocolListener;
-
     @Mock
     private DeviceReplyProcessor deviceReplyProcessor;
     @Mock
     private ConnectionAdapter connectionAdapter;
 
+    private final Uint32 xid = Uint32.valueOf(42);
+
+    private OpenflowProtocolListenerFullImpl ofProtocolListener;
+
     @Before
     public void setUp() {
         // place for mocking method's general behavior for HandshakeContext and ConnectionContext
         ofProtocolListener = new OpenflowProtocolListenerFullImpl(connectionAdapter, deviceReplyProcessor);
+        connectionAdapter.setMessageListener(ofProtocolListener);
+        when(connectionAdapter.getRemoteAddress())
+                .thenReturn(InetSocketAddress.createUnresolved("ofp-junit.example.org", 6663));
+        verify(connectionAdapter).setMessageListener(any(OpenflowProtocolListener.class));
     }
 
-    /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#OpenflowProtocolListenerInitialImpl(org.opendaylight.openflowplugin.api.openflow.connection.ConnectionContext, org.opendaylight.openflowplugin.api.openflow.connection.HandshakeContext)}.
-     */
-    @Test
-    @Ignore
-    public void testOpenflowProtocolListenerImpl() {
-        fail("Not yet implemented");
+    @After
+    public void tearDown() {
+        verifyNoMoreInteractions(connectionAdapter, deviceReplyProcessor);
     }
 
     /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#onEchoRequestMessage(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.EchoRequestMessage)}.
+     * Test method for
+     * {@link OpenflowProtocolListenerFullImpl#onEchoRequestMessage(
+     * org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.EchoRequestMessage)}.
      */
     @Test
-    @Ignore
     public void testOnEchoRequestMessage() {
-        fail("Not yet implemented");
+        when(connectionAdapter.echoReply(any())).thenReturn(Futures.immediateFuture(null));
+        ofProtocolListener.onEchoRequestMessage(
+            new EchoRequestMessageBuilder().setVersion(EncodeConstants.OF_VERSION_1_3).setXid(xid).build());
+
+        verify(connectionAdapter).echoReply(any(EchoReplyInput.class));
     }
 
     /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#onErrorMessage(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ErrorMessage)}.
+     * Test method for
+     * {@link OpenflowProtocolListenerFullImpl#onErrorMessage(
+     * org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ErrorMessage)}.
      */
     @Test
-    @Ignore
     public void testOnErrorMessage() {
-        fail("Not yet implemented");
+        ErrorMessage errorMessage = new ErrorMessageBuilder()
+                .setVersion(EncodeConstants.OF_VERSION_1_3).setXid(xid).build();
+        ofProtocolListener.onErrorMessage(errorMessage);
+
+        verify(deviceReplyProcessor).processReply(any(ErrorMessage.class));
     }
 
     /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#onExperimenterMessage(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ExperimenterMessage)}.
+     * Test method for
+     * {@link OpenflowProtocolListenerFullImpl#onExperimenterMessage(
+     * org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.ExperimenterMessage)}.
      */
     @Test
-    @Ignore
     public void testOnExperimenterMessage() {
-        fail("Not yet implemented");
+        ExperimenterMessage experimenterMessage = new ExperimenterMessageBuilder()
+                .setVersion(EncodeConstants.OF_VERSION_1_3).setXid(xid).build();
+        ofProtocolListener.onExperimenterMessage(experimenterMessage);
+
+        verify(deviceReplyProcessor).processExperimenterMessage(any());
     }
 
     /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#onFlowRemovedMessage(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.FlowRemovedMessage)}.
+     * Test method for
+     * {@link OpenflowProtocolListenerFullImpl#onFlowRemovedMessage(
+     * org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.FlowRemovedMessage)}.
      */
     @Test
-    @Ignore
     public void testOnFlowRemovedMessage() {
-        fail("Not yet implemented");
+        FlowRemovedMessage flowRemovedMessage = new FlowRemovedMessageBuilder()
+                .setVersion(EncodeConstants.OF_VERSION_1_3).setXid(xid).build();
+        ofProtocolListener.onFlowRemovedMessage(flowRemovedMessage);
+
+        verify(deviceReplyProcessor).processFlowRemovedMessage(any(FlowRemovedMessage.class));
     }
 
     /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#onHelloMessage(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.HelloMessage)}.
+     * Test method for
+     * {@link OpenflowProtocolListenerFullImpl#onHelloMessage(
+     * org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.HelloMessage)}.
      */
     @Test
-    @Ignore
     public void testOnHelloMessage() {
-        fail("Not yet implemented");
-    }
+        HelloMessage helloMessage = new HelloMessageBuilder()
+                .setVersion(EncodeConstants.OF_VERSION_1_3).setXid(xid).build();
+        ofProtocolListener.onHelloMessage(helloMessage);
 
-    /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#onMultipartReplyMessage(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.MultipartReplyMessage)}.
-     */
-    @Test
-    public void testOnMultipartReplyMessage() {
-        final long xid = 1l;
-        ofProtocolListener.registerMultipartMsg(xid);
-        final MultipartReply multipartReply = MsgGeneratorTestUtils.makeMultipartDescReply(xid, "test-val", false);
-        ofProtocolListener.onMultipartReplyMessage((MultipartReplyMessage) multipartReply);
-        Mockito.verify(deviceReplyProcessor, Mockito.times(1)).processReply(Mockito.any(Xid.class), Mockito.anyListOf(MultipartReply.class));
+        verify(connectionAdapter).getRemoteAddress();
+        verify(connectionAdapter).disconnect();
     }
 
     /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#onPacketInMessage(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.PacketInMessage)}.
+     * Test method for
+     * {@link OpenflowProtocolListenerFullImpl#onPacketInMessage(
+     * org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.PacketInMessage)}.
      */
     @Test
-    @Ignore
     public void testOnPacketInMessage() {
-        fail("Not yet implemented");
+        PacketInMessage packetInMessage = new PacketInMessageBuilder()
+                .setVersion(EncodeConstants.OF_VERSION_1_3).setXid(xid).build();
+        ofProtocolListener.onPacketInMessage(packetInMessage);
+
+        verify(deviceReplyProcessor).processPacketInMessage(any(PacketInMessage.class));
     }
 
     /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#onPortStatusMessage(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.PortStatusMessage)}.
+     * Test method for
+     * {@link OpenflowProtocolListenerFullImpl#onPortStatusMessage(
+     * org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.PortStatusMessage)}.
      */
     @Test
-    @Ignore
     public void testOnPortStatusMessage() {
-        fail("Not yet implemented");
-    }
+        PortStatusMessage portStatusMessage = new PortStatusMessageBuilder()
+                .setVersion(EncodeConstants.OF_VERSION_1_3).setXid(xid).build();
+        ofProtocolListener.onPortStatusMessage(portStatusMessage);
 
-    /**
-     * Test method for {@link OpenflowProtocolListenerInitialImpl#checkState(org.opendaylight.openflowplugin.api.openflow.connection.ConnectionContext.CONNECTION_STATE)}.
-     */
-    @Test
-    @Ignore
-    public void testCheckState() {
-        fail("Not yet implemented");
+        verify(deviceReplyProcessor).processPortStatusMessage(any(PortStatusMessage.class));
     }
-
 }