blob: 050621a40b791a18d18a1495a6fefd6e16bef3c6 [file] [log] [blame]
You Wang4eefdc82017-11-17 13:58:55 -08001// Copyright 2017-present Open Networking Foundation
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15pod_config = null
16deployment_config = null
17
Kailash Khalasia0d49002018-04-18 15:00:47 -070018node ("${devNodeName}") {
19
20 stage ("Parse deployment configuration file") {
You Wang4eefdc82017-11-17 13:58:55 -080021 sh returnStdout: true, script: 'rm -rf ${configRepoBaseDir}'
22 sh returnStdout: true, script: 'git clone -b ${branch} ${configRepoUrl}'
23 deployment_config = readYaml file: "${configRepoBaseDir}${configRepoFile}"
24 pod_config = readYaml file: "${configRepoBaseDir}${deployment_config.pod_config.file_name}"
25 }
You Wang4eefdc82017-11-17 13:58:55 -080026
You Wang4eefdc82017-11-17 13:58:55 -080027 stage('Prerequisites') {
28 runHeadNodeCmd("""
29 cd /opt/cord/test/cord-tester/src/test/setup
30 sudo ./prerequisites.sh --cord
31 """)
32 }
33 stage('Verify Collect Diag') {
34 timeout(10) {
35 try {
36 runHeadNodeCmd("""
Kailash Khalasi68f9f632018-04-11 08:09:19 -070037 export SERVER_IP=localhost
38 export SERVER_PORT=9101
39 export XOS_USER=xosadmin@opencord.org
Kailash Khalasia0d49002018-04-18 15:00:47 -070040 export XOS_PASSWD=\\\$(cat /opt/credentials/xosadmin@opencord.org)
You Wang4eefdc82017-11-17 13:58:55 -080041 rm -rf ~/diag-*
42 cd /opt/cord/build; make collect-diag
43 cd /opt/cord/test/cord-tester/src/test/diag/
44 rm -r Log/ || true
Kailash Khalasi3d1c4d72018-01-30 12:10:28 -080045 rm -r TestDoc/ || true
46 mkdir TestDoc || true
You Wang4eefdc82017-11-17 13:58:55 -080047 pybot -v CORD_PROFILE:${pod_config.cord_profile} -d Log -T verifyCollectDiag.robot
Kailash Khalasi3d1c4d72018-01-30 12:10:28 -080048 python -m robot.testdoc verifyCollectDiag.robot TestDoc/verifyCollectDiag.html
You Wang4eefdc82017-11-17 13:58:55 -080049 """)
50 } catch(error) { currentBuild.result = 'FAILURE' }
51 }
52 }
53 stage('Sanity Test') {
54 timeout(10) {
55 try {
56 runHeadNodeCmd("""
Kailash Khalasi68f9f632018-04-11 08:09:19 -070057 export SERVER_IP=localhost
58 export SERVER_PORT=9101
59 export XOS_USER=xosadmin@opencord.org
Kailash Khalasia0d49002018-04-18 15:00:47 -070060 export XOS_PASSWD=\\\$(cat /opt/credentials/xosadmin@opencord.org)
You Wang4eefdc82017-11-17 13:58:55 -080061 cd /opt/cord/test/cord-tester/src/test/robot/
62 rm -r Log/ || true
Kailash Khalasi3d1c4d72018-01-30 12:10:28 -080063 rm -r TestDoc/ || true
64 mkdir TestDoc || true
You Wang4eefdc82017-11-17 13:58:55 -080065 """)
66 if (deployment_config.fabric_switches != null) {
67 runHeadNodeCmd("""
Kailash Khalasi68f9f632018-04-11 08:09:19 -070068 export SERVER_IP=localhost
69 export SERVER_PORT=9101
70 export XOS_USER=xosadmin@opencord.org
Kailash Khalasia0d49002018-04-18 15:00:47 -070071 export XOS_PASSWD=\\\$(cat /opt/credentials/xosadmin@opencord.org)
You Wang4eefdc82017-11-17 13:58:55 -080072 cd /opt/cord/test/cord-tester/src/test/robot/
73 pybot --exclude notready -v FABRIC:on -v PUBLIC_IFACE:${pod_config.external_iface} -v CORD_PROFILE:${pod_config.cord_profile} -d Log -T SanityPhyPOD.robot
Kailash Khalasi3d1c4d72018-01-30 12:10:28 -080074 python -m robot.testdoc SanityPhyPOD.robot TestDoc/SanityPhyPOD.html
You Wang4eefdc82017-11-17 13:58:55 -080075 """)
76 }
77 else {
78 // Exclude fabric related tests
79 runHeadNodeCmd("""
Kailash Khalasi68f9f632018-04-11 08:09:19 -070080 export SERVER_IP=localhost
81 export SERVER_PORT=9101
82 export XOS_USER=xosadmin@opencord.org
Kailash Khalasia0d49002018-04-18 15:00:47 -070083 export XOS_PASSWD=\\\$(cat /opt/credentials/xosadmin@opencord.org)
You Wang4eefdc82017-11-17 13:58:55 -080084 cd /opt/cord/test/cord-tester/src/test/robot/
85 pybot --exclude notready --exclude fabric -v FABRIC:off -v PUBLIC_IFACE:${pod_config.external_iface} -v CORD_PROFILE:${pod_config.cord_profile} -d Log -T SanityPhyPOD.robot
Kailash Khalasi3d1c4d72018-01-30 12:10:28 -080086 python -m robot.testdoc SanityPhyPOD.robot TestDoc/SanityPhyPOD.html
You Wang4eefdc82017-11-17 13:58:55 -080087 """)
88 }
89 } catch(error) { currentBuild.result = 'FAILURE' }
90 }
91 }
92 stage('XOS API Tests') {
93 timeout(10) {
94 try {
95 runHeadNodeCmd("""
Kailash Khalasi68f9f632018-04-11 08:09:19 -070096 export SERVER_IP=localhost
97 export SERVER_PORT=9101
98 export XOS_USER=xosadmin@opencord.org
Kailash Khalasia0d49002018-04-18 15:00:47 -070099 export XOS_PASSWD=\\\$(cat /opt/credentials/xosadmin@opencord.org)
You Wang4eefdc82017-11-17 13:58:55 -0800100 """)
101 } catch(error) { currentBuild.result = 'FAILURE' }
102 }
103 }
104 stage('Publish') {
105 try {
106 sh """
107 if [ -d RobotLogs ]; then rm -r RobotLogs; fi; mkdir RobotLogs
Kailash Khalasi9b311092018-02-08 11:26:37 -0800108 mkdir RobotLogs/TestDoc || true
You Wang4eefdc82017-11-17 13:58:55 -0800109 scp -r ${deployment_config.head.user}@${deployment_config.head.ip}:/opt/cord/test/cord-tester/src/test/cord-api/Log/* ./RobotLogs || true
110 scp -r ${deployment_config.head.user}@${deployment_config.head.ip}:/opt/cord/test/cord-tester/src/test/robot/Log/* ./RobotLogs || true
111 scp -r ${deployment_config.head.user}@${deployment_config.head.ip}:/opt/cord/test/cord-tester/src/test/diag/Log/* ./RobotLogs || true
Kailash Khalasi9b311092018-02-08 11:26:37 -0800112 scp -r ${deployment_config.head.user}@${deployment_config.head.ip}:/opt/cord/test/cord-tester/src/test/robot/TestDoc/* ./RobotLogs/TestDoc || true
113 scp -r ${deployment_config.head.user}@${deployment_config.head.ip}:/opt/cord/test/cord-tester/src/test/diag/TestDoc/* ./RobotLogs/TestDoc || true
Kailash Khalasi3d1c4d72018-01-30 12:10:28 -0800114
You Wang4eefdc82017-11-17 13:58:55 -0800115 """
116 step([$class: 'RobotPublisher',
117 disableArchiveOutput: false,
118 logFileName: 'RobotLogs/log*.html',
Kailash Khalasi9b311092018-02-08 11:26:37 -0800119 otherFiles: 'RobotLogs/TestDoc/*.html',
You Wang4eefdc82017-11-17 13:58:55 -0800120 outputFileName: 'RobotLogs/output*.xml',
121 outputPath: '.',
122 passThreshold: 100,
123 reportFileName: 'RobotLogs/report*.html',
124 unstableThreshold: 0])
125 } catch(error) {}
126 }
127 step([$class: 'Mailer', notifyEveryUnstableBuild: true, recipients: "${notificationEmail}", sendToIndividuals: false])
128}
129
130/**
131 * Runs a command on the head node.
132 *
133 * @param command the command to run
134 * @param sshArgs arguments for the ssh command
135 * @return the output of the command
136 */
137def runHeadNodeCmd(command, sshArgs="") {
138 return sh(returnStdout: true, script: "sshpass -p ${deployment_config.head.pass} ssh ${sshArgs} -oStrictHostKeyChecking=no -l ${deployment_config.head.user} ${deployment_config.head.ip} \"${command}\"")
139}