Merge "Fix checkFlowsByDpid to retry"
diff --git a/TestON/JenkinsFile/JenkinsCommonFuncs.groovy b/TestON/JenkinsFile/JenkinsCommonFuncs.groovy
index 5925a6f..906c05d 100644
--- a/TestON/JenkinsFile/JenkinsCommonFuncs.groovy
+++ b/TestON/JenkinsFile/JenkinsCommonFuncs.groovy
@@ -194,7 +194,7 @@
 def publishToConfluence( prop, wikiLink, file ){
   if( isPostingResult( prop[ "manualRun" ], prop[ "postResult" ] ) ){
     publishConfluence siteName: 'wiki.onosproject.org', pageName: wikiLink, spaceName: 'ONOS',
-                  attachArchivedArtifacts: true,
+                  attachArchivedArtifacts: true, buildIfUnstable: true,
                   editorList: [
                       confluenceWritePage( confluenceFile( file ) )
                   ]
@@ -328,4 +328,4 @@
     echo ''' + database_command + '''
     done '''
 }
-return this;
\ No newline at end of file
+return this;
diff --git a/TestON/drivers/common/cli/emulator/mininetclidriver.py b/TestON/drivers/common/cli/emulator/mininetclidriver.py
index 580b3b5..d962e92 100644
--- a/TestON/drivers/common/cli/emulator/mininetclidriver.py
+++ b/TestON/drivers/common/cli/emulator/mininetclidriver.py
@@ -491,13 +491,13 @@
             main.log.exception( self.name + ": Uncaught exception!" )
             main.cleanAndExit()
 
-    def pingIpv6Hosts( self, hostList, prefix='1000::', wait=1 ):
+    def pingIpv6Hosts( self, hostList, wait=1, acceptableFailed=0 ):
         """
-        IPv6 ping all hosts in hostList. If no prefix passed this will use
-        default prefix of 1000::
+        IPv6 ping all hosts in hostList.
+
+        acceptableFailed: max number of acceptable failed pings
 
         Returns main.TRUE if all hosts specified can reach each other
-
         Returns main.FALSE if one or more of hosts specified cannot reach each other
         """
         try:
@@ -506,7 +506,7 @@
             wait = int( wait )
             cmd = " ping6 -c 1 -i 1 -W " + str( wait ) + " "
             pingResponse = "IPv6 Pingall output:\n"
-            failedPings = 0
+            failedPingsTotal = 0
             for host in hostList:
                 listIndex = hostList.index( host )
                 # List of hosts to ping other than itself
@@ -517,19 +517,26 @@
 
                 for temp in pingList:
                     # Current host pings all other hosts specified
+                    failedPings = 0
                     pingCmd = str( host ) + cmd + str( self.getIPAddress( temp, proto='IPv6' ) )
-                    self.handle.sendline( pingCmd )
-                    self.handle.expect( "mininet>", timeout=wait + 1 )
-                    response = self.handle.before
-                    if re.search( ',\s0\%\spacket\sloss', response ):
-                        pingResponse += str( " h" + str( temp[ 1: ] ) )
-                    else:
-                        pingResponse += " X"
+                    while failedPings <= acceptableFailed:
+                        main.log.debug( "Pinging from " + str( host ) + " to " + str( temp ) )
+                        self.handle.sendline( pingCmd )
+                        self.handle.expect( "mininet>", timeout=wait + 1 )
+                        response = self.handle.before
+                        if re.search( ',\s0\%\spacket\sloss', response ):
+                            pingResponse += str( " h" + str( temp[ 1: ] ) )
+                            break
+                        else:
+                            failedPings += 1
+                            time.sleep(1)
+                    if failedPings > acceptableFailed:
                         # One of the host to host pair is unreachable
+                        pingResponse += " X"
                         isReachable = main.FALSE
-                        failedPings += 1
+                        failedPingsTotal += 1
                 pingResponse += "\n"
-            main.log.info( pingResponse + "Failed pings: " + str( failedPings ) )
+            main.log.info( pingResponse + "Failed pings: " + str( failedPingsTotal ) )
             return isReachable
 
         except pexpect.TIMEOUT:
diff --git a/TestON/tests/USECASE/SegmentRouting/SRRouting/dependencies/SRRoutingTest.py b/TestON/tests/USECASE/SegmentRouting/SRRouting/dependencies/SRRoutingTest.py
index b1c8ea1..7566ff4 100644
--- a/TestON/tests/USECASE/SegmentRouting/SRRouting/dependencies/SRRoutingTest.py
+++ b/TestON/tests/USECASE/SegmentRouting/SRRouting/dependencies/SRRoutingTest.py
@@ -73,7 +73,7 @@
             time.sleep(60)
 
         # ping hosts
-        run.pingAllBasedOnIp( main, 'CASE%02d' % test_idx )
+        run.pingAll( main, 'CASE%02d' % test_idx, acceptableFailed=5, basedOnIp=True )
 
         if hasattr(main, 'Mininet1'):
             run.cleanup(main)
diff --git a/TestON/tests/USECASE/SegmentRouting/dependencies/Testcaselib.py b/TestON/tests/USECASE/SegmentRouting/dependencies/Testcaselib.py
index 97947be..b032efc 100644
--- a/TestON/tests/USECASE/SegmentRouting/dependencies/Testcaselib.py
+++ b/TestON/tests/USECASE/SegmentRouting/dependencies/Testcaselib.py
@@ -286,7 +286,11 @@
             onfail="Flow count looks wrong. " )
 
     @staticmethod
-    def pingAllBasedOnIp( main, tag="", dumpflows=True ):
+    def pingAll( main, tag="", dumpflows=True, acceptableFailed=0, basedOnIp=False ):
+        '''
+        acceptableFailed: max number of acceptable failed pings. Only works for ping6
+        basedOnIp: if True, run ping or ping6 based on suffix of host names
+        '''
         main.log.report( "Check full connectivity" )
         print main.pingChart
         if tag == "":
@@ -300,16 +304,22 @@
                 expect = main.FALSE
             main.step( "Connectivity for %s %s" % ( str( hosts ), tag ) )
 
-            if ("v4" in hosts[0]):
+            if basedOnIp:
+                if ("v4" in hosts[0]):
+                    pa = main.Network.pingallHosts( hosts )
+                    utilities.assert_equals( expect=expect, actual=pa,
+                                             onpass="IPv4 connectivity successfully tested",
+                                             onfail="IPv4 connectivity failed" )
+                if ("v6" in hosts[0]):
+                    pa = main.Network.pingIpv6Hosts( hosts, acceptableFailed=acceptableFailed )
+                    utilities.assert_equals( expect=expect, actual=pa,
+                                             onpass="IPv6 connectivity successfully tested",
+                                             onfail="IPv6 connectivity failed" )
+            else:
                 pa = main.Network.pingallHosts( hosts )
                 utilities.assert_equals( expect=expect, actual=pa,
-                                         onpass="IPv4 connectivity successfully tested",
-                                         onfail="IPv4 connectivity failed" )
-            if ("v6" in hosts[0]):
-                pa = main.Network.pingIpv6Hosts( hosts )
-                utilities.assert_equals( expect=expect, actual=pa,
-                                         onpass="IPv6 connectivity successfully tested",
-                                         onfail="IPv6 connectivity failed" )
+                                         onpass="IP connectivity successfully tested",
+                                         onfail="IP connectivity failed" )
 
         if dumpflows:
             main.ONOSbench.dumpONOSCmd( main.Cluster.active( 0 ).ipAddress,
@@ -322,35 +332,6 @@
                                         tag + "_GroupsOn" )
 
     @staticmethod
-    def pingAll( main, tag="", dumpflows=True ):
-        main.log.report( "Check full connectivity" )
-        print main.pingChart
-        if tag == "":
-            tag = 'CASE%d' % main.CurrentTestCaseNumber
-        for entry in main.pingChart.itervalues():
-            print entry
-            hosts, expect = entry[ 'hosts' ], entry[ 'expect' ]
-            try:
-                expect = main.TRUE if str(expect).lower() == 'true' else main.FALSE
-            except:
-                expect = main.FALSE
-            main.step( "Connectivity for %s %s" % ( str( hosts ), tag ) )
-            pa = main.Network.pingallHosts( hosts )
-
-            utilities.assert_equals( expect=expect, actual=pa,
-                                     onpass="IP connectivity successfully tested",
-                                     onfail="IP connectivity failed" )
-        if dumpflows:
-            main.ONOSbench.dumpONOSCmd( main.Cluster.active( 0 ).ipAddress,
-                                        "flows",
-                                        main.logdir,
-                                        tag + "_FlowsOn" )
-            main.ONOSbench.dumpONOSCmd( main.Cluster.active( 0 ).ipAddress,
-                                        "groups",
-                                        main.logdir,
-                                        tag + "_GroupsOn" )
-
-    @staticmethod
     def killLink( main, end1, end2, switches, links ):
         """
         end1,end2: identify the switches, ex.: 'leaf1', 'spine1'