Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 1 | class SReNBLeafSpinePortstateFailure: |
| 2 | def __init__( self ): |
| 3 | self.default = '' |
| 4 | |
| 5 | def CASE1( self, main ): |
| 6 | main.case("Testing connections") |
| 7 | main.persistentSetup = True |
| 8 | |
| 9 | def CASE2( self, main ): |
| 10 | """ |
| 11 | Connect to Pod |
| 12 | Perform eNB Leaf-Spine Link, portstate failure/recovery test |
| 13 | Collect logs and analyze results |
| 14 | """ |
| 15 | try: |
| 16 | from tests.USECASE.SegmentRouting.SRStaging.dependencies.SRStagingTest import SRStagingTest |
| 17 | import json |
| 18 | except ImportError: |
| 19 | main.log.error( "SRStagingTest not found. Exiting the test" ) |
| 20 | main.cleanAndExit() |
| 21 | try: |
| 22 | main.funcs |
| 23 | except ( NameError, AttributeError ): |
| 24 | main.funcs = SRStagingTest() |
| 25 | |
| 26 | descPrefix = "eNB_Leaf_Spine_Portstate" |
Jon Hall | be3a2ac | 2021-03-15 12:28:06 -0700 | [diff] [blame] | 27 | leafType = "eNB" |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 28 | main.funcs.setupTest( main, |
| 29 | topology='2x2staging', |
| 30 | onosNodes=3, |
| 31 | description="%s tests on the staging pod" % descPrefix ) |
| 32 | srcComponentNames = main.params[ 'PERF' ][ 'traffic_host' ].split() |
| 33 | srcComponentList = [] |
| 34 | for name in srcComponentNames: |
| 35 | srcComponentList.append( getattr( main, name ) ) |
| 36 | dstComponent = getattr( main, main.params[ 'PERF' ][ 'pcap_host' ] ) |
| 37 | |
| 38 | main.downtimeResults = {} |
| 39 | dbHeaders = [] |
| 40 | srcNames = [ src.name for src in srcComponentList ] |
| 41 | srcNames.sort() |
Jon Hall | be3a2ac | 2021-03-15 12:28:06 -0700 | [diff] [blame] | 42 | deviceShortName = None |
| 43 | portsList = [] |
| 44 | for shortName, values in main.params['PERF']['topo'].iteritems(): |
| 45 | if leafType in values['note']: |
| 46 | deviceShortName = shortName |
| 47 | portsList = [ int( p ) for p in values['ports'].split() ] |
| 48 | break |
| 49 | if not deviceShortName: |
| 50 | main.skipCase( result="FAIL", msg="Don't know which switch for test" ) |
| 51 | |
| 52 | device = "device:" + deviceShortName |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 53 | port1 = None |
| 54 | port2 = None |
| 55 | port3 = None |
| 56 | port4 = None |
| 57 | |
| 58 | ## First Link Down |
| 59 | shortDesc = descPrefix + "-Failure1" |
| 60 | longDesc = "%s Failure: Bring down port with most traffic on %s" % ( descPrefix, device ) |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 61 | targets = {} |
| 62 | targets[device] = portsList |
| 63 | device1, port1 = main.funcs.linkDown( targets, srcComponentList, dstComponent, shortDesc, longDesc ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 64 | for src in srcNames: |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 65 | srcComponent = getattr( main, src ) |
| 66 | dbHeaders.append( "%s-%s" % ( shortDesc, srcComponent.shortName ) ) |
| 67 | dbHeaders.append( "%s-%s-to-%s" % ( shortDesc, srcComponent.shortName, dstComponent.shortName ) ) |
| 68 | # Second Link Down |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 69 | shortDesc = descPrefix + "-Failure2" |
| 70 | longDesc = "%s Failure: Bring down port with most traffic on %s" % ( descPrefix, device ) |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 71 | device2, port2 = main.funcs.linkDown( targets, srcComponentList, dstComponent, shortDesc, longDesc ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 72 | for src in srcNames: |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 73 | srcComponent = getattr( main, src ) |
| 74 | dbHeaders.append( "%s-%s" % ( shortDesc, srcComponent.shortName ) ) |
| 75 | dbHeaders.append( "%s-%s-to-%s" % ( shortDesc, srcComponent.shortName, dstComponent.shortName ) ) |
| 76 | # First Link Up |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 77 | shortDesc = descPrefix + "-Recovery1" |
| 78 | longDesc = "%s Recovery: Bring up %s/%s" % ( descPrefix, device, port1 ) |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 79 | main.funcs.linkUp( device1, port1, srcComponentList, dstComponent, shortDesc, longDesc ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 80 | for src in srcNames: |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 81 | srcComponent = getattr( main, src ) |
| 82 | dbHeaders.append( "%s-%s" % ( shortDesc, srcComponent.shortName ) ) |
| 83 | dbHeaders.append( "%s-%s-to-%s" % ( shortDesc, srcComponent.shortName, dstComponent.shortName ) ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 84 | ## Second Link Up |
| 85 | shortDesc = descPrefix + "-Recovery2" |
| 86 | longDesc = "%s Recovery: Bring up %s/%s" % ( descPrefix, device, port2 ) |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 87 | main.funcs.linkUp( device2, port2, srcComponentList, dstComponent, shortDesc, longDesc ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 88 | for src in srcNames: |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 89 | srcComponent = getattr( main, src ) |
| 90 | dbHeaders.append( "%s-%s" % ( shortDesc, srcComponent.shortName ) ) |
| 91 | dbHeaders.append( "%s-%s-to-%s" % ( shortDesc, srcComponent.shortName, dstComponent.shortName ) ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 92 | ## Third Link Down |
| 93 | shortDesc = descPrefix + "-Failure3" |
| 94 | longDesc = "%s Failure: Bring down port with most traffic on %s" % ( descPrefix, device ) |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 95 | device3, port3 = main.funcs.linkDown( targets, srcComponentList, dstComponent, shortDesc, longDesc ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 96 | for src in srcNames: |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 97 | srcComponent = getattr( main, src ) |
| 98 | dbHeaders.append( "%s-%s" % ( shortDesc, srcComponent.shortName ) ) |
| 99 | dbHeaders.append( "%s-%s-to-%s" % ( shortDesc, srcComponent.shortName, dstComponent.shortName ) ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 100 | ## Forth Link Down |
| 101 | shortDesc = descPrefix + "-Failure4" |
| 102 | longDesc = "%s Failure: Bring down port with most traffic on %s" % ( descPrefix, device ) |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 103 | device4, port4 = main.funcs.linkDown( targets, srcComponentList, dstComponent, shortDesc, longDesc ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 104 | for src in srcNames: |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 105 | srcComponent = getattr( main, src ) |
| 106 | dbHeaders.append( "%s-%s" % ( shortDesc, srcComponent.shortName ) ) |
| 107 | dbHeaders.append( "%s-%s-to-%s" % ( shortDesc, srcComponent.shortName, dstComponent.shortName ) ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 108 | ## Third Link Up |
| 109 | shortDesc = descPrefix + "-Recovery3" |
Jon Hall | a7b27e6 | 2021-06-29 12:13:51 -0700 | [diff] [blame] | 110 | longDesc = "%s Recovery: Bring up %s/%s" % ( descPrefix, device, port3 ) |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 111 | main.funcs.linkUp( device3, port3, srcComponentList, dstComponent, shortDesc, longDesc ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 112 | for src in srcNames: |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 113 | srcComponent = getattr( main, src ) |
| 114 | dbHeaders.append( "%s-%s" % ( shortDesc, srcComponent.shortName ) ) |
| 115 | dbHeaders.append( "%s-%s-to-%s" % ( shortDesc, srcComponent.shortName, dstComponent.shortName ) ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 116 | ## Forth Link Up |
| 117 | shortDesc = descPrefix + "-Recovery4" |
Jon Hall | a7b27e6 | 2021-06-29 12:13:51 -0700 | [diff] [blame] | 118 | longDesc = "%s Recovery: Bring up %s/%s" % ( descPrefix, device, port4 ) |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 119 | main.funcs.linkUp( device4, port4, srcComponentList, dstComponent, shortDesc, longDesc ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 120 | for src in srcNames: |
Jon Hall | 66ce22f | 2021-06-30 14:57:40 -0700 | [diff] [blame^] | 121 | srcComponent = getattr( main, src ) |
| 122 | dbHeaders.append( "%s-%s" % ( shortDesc, srcComponent.shortName ) ) |
| 123 | dbHeaders.append( "%s-%s-to-%s" % ( shortDesc, srcComponent.shortName, dstComponent.shortName ) ) |
Jon Hall | 669bc86 | 2021-03-09 12:24:44 -0800 | [diff] [blame] | 124 | |
| 125 | main.log.warn( json.dumps( main.downtimeResults, indent=4, sort_keys=True ) ) |
| 126 | main.funcs.cleanup( main, headerOrder=dbHeaders ) |