Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 1 | #!groovy |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 2 | |
Devin Lim | 81ab48b | 2018-02-09 14:24:57 -0800 | [diff] [blame] | 3 | funcs = evaluate readTrusted( 'TestON/JenkinsFile/JenkinsCommonFuncs.groovy' ) |
Jeremy Ronquillo | 14ecc17 | 2018-03-05 09:57:17 -0800 | [diff] [blame] | 4 | test_lists = evaluate readTrusted( 'TestON/JenkinsFile/JenkinsTestONTests.groovy' ) |
| 5 | |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 6 | previous_version = "1.12" |
Devin Lim | 3fa96a9 | 2018-03-16 11:47:58 -0700 | [diff] [blame] | 7 | before_previous_version = "1.11" |
Jeremy Ronquillo | 14ecc17 | 2018-03-05 09:57:17 -0800 | [diff] [blame] | 8 | funcs.initializeTrend( "VM" ); |
| 9 | |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 10 | testcases = [ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 11 | "FUNC" : [ tests : "" , nodeName : "VM" ], |
| 12 | "HA" : [ tests : "" , nodeName : "VM" ], |
| 13 | "SR" : [ tests : "", nodeName : "VM" ], |
| 14 | "SCPF" : [ tests : "" , nodeName : "BM" ], |
| 15 | "USECASE" : [ tests : "" , nodeName : "BM" ] |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 16 | ] |
| 17 | Prefix_organizer = [ |
| 18 | "FU" : "FUNC", |
| 19 | "HA" : "HA", |
| 20 | "PL" : "USECASE", |
| 21 | "SA" : "USECASE", |
| 22 | "SC" : "SCPF", |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 23 | "SR" : "SR", |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 24 | "US" : "USECASE", |
| 25 | "VP" : "USECASE" |
| 26 | ] |
| 27 | |
Jeremy Ronquillo | cdd177d | 2018-03-09 16:55:44 -0800 | [diff] [blame] | 28 | manually_run = params.manual_run |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 29 | onos_b = "master" |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 30 | test_branch = "" |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 31 | onos_tag = params.ONOSTag |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 32 | isOldFlow = true |
Jeremy Ronquillo | 14ecc17 | 2018-03-05 09:57:17 -0800 | [diff] [blame] | 33 | |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 34 | // Set tests based on day of week |
Devin Lim | d1fb8e9 | 2018-02-28 16:29:33 -0800 | [diff] [blame] | 35 | def now = funcs.getCurrentTime() |
| 36 | print now.toString() |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 37 | today = now[ Calendar.DAY_OF_WEEK ] |
Jeremy Ronquillo | 14ecc17 | 2018-03-05 09:57:17 -0800 | [diff] [blame] | 38 | |
Jeremy Ronquillo | cdd177d | 2018-03-09 16:55:44 -0800 | [diff] [blame] | 39 | if ( manually_run ){ |
| 40 | onos_b = params.ONOSVersion |
| 41 | } else { |
| 42 | if ( today == Calendar.SATURDAY ){ |
| 43 | onos_b = previous_version |
| 44 | } else if( today == Calendar.SUNDAY ){ |
| 45 | onos_b = before_previous_version |
| 46 | } |
Jeremy Ronquillo | 14ecc17 | 2018-03-05 09:57:17 -0800 | [diff] [blame] | 47 | } |
| 48 | AllTheTests = test_lists.getAllTheTests( onos_b ) |
| 49 | |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 50 | day = "" |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 51 | SCPF_choices = "" |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 52 | USECASE_choices = "" |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 53 | FUNC_choices = "" |
| 54 | HA_choices = "" |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 55 | SR_choices = "" |
| 56 | stat_graph_generator_file = "testCategoryBuildStats.R" |
| 57 | pie_graph_generator_file = "testCategoryPiePassFail.R" |
| 58 | graph_saved_directory = "/var/jenkins/workspace/postjob-VM/" |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 59 | |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 60 | post_result = params.PostResult |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 61 | if( !manually_run ){ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 62 | slackSend( color:'#03CD9F', |
| 63 | message:":sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles:\n" |
| 64 | + "Starting tests on : " + now.toString() |
| 65 | + "\n:sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles::sparkles:" ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 66 | testDivider( today ) |
| 67 | FUNC_choices = lastCommaRemover( FUNC_choices ) |
| 68 | HA_choices = lastCommaRemover( HA_choices ) |
| 69 | SCPF_choices = lastCommaRemover( SCPF_choices ) |
| 70 | USECASE_choices = lastCommaRemover( USECASE_choices ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 71 | SR_choices = lastCommaRemover( SR_choices ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 72 | } |
| 73 | |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 74 | if ( manually_run ){ |
| 75 | organize_tests( params.Tests ) |
Jeremy Ronquillo | cdd177d | 2018-03-09 16:55:44 -0800 | [diff] [blame] | 76 | |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 77 | isOldFlow = params.isOldFlow |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 78 | println "Tests to be run manually : " |
| 79 | }else{ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 80 | testcases[ "SCPF" ][ "tests" ] = SCPF_choices |
| 81 | testcases[ "USECASE" ][ "tests" ] = USECASE_choices |
| 82 | testcases[ "FUNC" ][ "tests" ] = FUNC_choices |
| 83 | testcases[ "HA" ][ "tests" ] = HA_choices |
| 84 | testcases[ "SR" ][ "tests" ] = SR_choices |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 85 | println "Defaulting to " + day + " tests:" |
| 86 | } |
Jeremy Ronquillo | 14ecc17 | 2018-03-05 09:57:17 -0800 | [diff] [blame] | 87 | |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 88 | print_tests( testcases ) |
Jeremy Ronquillo | 14ecc17 | 2018-03-05 09:57:17 -0800 | [diff] [blame] | 89 | |
Devin Lim | 37a8379 | 2017-10-26 16:38:21 -0700 | [diff] [blame] | 90 | def runTest = [ |
| 91 | "VM" : [:], |
| 92 | "BM" : [:] |
| 93 | ] |
| 94 | for( String test in testcases.keySet() ){ |
| 95 | println test |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 96 | if ( testcases[ test ][ "tests" ] != "" ){ |
| 97 | runTest[ testcases[ test ][ "nodeName" ] ][ test ] = trigger_pipeline( onos_b, testcases[ test ][ "tests" ], testcases[ test ][ "nodeName" ], test, manually_run, onos_tag ) |
Devin Lim | 37a8379 | 2017-10-26 16:38:21 -0700 | [diff] [blame] | 98 | } |
| 99 | } |
| 100 | def finalList = [:] |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 101 | finalList[ "VM" ] = runTestSeq( runTest[ "VM" ] ) |
| 102 | finalList[ "BM" ] = runTestSeq( runTest[ "BM" ] ) |
Devin Lim | 37a8379 | 2017-10-26 16:38:21 -0700 | [diff] [blame] | 103 | parallel finalList |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 104 | //finalList[ "BM" ].call() |
Jeremy Ronquillo | 14ecc17 | 2018-03-05 09:57:17 -0800 | [diff] [blame] | 105 | |
| 106 | if ( !manually_run ){ |
Jeremy Ronquillo | f78a6ca | 2018-03-12 09:20:57 -0700 | [diff] [blame] | 107 | funcs.generateStatGraph( funcs.branchWithPrefix( onos_b ), |
| 108 | AllTheTests, |
| 109 | stat_graph_generator_file, |
| 110 | pie_graph_generator_file, |
| 111 | graph_saved_directory ) |
Jeremy Ronquillo | 14ecc17 | 2018-03-05 09:57:17 -0800 | [diff] [blame] | 112 | } |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 113 | |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 114 | def testDivider( today ){ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 115 | switch ( today ) { |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 116 | case Calendar.MONDAY: |
| 117 | monday( true ) |
| 118 | tuesday( true, false ) |
| 119 | wednesday( true, false ) |
| 120 | thursday( true, false ) |
| 121 | friday( true, false ) |
| 122 | day = "Monday" |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 123 | slackSend( color:'#FFD988', message:"Tests to be run this weekdays : \n" + printDaysForTest() ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 124 | break |
| 125 | case Calendar.TUESDAY: |
| 126 | tuesday( true, true ) |
| 127 | day = "Tuesday" |
| 128 | break |
| 129 | case Calendar.WEDNESDAY: |
| 130 | wednesday( true, true ) |
| 131 | day = "Wednesday" |
| 132 | break |
| 133 | case Calendar.THURSDAY: |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 134 | thursday( true, true ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 135 | day = "Thursday" |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 136 | isOldFlow = false |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 137 | break |
| 138 | case Calendar.FRIDAY: |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 139 | friday( true, true ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 140 | day = "Friday" |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 141 | isOldFlow = false |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 142 | break |
| 143 | case Calendar.SATURDAY: |
| 144 | saturday() |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 145 | day = "Saturday" |
| 146 | break |
| 147 | case Calendar.SUNDAY: |
| 148 | sunday() |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 149 | day = "Sunday" |
Devin Lim | 3fa96a9 | 2018-03-16 11:47:58 -0700 | [diff] [blame] | 150 | isOldFlow = false |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 151 | break |
| 152 | } |
| 153 | } |
| 154 | def printDaysForTest(){ |
| 155 | result = "" |
| 156 | for ( String test in AllTheTests.keySet() ){ |
| 157 | result += test + " : \n" |
| 158 | for( String each in AllTheTests[ test ].keySet() ){ |
| 159 | AllTheTests[ test ][ each ][ "day" ] = lastCommaRemover( AllTheTests[ test ][ each ][ "day" ] ) |
| 160 | result += " " + each + ":[" + AllTheTests[ test ][ each ][ "day" ] + "]\n" |
| 161 | } |
| 162 | result += "\n" |
| 163 | } |
| 164 | return result |
| 165 | } |
| 166 | def lastCommaRemover( str ){ |
| 167 | if ( str.size() > 0 && str[ str.size() - 1 ] == ',' ){ |
| 168 | str = str.substring( 0,str.size() - 1 ) |
| 169 | } |
| 170 | return str |
| 171 | } |
| 172 | def monday( getResult ){ |
| 173 | FUNC_choices += adder( "FUNC", "basic", true, "M", getResult ) |
Devin Lim | 3ebd5e7 | 2017-11-14 10:38:00 -0800 | [diff] [blame] | 174 | FUNC_choices += adder( "FUNC", "new_Test", true, "M", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 175 | FUNC_choices += adder( "FUNC", "extra_A", true, "M", getResult ) |
| 176 | HA_choices += adder( "HA", "basic", true, "M", getResult ) |
| 177 | HA_choices += adder( "HA", "extra_A", true, "M", getResult ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 178 | //HA_choices += adder( "HA", "new_Test", true, "M", getResult ) |
| 179 | SR_choices += adder( "SR", "basic", true, "M", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 180 | SCPF_choices += adder( "SCPF", "basic", true, "M", getResult ) |
| 181 | SCPF_choices += adder( "SCPF", "extra_B", true, "M", getResult ) |
| 182 | } |
| 183 | def tuesday( getDay, getResult ){ |
| 184 | FUNC_choices += adder( "FUNC", "basic", getDay, "T", getResult ) |
Devin Lim | 3ebd5e7 | 2017-11-14 10:38:00 -0800 | [diff] [blame] | 185 | FUNC_choices += adder( "FUNC", "new_Test", getDay, "T", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 186 | FUNC_choices += adder( "FUNC", "extra_B", getDay, "T", getResult ) |
| 187 | HA_choices += adder( "HA", "basic", getDay, "T", getResult ) |
| 188 | HA_choices += adder( "HA", "extra_B", getDay, "T", getResult ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 189 | HA_choices += adder( "HA", "new_Test", getDay, "T", getResult ) |
| 190 | SR_choices += adder( "SR", "basic", getDay, "T", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 191 | SCPF_choices += adder( "SCPF", "basic", getDay, "T", getResult ) |
| 192 | SCPF_choices += adder( "SCPF", "extra_C", getDay, "T", getResult ) |
| 193 | USECASE_choices += adder( "USECASE", "basic", getDay, "T", getResult ) |
| 194 | USECASE_choices += adder( "USECASE", "extra_A", getDay, "T", getResult ) |
| 195 | USECASE_choices += adder( "USECASE", "new_Test", getDay, "T", getResult ) |
| 196 | } |
| 197 | def wednesday( getDay, getResult ){ |
| 198 | FUNC_choices += adder( "FUNC", "basic", getDay, "W", getResult ) |
Devin Lim | 3ebd5e7 | 2017-11-14 10:38:00 -0800 | [diff] [blame] | 199 | FUNC_choices += adder( "FUNC", "new_Test", getDay, "W", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 200 | FUNC_choices += adder( "FUNC", "extra_A", getDay, "W", getResult ) |
| 201 | HA_choices += adder( "HA", "basic", getDay, "W", getResult ) |
| 202 | HA_choices += adder( "HA", "extra_A", getDay, "W", getResult ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 203 | //HA_choices += adder( "HA", "new_Test", getDay, "W", getResult ) |
| 204 | SR_choices += adder( "SR", "basic", getDay, "W", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 205 | SCPF_choices += adder( "SCPF", "basic", getDay, "W", getResult ) |
| 206 | SCPF_choices += adder( "SCPF", "extra_A", getDay, "W", getResult ) |
| 207 | SCPF_choices += adder( "SCPF", "new_Test", getDay, "W", getResult ) |
| 208 | } |
| 209 | def thursday( getDay, getResult ){ |
| 210 | FUNC_choices += adder( "FUNC", "basic", getDay, "Th", getResult ) |
Devin Lim | 3ebd5e7 | 2017-11-14 10:38:00 -0800 | [diff] [blame] | 211 | FUNC_choices += adder( "FUNC", "new_Test", getDay, "Th", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 212 | FUNC_choices += adder( "FUNC", "extra_B", getDay, "Th", getResult ) |
| 213 | HA_choices += adder( "HA", "basic", getDay, "Th", getResult ) |
| 214 | HA_choices += adder( "HA", "extra_B", getDay, "Th", getResult ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 215 | HA_choices += adder( "HA", "new_Test", getDay, "Th", getResult ) |
| 216 | SR_choices += adder( "SR", "basic", getDay, "Th", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 217 | SCPF_choices += adder( "SCPF", "basic", getDay, "Th", getResult ) |
| 218 | SCPF_choices += adder( "SCPF", "extra_B", getDay, "Th", getResult ) |
| 219 | } |
| 220 | def friday( getDay, getResult ){ |
| 221 | FUNC_choices += adder( "FUNC", "basic", getDay, "F", getResult ) |
Devin Lim | 3ebd5e7 | 2017-11-14 10:38:00 -0800 | [diff] [blame] | 222 | FUNC_choices += adder( "FUNC", "new_Test", getDay, "F", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 223 | FUNC_choices += adder( "FUNC", "extra_A", getDay, "F", getResult ) |
| 224 | HA_choices += adder( "HA", "basic", getDay, "F", getResult ) |
| 225 | HA_choices += adder( "HA", "extra_A", getDay, "F", getResult ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 226 | //HA_choices += adder( "HA", "new_Test", getDay, "F", getResult ) |
| 227 | SR_choices += adder( "SR", "basic", getDay, "F", getResult ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 228 | SCPF_choices += adder( "SCPF", "basic", getDay, "F", getResult ) |
| 229 | SCPF_choices += adder( "SCPF", "extra_A", getDay, "F", getResult ) |
| 230 | SCPF_choices += adder( "SCPF", "extra_D", getDay, "F", getResult ) |
| 231 | } |
| 232 | def saturday(){ |
| 233 | FUNC_choices += adder( "FUNC", "basic", false, "Sa", true ) |
| 234 | FUNC_choices += adder( "FUNC", "extra_A", false, "Sa", true ) |
| 235 | FUNC_choices += adder( "FUNC", "extra_B", false, "Sa", true ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 236 | FUNC_choices += adder( "FUNC", "new_Test", true, "Sa", true ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 237 | HA_choices += adder( "HA", "basic", false, "Sa", true ) |
| 238 | HA_choices += adder( "HA", "extra_A", false, "Sa", true ) |
| 239 | HA_choices += adder( "HA", "extra_B", false, "Sa", true ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 240 | HA_choices += adder( "HA", "new_Test", false, "Sa", true ) |
| 241 | SR_choices += adder( "SR", "basic", false, "Sa", true ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 242 | SCPF_choices += adder( "SCPF", "basic", false, "Sa", true ) |
| 243 | SCPF_choices += adder( "SCPF", "extra_A", false, "Sa", true ) |
| 244 | SCPF_choices += adder( "SCPF", "extra_B", false, "Sa", true ) |
| 245 | SCPF_choices += adder( "SCPF", "extra_C", false, "Sa", true ) |
| 246 | SCPF_choices += adder( "SCPF", "extra_D", false, "Sa", true ) |
| 247 | SCPF_choices += adder( "SCPF", "new_Test", false, "Sa", true ) |
| 248 | USECASE_choices += adder( "USECASE", "basic", false, "Sa", true ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 249 | } |
| 250 | def sunday(){ |
| 251 | FUNC_choices += adder( "FUNC", "basic", false, "S", true ) |
| 252 | FUNC_choices += adder( "FUNC", "extra_A", false, "S", true ) |
| 253 | FUNC_choices += adder( "FUNC", "extra_B", false, "S", true ) |
| 254 | HA_choices += adder( "HA", "basic", false, "S", true ) |
| 255 | HA_choices += adder( "HA", "extra_A", false, "S", true ) |
| 256 | HA_choices += adder( "HA", "extra_B", false, "S", true ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 257 | SR_choices += adder( "SR", "basic", false, "S", true ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 258 | SCPF_choices += adder( "SCPF", "basic", false, "S", true ) |
Devin Lim | 7220c50 | 2018-03-12 11:43:06 -0700 | [diff] [blame] | 259 | SCPF_choices += adder( "SCPF", "extra_A", false, "S", true ) |
Devin Lim | 3fa96a9 | 2018-03-16 11:47:58 -0700 | [diff] [blame] | 260 | SCPF_choices += adder( "SCPF", "extra_B", false, "S", true ) |
| 261 | SCPF_choices += adder( "SCPF", "extra_C", false, "S", true ) |
| 262 | SCPF_choices += adder( "SCPF", "extra_D", false, "S", true ) |
Devin Lim | 61657e4 | 2017-10-09 17:24:40 -0700 | [diff] [blame] | 263 | USECASE_choices += adder( "USECASE", "basic", false, "S", true ) |
| 264 | } |
| 265 | def adder( testCat, set, dayAdding, day, getResult ){ |
| 266 | result = "" |
| 267 | for( String test in AllTheTests[ testCat ].keySet() ){ |
| 268 | if( AllTheTests[ testCat ][ test ][ set ] ){ |
| 269 | if( getResult ) |
| 270 | result += test + "," |
| 271 | if( dayAdding ) |
| 272 | dayAdder( testCat, test, day ) |
| 273 | } |
| 274 | } |
| 275 | return result |
| 276 | } |
| 277 | def dayAdder( testCat, testName, dayOfWeek ){ |
| 278 | AllTheTests[ testCat ][ testName ][ "day" ] += dayOfWeek + "," |
| 279 | } |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 280 | def runTestSeq( testList ){ |
| 281 | return{ |
| 282 | for ( test in testList.keySet() ){ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 283 | testList[ test ].call() |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 284 | } |
| 285 | } |
| 286 | } |
| 287 | |
| 288 | def print_tests( tests ){ |
| 289 | for( String test in tests.keySet() ){ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 290 | if( tests[ test ][ "tests" ] != "" ){ |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 291 | println test + ":" |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 292 | println tests[ test ][ "tests" ] |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 293 | } |
| 294 | } |
| 295 | } |
| 296 | def organize_tests( tests ){ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 297 | testList = tests.tokenize( "\n;, " ) |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 298 | for( String test in testList ) |
| 299 | testcases [ Prefix_organizer[ ( test == "FUNCbgpls" || test == "FUNCvirNetNB" ? "US" : ( test[ 0 ] + test[ 1 ] ) ) ] ][ "tests" ] += test + "," |
| 300 | } |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 301 | def borrow_mn( jobOn ){ |
| 302 | result = "" |
| 303 | if( jobOn == "SR" ){ |
| 304 | result = "~/cell_borrow.sh" |
| 305 | } |
| 306 | return result |
| 307 | } |
| 308 | def trigger( branch, tests, nodeName, jobOn, manuallyRun, onosTag ){ |
| 309 | println jobOn + "-pipeline-" + manuallyRun ? "manually" : branch |
| 310 | wiki = branch |
Jeremy Ronquillo | f78a6ca | 2018-03-12 09:20:57 -0700 | [diff] [blame] | 311 | branch = funcs.branchWithPrefix( branch ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 312 | test_branch = "master" |
| 313 | node( "TestStation-" + nodeName + "s" ){ |
| 314 | envSetup( branch, test_branch, onosTag, jobOn, manuallyRun ) |
| 315 | |
| 316 | exportEnvProperty( branch, test_branch, wiki, tests, post_result, manuallyRun, onosTag, isOldFlow ) |
| 317 | } |
| 318 | |
| 319 | jobToRun = jobOn + "-pipeline-" + ( manuallyRun ? "manually" : wiki ) |
| 320 | build job: jobToRun, propagate: false |
| 321 | } |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 322 | def trigger_pipeline( branch, tests, nodeName, jobOn, manuallyRun, onosTag ){ |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 323 | // nodeName : "BM" or "VM" |
| 324 | // jobOn : "SCPF" or "USECASE" or "FUNC" or "HA" |
| 325 | return{ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 326 | if( jobOn == "SR" ){ |
Devin Lim | f5bf9b5 | 2018-02-28 18:16:21 -0800 | [diff] [blame] | 327 | trigger( "1.11", tests, nodeName, jobOn, manuallyRun, onosTag ) |
| 328 | trigger( "1.12", tests, nodeName, jobOn, manuallyRun, onosTag ) |
| 329 | trigger( "master", tests, nodeName, jobOn, manuallyRun, onosTag ) |
Devin Lim | d1fb8e9 | 2018-02-28 16:29:33 -0800 | [diff] [blame] | 330 | // returnCell( nodeName ) |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 331 | }else{ |
| 332 | trigger( branch, tests, nodeName, jobOn, manuallyRun, onosTag ) |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 333 | } |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 334 | } |
| 335 | } |
| 336 | |
| 337 | // export Environment properties. |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 338 | def exportEnvProperty( onos_branch, test_branch, wiki, tests, postResult, manually_run, onosTag, isOldFlow ){ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 339 | stage( "export Property" ){ |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 340 | sh ''' |
| 341 | echo "ONOSBranch=''' + onos_branch +'''" > /var/jenkins/TestONOS.property |
| 342 | echo "TestONBranch=''' + test_branch +'''" >> /var/jenkins/TestONOS.property |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 343 | echo "ONOSTag='''+ onosTag +'''" >> /var/jenkins/TestONOS.property |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 344 | echo "WikiPrefix=''' + wiki +'''" >> /var/jenkins/TestONOS.property |
| 345 | echo "ONOSJVMHeap='''+ env.ONOSJVMHeap +'''" >> /var/jenkins/TestONOS.property |
| 346 | echo "Tests=''' + tests +'''" >> /var/jenkins/TestONOS.property |
| 347 | echo "postResult=''' + postResult +'''" >> /var/jenkins/TestONOS.property |
| 348 | echo "manualRun=''' + manually_run +'''" >> /var/jenkins/TestONOS.property |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 349 | echo "isOldFlow=''' + isOldFlow +'''" >> /var/jenkins/TestONOS.property |
| 350 | |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 351 | ''' |
| 352 | } |
| 353 | } |
| 354 | // Initialize the environment Setup for the onos and OnosSystemTest |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 355 | def envSetup( onos_branch, test_branch, onos_tag, jobOn, manuallyRun ){ |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 356 | stage( "envSetup" ) { |
Devin Lim | f5bf9b5 | 2018-02-28 18:16:21 -0800 | [diff] [blame] | 357 | // after env: ''' + borrow_mn( jobOn ) + ''' |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 358 | sh '''#!/bin/bash -l |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 359 | set +e |
| 360 | . ~/.bashrc |
| 361 | env |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 362 | ''' + preSetup( onos_branch, test_branch, onos_tag, manuallyRun ) + ''' |
Devin Lim | cbba085 | 2017-11-13 10:31:32 -0800 | [diff] [blame] | 363 | ''' + oldFlowCheck( jobOn, onos_branch ) + ''' |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 364 | ''' + postSetup( onos_branch, test_branch, onos_tag, manuallyRun ) |
| 365 | } |
| 366 | } |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 367 | def tagCheck( onos_tag, onos_branch ){ |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 368 | result = "git checkout " |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 369 | if ( onos_tag == "" ) |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 370 | result += onos_branch //create new local branch |
| 371 | else |
| 372 | result += onos_tag //checkout the tag |
| 373 | return result |
| 374 | } |
| 375 | def preSetup( onos_branch, test_branch, onos_tag, isManual ){ |
| 376 | result = "" |
| 377 | if( !isManual ){ |
| 378 | result = '''echo -e "\n##### Set TestON Branch #####" |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 379 | echo "TestON Branch is set on: ''' + test_branch + '''" |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 380 | |
| 381 | cd ~/OnosSystemTest/ |
| 382 | git checkout HEAD~1 # Make sure you aren't pn a branch |
| 383 | git branch | grep -v "detached from" | xargs git branch -d # delete all local branches merged with remote |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 384 | git branch -D ''' + test_branch + ''' # just incase there are local changes. This will normally result in a branch not found error |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 385 | git clean -df # clean any local files |
| 386 | git fetch --all # update all caches from remotes |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 387 | git reset --hard origin/''' + test_branch +''' # force local index to match remote branch |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 388 | git clean -df # clean any local files |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 389 | git checkout ''' + test_branch + ''' #create new local branch |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 390 | git branch |
| 391 | git log -1 --decorate |
| 392 | |
| 393 | |
| 394 | echo -e "\n##### Set ONOS Branch #####" |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 395 | echo "ONOS Branch is set on: ''' + onos_branch + '''" |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 396 | |
| 397 | echo -e "\n #### check karaf version ######" |
| 398 | env |grep karaf |
| 399 | |
| 400 | cd ~/onos |
| 401 | rm -rf buck-out/* |
| 402 | ~/onos/tools/build/onos-buck clean |
| 403 | git checkout HEAD~1 # Make sure you aren't pn a branch |
| 404 | git branch | grep -v "detached from" | xargs git branch -d # delete all local branches merged with remote |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 405 | git branch -D ''' + onos_branch + ''' # just incase there are local changes. This will normally result in a branch not found error |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 406 | git clean -df # clean any local files |
| 407 | git fetch --all # update all caches from remotes |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 408 | git reset --hard origin/''' + onos_branch + ''' # force local index to match remote branch |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 409 | git clean -df # clean any local files |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 410 | ''' + tagCheck( onos_tag, onos_branch ) + ''' |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 411 | git branch |
| 412 | git log -1 --decorate |
| 413 | |
| 414 | |
| 415 | echo -e "\n##### set jvm heap size to 8G #####" |
| 416 | echo ${ONOSJVMHeap} |
| 417 | |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 418 | inserted_line="export JAVA_OPTS=\"\${ONOSJVMHeap}\"" |
| 419 | sed -i "s/bash/bash\\n$inserted_line/" ~/onos/tools/package/bin/onos-service |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 420 | |
| 421 | echo "##### Check onos-service setting..... #####" |
| 422 | cat ~/onos/tools/package/bin/onos-service |
| 423 | |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 424 | export JAVA_HOME=/usr/lib/jvm/java-8-oracle''' |
| 425 | } |
| 426 | return result |
| 427 | } |
Devin Lim | cbba085 | 2017-11-13 10:31:32 -0800 | [diff] [blame] | 428 | def oldFlowCheck( jobOn, onos_branch ){ |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 429 | result = "" |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 430 | if( jobOn == "SCPF" && ( onos_branch== "master" || onos_branch=="onos-1.12" ) ) |
| 431 | result = '''sed -i -e 's/@Component(immediate = true)/@Component(enabled = false)/g' ~/onos/core/store/dist/src/main/java/org/onosproject/store/flow/impl/''' + ( isOldFlow ? "DistributedFlowRuleStore" : "ECFlowRuleStore" ) + '''.java |
| 432 | sed -i -e 's/@Component(enabled = false)/@Component(immediate = true)/g' ~/onos/core/store/dist/src/main/java/org/onosproject/store/flow/impl/''' + ( isOldFlow ? "ECFlowRuleStore" : "DistributedFlowRuleStore" ) + ".java" |
Devin Lim | 0e96716 | 2017-11-03 15:59:53 -0700 | [diff] [blame] | 433 | return result |
| 434 | } |
| 435 | def postSetup( onos_branch, test_branch, onos_tag, isManual ){ |
| 436 | result = "" |
| 437 | if( !isManual ){ |
| 438 | result = '''echo -e "\n##### build ONOS skip unit tests ######" |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 439 | #mvn clean install -DskipTests |
| 440 | # Force buck update |
| 441 | rm -f ~/onos/bin/buck |
| 442 | ~/onos/tools/build/onos-buck build onos |
| 443 | |
Devin Lim | a0e52eb | 2017-09-13 18:35:12 -0700 | [diff] [blame] | 444 | sleep 30 |
| 445 | echo -e "\n##### Stop all running instances of Karaf #####" |
| 446 | kill $(ps -efw | grep karaf | grep -v grep | awk '{print $2}') |
| 447 | sleep 30 |
| 448 | |
Devin Lim | 90803a8 | 2017-08-29 13:41:44 -0700 | [diff] [blame] | 449 | git branch''' |
| 450 | } |
Devin Lim | 37a8379 | 2017-10-26 16:38:21 -0700 | [diff] [blame] | 451 | return result |
Devin Lim | 6164376 | 2017-12-07 15:55:38 -0800 | [diff] [blame] | 452 | } |
| 453 | def returnCell( nodeName ){ |
| 454 | node( "TestStation-" + nodeName + "s" ){ |
| 455 | sh '''#!/bin/bash -l |
| 456 | set +e |
| 457 | . ~/.bashrc |
| 458 | env |
| 459 | ~/./return_cell.sh |
| 460 | ''' |
| 461 | } |
Devin Lim | 3fa96a9 | 2018-03-16 11:47:58 -0700 | [diff] [blame] | 462 | } |