blob: 51c613ecf86a8fca4f95f658203fc8c5e4771efb [file] [log] [blame]
Devin Lim90803a82017-08-29 13:41:44 -07001#!groovy
2// This is a Jenkinsfile for a scripted pipeline for the FUNC tests
3def prop = null
4node("TestStation-VMs"){
5 prop = readProperties(file:'/var/jenkins/TestONOS.property')
6}
7// TODO: Exception handling around steps
8FUNC = [
9"FUNCipv6Intent" : [wiki_link:prop["WikiPrefix"]+"-"+"FUNCipv6Intent", wiki_file:"FUNCipv6IntentWiki.txt", ],
10"FUNCoptical" : [wiki_link:prop["WikiPrefix"]+"-"+"FUNCoptical", wiki_file:"FUNCopticalWiki.txt"],
11"FUNCflow" : [wiki_link:prop["WikiPrefix"]+"-"+"FUNCflow", wiki_file:"FUNCflowWiki.txt"],
12"FUNCnetCfg": [wiki_link:prop["WikiPrefix"]+"-"+"FUNCnetCfg", wiki_file:"FUNCnetCfgWiki.txt"],
13"FUNCovsdbtest" : [wiki_link:prop["WikiPrefix"]+"-"+"FUNCovsdbtestWiki", wiki_file:"FUNCovsdbtestWiki.txt"],
14"FUNCnetconf" : [wiki_link:prop["WikiPrefix"]+"-"+"FUNCnetconf", wiki_file:"FUNCnetconfWiki.txt"],
15"FUNCgroup" : [wiki_link:prop["WikiPrefix"]+"-"+"FUNCgroup", wiki_file:"FUNCgroupWiki.txt"],
16"FUNCintent" : [wiki_link:prop["WikiPrefix"]+"-"+"FUNCintent", wiki_file:"FUNCintentWiki.txt"],
17"FUNCintentRest" : [wiki_link:prop["WikiPrefix"]+"-"+"FUNCintentRest", wiki_file:"FUNCintentRestWiki.txt"]
18]
19table_name = "executed_test_tests"
20result_name = "executed_test_results"
21graph_generator_file = "~/OnosSystemTest/TestON/JenkinsFile/testCaseGraphGenerator.R"
22graph_saved_directory = "/var/jenkins/workspace/Pipeline_postjob_VM/"
23echo("Testcases:")
24def testsToRun = null
25testsToRun = prop["Tests"].tokenize("\n;, ")
26
27for ( String test : testsToRun ) {
28 println test
29}
30def tests = [:]
31for( String test : FUNC.keySet() ){
32 toBeRun = testsToRun.contains( test )
33 def stepName = ( toBeRun ? "" : "Not " ) + "Running $test"
34 tests[stepName] = FUNCTest(test, toBeRun, prop)
35}
36
37// run the tests
38for ( test in tests.keySet() ){
39 tests[test].call()
40}
41
42// The testName should be the key from the FUNC
43def FUNCTest( testName, toBeRun, prop ) {
44 return {
45 catchError{
46 stage(testName) {
47 if ( toBeRun ){
48 workSpace = "/var/jenkins/workspace/"+testName
49 def fileContents = ""
50 node("TestStation-VMs"){
51 withEnv(['ONOSBranch='+prop["ONOSBranch"],
52 'ONOSJVMHeap='+prop["ONOSJVMHeap"],
53 'TestONBranch='+prop["TestONBranch"],
54 'ONOSTag='+prop["ONOSTag"],
55 'WikiPrefix='+prop["WikiPrefix"],
56 'WORKSPACE='+workSpace]){
57 sh '''#!/bin/bash -l
58 set -i # interactive
59 shopt -s expand_aliases # expand alias in non-interactive mode
60 export PYTHONUNBUFFERED=1
61
62 ifconfig
63
64 echo "ONOS Branch is: $ONOSBranch"
65 echo "TestON Branch is: $TestONBranch"
66 echo "Test date: "
67 date
68
69 cd ~
70 export PATH=$PATH:onos/tools/test/bin
71
72 timeout 240 stc shutdown | head -100
73 timeout 240 stc teardown | head -100
74 timeout 240 stc shutdown | head -100
75
76 cd ~/OnosSystemTest/TestON/bin
77 git log |head
78 ./cleanup.sh
79 ''' + "./cli.py run " + testName + '''
80 # cleanup config changes
81 cd ~/onos/tools/package/config
82 git clean -df'''
83
84 // For the Wiki page
85 sh '''#!/bin/bash -i
86
87 echo "ONOS Branch is: ${ONOSBranch}"
88 echo "TestON Branch is: ${TestONBranch}"
89
90 echo "Job name is: "''' + testName + '''
91 echo "Workspace is: ${WORKSPACE}/"
92
93 echo "Wiki page to post is: ${WikiPrefix}-"
94
95 # remove any leftover files from previous tests
96 sudo rm ${WORKSPACE}/*Wiki.txt
97 sudo rm ${WORKSPACE}/*Summary.txt
98 sudo rm ${WORKSPACE}/*Result.txt
99 sudo rm ${WORKSPACE}/*.csv
100
101 #copy files to workspace
102 cd `ls -t ~/OnosSystemTest/TestON/logs/*/ | head -1 | sed 's/://'`
103 sudo cp *.txt ${WORKSPACE}/
104 sudo cp *.csv ${WORKSPACE}/
105 cd ${WORKSPACE}/
106 for i in *.csv
107 do mv "$i" "$WikiPrefix"-"$i"
108 done
109 ls -al
110 cd '''
111 if( prop["manualRun"] == "false" ){
112 // Post Results
113 withCredentials([
114 string(credentialsId: 'db_pass', variable: 'pass'),
115 string(credentialsId: 'db_user', variable: 'user'),
116 string(credentialsId: 'db_host', variable: 'host'),
117 string(credentialsId: 'db_port', variable: 'port')]) {
118 def database_command = pass + "|psql --host=" + host + " --port=" + port + " --username=" + user + " --password --dbname onostest -c \"INSERT INTO " + table_name + " VALUES('\$DATE','" + result_name + "','" + testName + "',\$BUILD_NUMBER, '\$ONOSBranch', \$line);\""
119
120 sh '''#!/bin/bash
121 set +e
122 export DATE=\$(date +%F_%T)
123 cd ~
124 pwd
125 sed 1d ''' + workSpace + "/" + prop["WikiPrefix"] + "-" + testName + '''.csv | while read line
126 do
127 echo \$line
128 echo ''' + database_command + '''
129
130 done
131 Rscript ''' + graph_generator_file + " " + host + " " + port + " " + user + " " + pass + " " + testName + " " + prop["ONOSBranch"] + " 20 " + graph_saved_directory
132
133 }
134 }
135 // Fetch Logs
136 sh '''#!/bin/bash
137
138 cd ~/OnosSystemTest/TestON/logs
139 echo "Job Name is: " + ''' + testName + '''
140 TestONlogDir=$(ls -t | grep ${TEST_NAME}_ |head -1)
141 echo "########################################################################################"
142 echo "##### copying ONOS logs from all nodes to TestON/logs directory: ${TestONlogDir}"
143 echo "########################################################################################"
144 cd $TestONlogDir
145 if [ $? -eq 1 ]
146 then
147 echo "Job name does not match any test suite name to move log!"
148 else
149 pwd
150 for i in $OC{1..7}; do onos-fetch-logs $i || echo log does not exist; done
151 fi
152 cd'''
153 fileContents = readFile workSpace+"/"+FUNC[testName]['wiki_file']
154 }
155 }
156
157 if( prop["manualRun"] == "false" ){
158 def post = build job: "Pipeline_postjob_VM", propagate: false,
159 parameters: [
160 string(name: 'Wiki_Contents', value: fileContents),
161 string(name: 'Wiki_Link', value: FUNC[testName]['wiki_link'])
162 ]
163 }
164 node("TestStation-VMs"){
165 sh '''#!/bin/bash
166
167 if [ -e ''' + workSpace + "/" + testName + "Result.txt ] && grep -q \"1\" " + workSpace + "/" + testName + "Result.txt" + '''
168 then
169 echo ''' + testName + " : All passed." + '''
170 else
171 echo ''' + testName + " : not all passed." + '''
172 DoingThisToSetTheResultFalse
173 fi'''
174 }
175 }
176 }
177 }
178 }
179}