Fixes openflow echo req adding flush after write

This fix will avoid the disconnection of the backup instance

Change-Id: I6e4251c0207cdf8a044d2f0f6b033385823b0c51
diff --git a/protocols/openflow/ctl/src/main/java/org/onosproject/openflow/controller/impl/OFChannelHandler.java b/protocols/openflow/ctl/src/main/java/org/onosproject/openflow/controller/impl/OFChannelHandler.java
index e04bd41..b2fc126 100644
--- a/protocols/openflow/ctl/src/main/java/org/onosproject/openflow/controller/impl/OFChannelHandler.java
+++ b/protocols/openflow/ctl/src/main/java/org/onosproject/openflow/controller/impl/OFChannelHandler.java
@@ -1374,7 +1374,7 @@
         if (factory != null) {
             OFMessage m = factory.buildEchoRequest().build();
             log.debug("Sending Echo Request on idle channel: {}", ctx.channel());
-            ctx.write(Collections.singletonList(m), ctx.voidPromise());
+            ctx.writeAndFlush(Collections.singletonList(m), ctx.voidPromise());
             // XXX S some problems here -- echo request has no transaction id, and
             // echo reply is not correlated to the echo request.
         }
@@ -1385,12 +1385,13 @@
     public void userEventTriggered(ChannelHandlerContext ctx,
                                    Object evt)
             throws Exception {
-
+        // If the connection is READER/WRITER idle try to send an echo request
         if (evt instanceof IdleStateEvent) {
+            log.info("Channel {} is {}", ctx.channel(), ((IdleStateEvent) evt).state());
             channelIdle(ctx, (IdleStateEvent) evt);
+        } else {
+            super.userEventTriggered(ctx, evt);
         }
-
-        super.userEventTriggered(ctx, evt);
     }
 
     // SimpleChannelInboundHandler without dependency to TypeParameterMatcher