| """ |
| Copyright 2015 Open Networking Foundation (ONF) |
| |
| Please refer questions to either the onos test mailing list at <onos-test@onosproject.org>, |
| the System Testing Plans and Results wiki page at <https://wiki.onosproject.org/x/voMg>, |
| or the System Testing Guide page at <https://wiki.onosproject.org/x/WYQg> |
| |
| TestON is free software: you can redistribute it and/or modify |
| it under the terms of the GNU General Public License as published by |
| the Free Software Foundation, either version 2 of the License, or |
| (at your option) any later version. |
| |
| TestON is distributed in the hope that it will be useful, |
| but WITHOUT ANY WARRANTY; without even the implied warranty of |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| GNU General Public License for more details. |
| |
| You should have received a copy of the GNU General Public License |
| along with TestON. If not, see <http://www.gnu.org/licenses/>. |
| """ |
| |
| # Testing the functionality of SDN-IP with single ONOS instance |
| class USECASE_SdnipFunctionCluster_fsfw: |
| |
| def __init__( self ): |
| self.default = '' |
| global branchName |
| |
| def CASE100( self, main ): |
| """ |
| Start mininet |
| """ |
| import imp |
| main.case( "Setup the Mininet testbed" ) |
| main.dependencyPath = main.testDir + \ |
| main.params[ 'DEPENDENCY' ][ 'path' ] |
| main.topology = main.params[ 'DEPENDENCY' ][ 'topology' ] |
| |
| main.step( "Starting Mininet Topology" ) |
| topology = main.dependencyPath + main.topology |
| topoResult = main.Mininet.startNet( topoFile=topology ) |
| utilities.assert_equals( expect=main.TRUE, |
| actual=topoResult, |
| onpass="Successfully loaded topology", |
| onfail="Failed to load topology" ) |
| # Exit if topology did not load properly |
| if not topoResult: |
| main.cleanup() |
| main.exit() |
| main.step( "Connect switches to FSFW" ) |
| |
| swResult = main.TRUE |
| for i in range ( 1, int( main.params['config']['switchNum'] ) + 1 ): |
| sw = "sw%s" % ( i ) |
| swResult = swResult and main.Mininet.assignSwController( sw, fsfwIp, |
| port=fsfwPort ) |
| |
| utilities.assert_equals( expect=main.TRUE, |
| actual=swResult, |
| onpass="Successfully connect all switches to FSFW", |
| onfail="Failed to connect all switches to FSFW" ) |
| if not swResult: |
| main.cleanup() |
| main.exit() |
| |
| |
| def CASE101( self, main ): |
| """ |
| Package ONOS and install it |
| Startup sequence: |
| cell <name> |
| onos-verify-cell |
| onos-package |
| onos-install -f |
| onos-wait-for-start |
| """ |
| import json |
| import time |
| import os |
| from operator import eq |
| global pr64514 |
| global pr64515 |
| global pr64516 |
| pr64514 = main.params['config']['pr64514'] |
| pr64515 = main.params['config']['pr64515'] |
| pr64516 = main.params['config']['pr64516'] |
| |
| global fsfwIp |
| global fsfwPort |
| fsfwIp = main.params[ 'CTRL' ][ 'fsfwIp' ] |
| fsfwPort = main.params[ 'CTRL' ][ 'fsfwPort' ] |
| |
| try: |
| from tests.USECASE.dependencies.sdnipBaseFunction import SdnBase |
| except ImportError: |
| main.log.error( "sdnBase not found. exiting the test" ) |
| main.exit() |
| try: |
| main.sdnBase |
| except ( NameError, AttributeError ): |
| main.sdnBase = SdnBase() |
| |
| main.sdnBase.initSetup() |
| |
| |
| def CASE200( self, main ): |
| main.case( "Activate sdn-ip application" ) |
| main.log.info( "waiting link discovery......" ) |
| time.sleep( int( main.params['timers']['TopoDiscovery'] ) ) |
| |
| main.log.info( "Get links in the network" ) |
| summaryResult = main.ONOScli1.summary() |
| linkNum = json.loads( summaryResult )[ "links" ] |
| listResult = main.ONOScli1.links( jsonFormat=False ) |
| main.log.info( listResult ) |
| if linkNum < 100: |
| main.log.error( "Link number is wrong!" ) |
| time.sleep( int( main.params['timers']['TopoDiscovery'] ) ) |
| listResult = main.ONOScli1.links( jsonFormat=False ) |
| main.log.info( listResult ) |
| main.cleanup() |
| main.exit() |
| |
| main.step( "Activate sdn-ip application" ) |
| activeSDNIPresult = main.ONOScli1.activateApp( "org.onosproject.sdnip" ) |
| utilities.assert_equals( expect=main.TRUE, |
| actual=activeSDNIPresult, |
| onpass="Activate SDN-IP succeeded", |
| onfail="Activate SDN-IP failed" ) |
| if not activeSDNIPresult: |
| main.log.info( "Activate SDN-IP failed!" ) |
| main.cleanup() |
| main.exit() |
| |
| |
| def CASE102( self, main ): |
| ''' |
| This test case is to load the methods from other Python files, and create |
| tunnels from mininet host to onos nodes. |
| ''' |
| import time |
| main.case( "Load methods from other Python file and create tunnels" ) |
| # load the methods from other file |
| wrapperFile1 = main.params[ 'DEPENDENCY' ][ 'wrapper1' ] |
| main.Functions = imp.load_source( wrapperFile1, |
| main.dependencyPath + |
| wrapperFile1 + |
| ".py" ) |
| # Create tunnels |
| for i in range ( len( main.ONOSip ) ): |
| main.Functions.setupTunnel( main, '1.1.1.' + str( ( i + 1 ) * 2 ), 2000, main.ONOSip[ i ], 2000 ) |
| |
| main.log.info( "Wait SDN-IP to finish installing connectivity intents \ |
| and the BGP paths in data plane are ready..." ) |
| time.sleep( int( main.params[ 'timers' ][ 'SdnIpSetup' ] ) ) |
| |
| main.log.info( "Wait Quagga to finish delivery all routes to each \ |
| other and to sdn-ip, plus finish installing all intents..." ) |
| time.sleep( int( main.params[ 'timers' ][ 'RouteDelivery' ] ) ) |
| |
| def CASE1( self, main ): |
| ''' |
| ping test from 3 bgp peers to BGP speaker |
| ''' |
| |
| main.case( "Ping tests between BGP peers and speakers" ) |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker1"], |
| peers=["pr64514", "pr64515", "pr64516"], |
| expectAllSuccess=True ) |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker2"], |
| peers=[pr64514, pr64515, pr64516], |
| expectAllSuccess=True ) |
| |
| def CASE2( self, main ): |
| ''' |
| point-to-point intents test for each BGP peer and BGP speaker pair |
| ''' |
| main.sdnBase.pToPIntentTest( 12 ) |
| |
| |
| def CASE3( self, main ): |
| ''' |
| routes and intents check to all BGP peers |
| ''' |
| import time |
| main.case( "Check routes and M2S intents to all BGP peers" ) |
| |
| allRoutesExpected = [] |
| allRoutesExpected.append( "4.0.0.0/24" + "/" + "10.0.4.1" ) |
| allRoutesExpected.append( "5.0.0.0/24" + "/" + "10.0.5.1" ) |
| allRoutesExpected.append( "6.0.0.0/24" + "/" + "10.0.6.1" ) |
| |
| main.sdnBase.routeAndIntentCheck( allRoutesExpected, 3 ) |
| |
| |
| def CASE4( self, main ): |
| ''' |
| Ping test in data plane for each route |
| ''' |
| main.case( "Ping test for each route, all hosts behind BGP peers" ) |
| main.Functions.pingHostToHost( main, |
| hosts=["host64514", "host64515", "host64516"], |
| expectAllSuccess=True ) |
| |
| def CASE5( self, main ): |
| ''' |
| Cut links to peers one by one, check routes/intents |
| ''' |
| main.sdnBase.linkUpDownCheck( "pr64514", "pr64515", "pr64516", |
| 2, 2, 1, 1, 0, 0, |
| "speaker1", [ "host64514", "host64515", "host64516" ], |
| "down" ) |
| |
| def CASE6( self, main ): |
| ''' |
| Recover links to peers one by one, check routes/intents |
| ''' |
| main.sdnBase.linkUpDownCheck( "pr64514", "pr64515", "pr64516", |
| 1, 1, 2, 2, 3, 3, |
| "speaker1", [ "host64514", "host64515", "host64516" ], |
| "up" ) |
| |
| def CASE7( self, main ): |
| ''' |
| Shut down a edge switch, check P-2-P and M-2-S intents, ping test |
| ''' |
| import time |
| main.case( "Stop edge sw32,check P-2-P and M-2-S intents, ping test" ) |
| main.step( "Stop sw32" ) |
| result = main.Mininet.switch( SW="sw32", OPTION="stop" ) |
| utilities.assertEquals( expect=main.TRUE, actual=result, |
| onpass="Stopping switch succeeded!", |
| onfail="Stopping switch failed!" ) |
| |
| if result == main.TRUE: |
| time.sleep( int( main.params[ 'timers' ][ 'RouteDelivery' ] ) ) |
| main.Functions.checkRouteNum( main, 2 ) |
| main.Functions.checkM2SintentNum( main, 2 ) |
| main.Functions.checkP2PintentNum( main, 12 * 2 ) |
| else: |
| main.log.error( "Stopping switch failed!" ) |
| main.cleanup() |
| main.exit() |
| |
| main.step( "Check ping between hosts behind BGP peers" ) |
| result1 = main.Mininet.pingHost( src="host64514", target="host64515" ) |
| result2 = main.Mininet.pingHost( src="host64515", target="host64516" ) |
| result3 = main.Mininet.pingHost( src="host64514", target="host64516" ) |
| |
| pingResult1 = ( result1 == main.FALSE ) and ( result2 == main.TRUE ) \ |
| and ( result3 == main.FALSE ) |
| utilities.assert_equals( expect=True, actual=pingResult1, |
| onpass="Ping test result is correct", |
| onfail="Ping test result is wrong" ) |
| |
| if pingResult1 == False: |
| main.cleanup() |
| main.exit() |
| |
| main.step( "Check ping between BGP peers and speaker1" ) |
| result4 = main.Mininet.pingHost( src="speaker1", target="pr64514" ) |
| result5 = main.Mininet.pingHost( src="speaker1", target="pr64515" ) |
| result6 = main.Mininet.pingHost( src="speaker1", target="pr64516" ) |
| |
| pingResult2 = ( result4 == main.FALSE ) and ( result5 == main.TRUE ) \ |
| and ( result6 == main.TRUE ) |
| utilities.assert_equals( expect=True, actual=pingResult2, |
| onpass="Speaker1 ping peers successful", |
| onfail="Speaker1 ping peers NOT successful" ) |
| |
| if pingResult2 == False: |
| main.cleanup() |
| main.exit() |
| |
| main.step( "Check ping between BGP peers and speaker2" ) |
| # TODO |
| result7 = main.Mininet.pingHost( src="speaker2", target=pr64514 ) |
| result8 = main.Mininet.pingHost( src="speaker2", target=pr64515 ) |
| result9 = main.Mininet.pingHost( src="speaker2", target=pr64516 ) |
| |
| pingResult3 = ( result7 == main.FALSE ) and ( result8 == main.TRUE ) \ |
| and ( result9 == main.TRUE ) |
| utilities.assert_equals( expect=True, actual=pingResult2, |
| onpass="Speaker2 ping peers successful", |
| onfail="Speaker2 ping peers NOT successful" ) |
| |
| if pingResult3 == False: |
| main.cleanup() |
| main.exit() |
| |
| main.step( "Check whether all flow status are ADDED" ) |
| flowCheck = utilities.retry( main.ONOScli1.checkFlowsState, |
| main.FALSE, |
| kwargs={'isPENDING':False}, |
| attempts=10 ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=flowCheck, |
| onpass="Flow status is correct!", |
| onfail="Flow status is wrong!" ) |
| |
| |
| def CASE8( self, main ): |
| ''' |
| Bring up the edge switch (sw32) which was shut down in CASE7, |
| check P-2-P and M-2-S intents, ping test |
| ''' |
| import time |
| main.case( "Start the edge sw32, check P-2-P and M-2-S intents, ping test" ) |
| main.step( "Start sw32" ) |
| result1 = main.Mininet.switch( SW="sw32", OPTION="start" ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=result1, |
| onpass="Starting switch succeeded!", |
| onfail="Starting switch failed!" ) |
| |
| result2 = main.Mininet.assignSwController( "sw32", fsfwIp, |
| port=fsfwPort ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=result2, |
| onpass="Connect switch to FSFW succeeded!", |
| onfail="Connect switch to FSFW failed!" ) |
| |
| if result1 and result2: |
| time.sleep( int( main.params[ 'timers' ][ 'RouteDelivery' ] ) ) |
| main.Functions.checkRouteNum( main, 3 ) |
| main.Functions.checkM2SintentNum( main, 3 ) |
| main.Functions.checkP2PintentNum( main, 18 * 2 ) |
| else: |
| main.log.error( "Starting switch failed!" ) |
| main.cleanup() |
| main.exit() |
| |
| main.step( "Check whether all flow status are ADDED" ) |
| flowCheck = utilities.retry( main.ONOScli1.checkFlowsState, |
| main.FALSE, |
| kwargs={'isPENDING':False}, |
| attempts=10 ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=flowCheck, |
| onpass="Flow status is correct!", |
| onfail="Flow status is wrong!" ) |
| |
| # Ping test |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker1"], |
| peers=["pr64514", "pr64515", "pr64516"], |
| expectAllSuccess=True ) |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker2"], |
| peers=[pr64514, pr64515, pr64516], |
| expectAllSuccess=True ) |
| main.Functions.pingHostToHost( main, |
| hosts=["host64514", "host64515", "host64516"], |
| expectAllSuccess=True ) |
| |
| |
| def CASE9( self, main ): |
| ''' |
| Bring down a switch in best path, check: |
| route number, P2P intent number, M2S intent number, ping test |
| ''' |
| main.case( "Stop sw11 located in best path, \ |
| check route number, P2P intent number, M2S intent number, ping test" ) |
| |
| main.log.info( "Check the flow number correctness before stopping sw11" ) |
| main.Functions.checkFlowNum( main, "sw11", 19 ) |
| main.Functions.checkFlowNum( main, "sw1", 3 ) |
| main.Functions.checkFlowNum( main, "sw7", 3 ) |
| main.log.info( main.Mininet.checkFlows( "sw11" ) ) |
| main.log.info( main.Mininet.checkFlows( "sw1" ) ) |
| main.log.info( main.Mininet.checkFlows( "sw7" ) ) |
| |
| main.step( "Stop sw11" ) |
| result = main.Mininet.switch( SW="sw11", OPTION="stop" ) |
| utilities.assertEquals( expect=main.TRUE, actual=result, |
| onpass="Stopping switch succeeded!", |
| onfail="Stopping switch failed!" ) |
| if result: |
| time.sleep( int( main.params[ 'timers' ][ 'RouteDelivery' ] ) ) |
| time.sleep( int( main.params[ 'timers' ][ 'RouteDelivery' ] ) ) |
| main.Functions.checkRouteNum( main, 3 ) |
| main.Functions.checkM2SintentNum( main, 3 ) |
| main.Functions.checkP2PintentNum( main, 18 * 2 ) |
| else: |
| main.log.error( "Stopping switch failed!" ) |
| main.cleanup() |
| main.exit() |
| |
| main.step( "Check whether all flow status are ADDED" ) |
| flowCheck = utilities.retry( main.ONOScli1.checkFlowsState, |
| main.FALSE, |
| kwargs={'isPENDING':False}, |
| attempts=10 ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=flowCheck, |
| onpass="Flow status is correct!", |
| onfail="Flow status is wrong!" ) |
| # Ping test |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker1"], |
| peers=["pr64514", "pr64515", "pr64516"], |
| expectAllSuccess=True ) |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker2"], |
| peers=[pr64514, pr64515, pr64516], |
| expectAllSuccess=True ) |
| main.Functions.pingHostToHost( main, |
| hosts=["host64514", "host64515", "host64516"], |
| expectAllSuccess=True ) |
| |
| |
| def CASE10( self, main ): |
| ''' |
| Bring up the switch which was stopped in CASE9, check: |
| route number, P2P intent number, M2S intent number, ping test |
| ''' |
| main.case( "Start sw11 which was stopped in CASE9, \ |
| check route number, P2P intent number, M2S intent number, ping test" ) |
| |
| main.log.info( "Check the flow status before starting sw11" ) |
| main.Functions.checkFlowNum( main, "sw1", 17 ) |
| main.Functions.checkFlowNum( main, "sw7", 5 ) |
| main.log.info( main.Mininet.checkFlows( "sw1" ) ) |
| main.log.info( main.Mininet.checkFlows( "sw7" ) ) |
| |
| main.step( "Start sw11" ) |
| result1 = main.Mininet.switch( SW="sw11", OPTION="start" ) |
| utilities.assertEquals( expect=main.TRUE, actual=result1, |
| onpass="Starting switch succeeded!", |
| onfail="Starting switch failed!" ) |
| result2 = main.Mininet.assignSwController( "sw11", fsfwIp, |
| port=fsfwPort ) |
| utilities.assertEquals( expect=main.TRUE, actual=result2, |
| onpass="Connect switch to FSFW succeeded!", |
| onfail="Connect switch to FSFW failed!" ) |
| if result1 and result2: |
| time.sleep( int( main.params[ 'timers' ][ 'RouteDelivery' ] ) ) |
| main.Functions.checkRouteNum( main, 3 ) |
| main.Functions.checkM2SintentNum( main, 3 ) |
| main.Functions.checkP2PintentNum( main, 18 * 2 ) |
| |
| main.log.debug( main.Mininet.checkFlows( "sw11" ) ) |
| main.log.debug( main.Mininet.checkFlows( "sw1" ) ) |
| main.log.debug( main.Mininet.checkFlows( "sw7" ) ) |
| else: |
| main.log.error( "Starting switch failed!" ) |
| main.cleanup() |
| main.exit() |
| |
| main.step( "Check whether all flow status are ADDED" ) |
| flowCheck = utilities.retry( main.ONOScli1.checkFlowsState, |
| main.FALSE, |
| kwargs={'isPENDING':False}, |
| attempts=10 ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=flowCheck, |
| onpass="Flow status is correct!", |
| onfail="Flow status is wrong!" ) |
| # Ping test |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker1"], |
| peers=["pr64514", "pr64515", "pr64516"], |
| expectAllSuccess=True ) |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker2"], |
| peers=[pr64514, pr64515, pr64516], |
| expectAllSuccess=True ) |
| main.Functions.pingHostToHost( main, |
| hosts=["host64514", "host64515", "host64516"], |
| expectAllSuccess=True ) |
| |
| |
| def CASE11(self, main): |
| import time |
| main.case( "Kill speaker1, check:\ |
| route number, P2P intent number, M2S intent number, ping test" ) |
| main.log.info( "Check network status before killing speaker1" ) |
| main.Functions.checkRouteNum( main, 3 ) |
| main.Functions.checkM2SintentNum( main, 3 ) |
| main.Functions.checkP2PintentNum( main, 18 * 2 ) |
| main.step( "Check whether all flow status are ADDED" ) |
| flowCheck = utilities.retry( main.ONOScli1.checkFlowsState, |
| main.FALSE, |
| kwargs={'isPENDING':False}, |
| attempts=10 ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=flowCheck, |
| onpass="Flow status is correct!", |
| onfail="Flow status is wrong!" ) |
| |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker1"], |
| peers=["pr64514", "pr64515", "pr64516"], |
| expectAllSuccess=True ) |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker2"], |
| peers=[pr64514, pr64515, pr64516], |
| expectAllSuccess=True ) |
| main.Functions.pingHostToHost( main, |
| hosts=["host64514", "host64515", "host64516"], |
| expectAllSuccess=True ) |
| |
| main.step( "Kill speaker1" ) |
| command1 = "ps -e | grep bgp -c" |
| result1 = main.Mininet.node( "root", command1 ) |
| |
| # The total BGP daemon number in this test environment is 5. |
| if "5" in result1: |
| main.log.debug( "Before kill speaker1, 5 BGP daemons - correct" ) |
| else: |
| main.log.warn( "Before kill speaker1, number of BGP daemons is wrong" ) |
| main.log.info( result1 ) |
| |
| command2 = "sudo kill -9 `ps -ef | grep quagga-sdn.conf | grep -v grep | awk '{print $2}'`" |
| result2 = main.Mininet.node( "root", command2 ) |
| |
| result3 = main.Mininet.node( "root", command1 ) |
| |
| utilities.assert_equals( expect=True, |
| actual=( "4" in result3 ), |
| onpass="Kill speaker1 succeeded", |
| onfail="Kill speaker1 failed" ) |
| if ( "4" not in result3 ) : |
| main.log.info( result3 ) |
| main.cleanup() |
| main.exit() |
| |
| time.sleep( int( main.params[ 'timers' ][ 'RouteDelivery' ] ) ) |
| main.Functions.checkRouteNum( main, 3 ) |
| main.Functions.checkM2SintentNum( main, 3 ) |
| main.Functions.checkP2PintentNum( main, 18 * 2 ) |
| |
| main.step( "Check whether all flow status are ADDED" ) |
| flowCheck = utilities.retry( main.ONOScli1.checkFlowsState, |
| main.FALSE, |
| kwargs={'isPENDING':False}, |
| attempts=10 ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=flowCheck, |
| onpass="Flow status is correct!", |
| onfail="Flow status is wrong!" ) |
| |
| ''' |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker1"], |
| peers=["pr64514", "pr64515", "pr64516"], |
| expectAllSuccess=False ) |
| ''' |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker2"], |
| peers=[pr64514, pr64515, pr64516], |
| expectAllSuccess=True ) |
| main.Functions.pingHostToHost( main, |
| hosts=["host64514", "host64515", "host64516"], |
| expectAllSuccess=True ) |
| |
| |
| def CASE12( self, main ): |
| import time |
| import json |
| main.case( "Bring down leader ONOS node, check: \ |
| route number, P2P intent number, M2S intent number, ping test" ) |
| main.step( "Find out ONOS leader node" ) |
| result = main.ONOScli1.leaders() |
| jsonResult = json.loads( result ) |
| leaderIP = "" |
| for entry in jsonResult: |
| if entry["topic"] == "org.onosproject.sdnip": |
| leaderIP = entry["leader"] |
| main.log.info( "leaderIP is: " ) |
| main.log.info( leaderIP ) |
| |
| main.step( "Uninstall ONOS/SDN-IP leader node" ) |
| for ip in main.ONOSip: |
| if leaderIP == ip: |
| uninstallResult = main.ONOSbench.onosStop( ip ) |
| |
| utilities.assert_equals( expect=main.TRUE, |
| actual=uninstallResult, |
| onpass="Uninstall ONOS leader succeeded", |
| onfail="Uninstall ONOS leader failed" ) |
| if uninstallResult != main.TRUE: |
| main.cleanup() |
| main.exit() |
| time.sleep( int( main.params[ 'timers' ][ 'RouteDelivery' ] ) ) |
| |
| if leaderIP == main.ONOSip[ 0 ]: |
| main.Functions.checkRouteNum( main, 3, ONOScli="ONOScli2" ) |
| main.Functions.checkM2SintentNum( main, 3, ONOScli="ONOScli2" ) |
| main.Functions.checkP2PintentNum( main, 18 * 2, ONOScli="ONOScli2" ) |
| |
| main.step( "Check whether all flow status are ADDED" ) |
| flowCheck = utilities.retry( main.ONOScli1.checkFlowsState, |
| main.FALSE, |
| kwargs={'isPENDING':False}, |
| attempts=10 ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=flowCheck, |
| onpass="Flow status is correct!", |
| onfail="Flow status is wrong!" ) |
| else: |
| main.Functions.checkRouteNum( main, 3 ) |
| main.Functions.checkM2SintentNum( main, 3 ) |
| main.Functions.checkP2PintentNum( main, 18 * 2 ) |
| |
| main.step( "Check whether all flow status are ADDED" ) |
| flowCheck = utilities.retry( main.ONOScli1.checkFlowsState, |
| main.FALSE, |
| kwargs={'isPENDING':False}, |
| attempts=10 ) |
| utilities.assertEquals( \ |
| expect=main.TRUE, |
| actual=flowCheck, |
| onpass="Flow status is correct!", |
| onfail="Flow status is wrong!" ) |
| |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker1"], |
| peers=["pr64514", "pr64515", "pr64516"], |
| expectAllSuccess=True ) |
| main.Functions.pingSpeakerToPeer( main, speakers=["speaker2"], |
| peers=[pr64514, pr64515, pr64516], |
| expectAllSuccess=True ) |
| main.Functions.pingHostToHost( main, |
| hosts=["host64514", "host64515", "host64516"], |
| expectAllSuccess=True ) |