blob: 31142f57300b80f5d4df8a23c5ed26b679013bae [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
18node ('master') {
19 stage ("Parse configuration file") {
20 sh returnStdout: true, script: 'rm -rf ${configRepoBaseDir}'
21 sh returnStdout: true, script: 'git clone -b ${branch} ${configRepoUrl}'
22 deployment_config = readYaml file: "${configRepoBaseDir}${configRepoFile}"
23 pod_config = readYaml file: "${configRepoBaseDir}${deployment_config.pod_config.file_name}"
24 }
25}
26
27node ("${deployment_config.dev_node.name}") {
28 stage('Prerequisites') {
29 runHeadNodeCmd("""
30 cd /opt/cord/test/cord-tester/src/test/setup
31 sudo ./prerequisites.sh --cord
32 """)
33 }
Kailash Khalasiecf30142018-01-24 15:16:45 -080034 stage('Bring up Cord-Test Container') {
35 runHeadNodeCmd("""
36 cd /opt/cord/test/cord-tester/src/test/setup
37 sudo ./cord-test.py setup -m manifest-onf-cord.json
38 """)
39 }
You Wang9d616dd2018-01-22 14:10:28 -080040 stage('Configure Fabric for E2E testing') {
41 //FIXME: this only works for PODs with 2 leaf switches
42 fabricIpPrefix = pod_config.fabric_ip.split(/\.\d+\.\d+\/24/)[0]
43 runHeadNodeCmd("sudo ip route add ${fabricIpPrefix}.2.0/24 via ${fabricIpPrefix}.1.254 || echo route already exists")
44 runHeadNodeCmd("sudo route add -net 10.7.1.0/24 gw 10.6.1.254 || echo route already exists")
45 runHeadNodeCmd("sudo route add -net 10.8.1.0/24 gw 10.6.1.254 || echo route already exists")
46 runHeadNodeCmd("ping -c 1 ${fabricIpPrefix}.1.254", "-qftn")
47 runOnosCliCmd("onos-fabric", "8101", "onos", "rocks", "route-add 0.0.0.0/0 ${fabricIpPrefix}.1.1")
48 // Verify ONOS has recognized the hosts
49 timeout(time: 5) {
50 waitUntil {
51 try {
52 num = runHeadNodeCmd("\"sshpass -p rocks ssh -q -oStrictHostKeyChecking=no -l onos -p 8101 onos-fabric hosts | grep id= | wc -l\"").trim()
53 return num.toInteger() == deployment_config.compute_nodes.size() + 1
54 } catch (exception) {
55 return false
56 }
57 }
58 }
59 // Generate network configuration
60 runHeadNodeCmd("""
61 cd /opt/cord_profile/
62 cp fabric-network-cfg.json fabric-network-cfg.json.\$(date +%Y%m%d-%H%M%S)
63 cord generate > fabric-network-cfg.json
64 """)
65 // Delete old ONOS netcfg
66 runHeadNodeCmd("http -a onos:rocks DELETE http://onos-fabric:8181/onos/v1/network/configuration/")
67 // Load new configuration
68 runHeadNodeCmd("http -a onos:rocks POST http://onos-fabric:8181/onos/v1/network/configuration/ < /opt/cord_profile/fabric-network-cfg.json")
69 // Restart ONOS apps
70 runHeadNodeCmd("""
71 http -a onos:rocks DELETE http://onos-fabric:8181/onos/v1/applications/org.onosproject.segmentrouting/active; sleep 5
72 http -a onos:rocks POST http://onos-fabric:8181/onos/v1/applications/org.onosproject.segmentrouting/active; sleep 5
73 """)
74 }
You Wang4eefdc82017-11-17 13:58:55 -080075 stage('Verify Collect Diag') {
76 timeout(10) {
77 try {
78 runHeadNodeCmd("""
79 rm -rf ~/diag-*
80 cd /opt/cord/build; make collect-diag
81 cd /opt/cord/test/cord-tester/src/test/diag/
82 rm -r Log/ || true
83 pybot -v CORD_PROFILE:${pod_config.cord_profile} -d Log -T verifyCollectDiag.robot
84 """)
85 } catch(error) { currentBuild.result = 'FAILURE' }
86 }
87 }
88 stage('Sanity Test') {
89 timeout(10) {
90 try {
91 runHeadNodeCmd("""
92 cd /opt/cord/test/cord-tester/src/test/robot/
93 rm -r Log/ || true
94 """)
95 if (deployment_config.fabric_switches != null) {
96 runHeadNodeCmd("""
97 cd /opt/cord/test/cord-tester/src/test/robot/
98 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
99 """)
100 }
101 else {
102 // Exclude fabric related tests
103 runHeadNodeCmd("""
104 cd /opt/cord/test/cord-tester/src/test/robot/
105 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
106 """)
107 }
108 } catch(error) { currentBuild.result = 'FAILURE' }
109 }
110 }
111 stage('XOS API Tests') {
112 timeout(10) {
113 try {
114 runHeadNodeCmd("""
115 cd /opt/cord/test/cord-tester/src/test/cord-api/Properties/
116 sed -i s/^SERVER_IP\\ =\\ .*/SERVER_IP\\ =\\ \\'localhost\\'/ RestApiProperties.py
117 sed -i s/^SERVER_PORT\\ =\\ .*/SERVER_PORT\\ =\\ \\'9101\\'/ RestApiProperties.py
118 sed -i s/^PASSWD\\ =\\ .*/PASSWD\\ =\\ \\'\\\$(cat /opt/credentials/xosadmin@opencord.org)\\'/ RestApiProperties.py
119 all_passed=true
120 cd /opt/cord/test/cord-tester/src/test/cord-api/
121 rm -r Log/ || true
122 pybot -d Log -T Tests/Ch_defaultImagesCheck.txt || all_passed=false
123 pybot -d Log -T -v PROFILE:${pod_config.cord_profile} Tests/Ch_DefaultServiceCheck.txt || all_passed=false
124 pybot -d Log -T Tests/Ch_SubscriberTest.txt || all_passed=false
125 pybot -d Log -T Tests/Ch_VoltTenant.txt || all_passed=false
126 pybot -d Log -T Tests/Ch_ServiceTest.txt || all_passed=false
127 pybot -d Log -T Tests/Ch_UsersTest.txt || all_passed=false
128 pybot -d Log -T Tests/Ch_DeploymentTest.txt || all_passed=false
129 pybot -d Log -T Tests/Ch_NodeTest.txt || all_passed=false
130 pybot -d Log -T Tests/Ch_SliceTest.txt || all_passed=false
131 pybot -d Log -T Tests/Ch_SanityInstance.txt || all_passed=false
132 pybot -d Log -T Tests/Ch_SanityFlavors.txt || all_passed=false
133 pybot -d Log -T Tests/Ch_SiteTest.txt || all_passed=false
134 if [ "\\\$all_passed" = true ]; then exit 0; else exit 1; fi
135 """)
136 } catch(error) { currentBuild.result = 'FAILURE' }
137 }
138 }
Kailash Khalasiecf30142018-01-24 15:16:45 -0800139 stage('Dataplane Test') {
140 timeout(10) {
141 try {
142 runHeadNodeCmd("""
143 cd /opt/cord/test/cord-tester/src/test/vsg/
144 rm -r Log/ || true
145 ssh-agent bash
146 ssh-add
147 pybot -L TRACE -d Log -T vsg_dataplane_test.robot
148 """)
149 } catch(error) { currentBuild.result = 'FAILURE' }
150 }
151 }
You Wang4eefdc82017-11-17 13:58:55 -0800152 stage('Publish') {
153 try {
154 sh """
155 if [ -d RobotLogs ]; then rm -r RobotLogs; fi; mkdir RobotLogs
156 scp -r ${deployment_config.head.user}@${deployment_config.head.ip}:/opt/cord/test/cord-tester/src/test/cord-api/Log/* ./RobotLogs || true
157 scp -r ${deployment_config.head.user}@${deployment_config.head.ip}:/opt/cord/test/cord-tester/src/test/robot/Log/* ./RobotLogs || true
158 scp -r ${deployment_config.head.user}@${deployment_config.head.ip}:/opt/cord/test/cord-tester/src/test/diag/Log/* ./RobotLogs || true
Kailash Khalasiecf30142018-01-24 15:16:45 -0800159 scp -r ${deployment_config.head.user}@${deployment_config.head.ip}:/opt/cord/test/cord-tester/src/test/vsg/Log/* ./RobotLogs || true
You Wang4eefdc82017-11-17 13:58:55 -0800160 """
161 step([$class: 'RobotPublisher',
162 disableArchiveOutput: false,
163 logFileName: 'RobotLogs/log*.html',
164 otherFiles: '',
165 outputFileName: 'RobotLogs/output*.xml',
166 outputPath: '.',
167 passThreshold: 100,
168 reportFileName: 'RobotLogs/report*.html',
169 unstableThreshold: 0])
170 } catch(error) {}
171 }
172 step([$class: 'Mailer', notifyEveryUnstableBuild: true, recipients: "${notificationEmail}", sendToIndividuals: false])
173}
174
175/**
176 * Runs a command on the head node.
177 *
178 * @param command the command to run
179 * @param sshArgs arguments for the ssh command
180 * @return the output of the command
181 */
182def runHeadNodeCmd(command, sshArgs="") {
183 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}\"")
184}
You Wang9d616dd2018-01-22 14:10:28 -0800185
186/**
187 * Runs an ONOS CLI command
188 *
189 * @param name the onos node name, reachable from the head node
190 * @param port the port used to login to ONOS CLI
191 * @param user the user name to login to ONOS CLI
192 * @param pass the password to login to ONOS CLI
193 * @param command the command to run in ONOS CLI
194 * @return the output of the command
195 */
196def runOnosCliCmd(name, port, user, pass, command) {
197 return sh(returnStdout: true, script: "sshpass -p ${deployment_config.head.pass} ssh -oStrictHostKeyChecking=no -l ${deployment_config.head.user} ${deployment_config.head.ip} \"sshpass -p ${pass} ssh -oStrictHostKeyChecking=no -l ${user} -p ${port} ${name} ${command}\"")
198}