blob: 5ba7755bde36a9d92662425cd70cfab3ca0d1a54 [file] [log] [blame]
Suchitra Vemuribaed17e2019-08-30 15:22:09 -07001// 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
15node ("${TestNodeName}") {
16 timeout (200) {
17 try {
18 stage ("Parse deployment configuration file") {
19 sh returnStdout: true, script: "rm -rf ${configBaseDir}"
20 sh returnStdout: true, script: "git clone -b ${branch} ${cordRepoUrl}/${configBaseDir}"
21 deployment_config = readYaml file: "${configBaseDir}/${configDeploymentDir}/${configFileName}.yaml"
22 }
23 stage('Download Test repos') {
24 timeout(2) {
25 sh returnStdout: true, script: """
Suchitra Vemurib9945942019-09-11 15:39:02 -070026 rm -rf helm-charts cord-tester voltha voltha-system-tests
Matteo Scandolo1294aeb2019-09-24 16:20:32 -070027 git clone -b ${branch} ${cordRepoUrl}/helm-charts # NOTE do we need helm-charts?
Suchitra Vemuribaed17e2019-08-30 15:22:09 -070028 git clone -b ${branch} ${cordRepoUrl}/cord-tester
29 git clone -b ${branch} ${cordRepoUrl}/voltha-system-tests
Matteo Scandolo1294aeb2019-09-24 16:20:32 -070030 git clone -b ${branch} ${cordRepoUrl}/voltha # NOTE do we need the voltha source code??
Suchitra Vemuribaed17e2019-08-30 15:22:09 -070031 """
32 }
33 }
34 stage('Subscriber Validation and Ping Tests') {
35 timeout(180) {
36 sh """
37 export KUBECONFIG=$WORKSPACE/${configBaseDir}/${configKubernetesDir}/${configFileName}.conf
Suchitra Vemurida6dda92019-10-15 18:30:16 -070038 cd $WORKSPACE
39 rm -rf *.log
Suchitra Vemuri017a14b2019-10-30 14:31:29 -070040 export VOLTCONFIG=/home/cord/.volt/config ; sleep 10
Matteo Scandolo71ae5362020-06-03 11:45:24 -070041 cd $WORKSPACE/voltha-system-tests
42 make vst_venv
43 source vst_venv/bin/activate
44 cd tests
Suchitra Vemuri62dbe012020-06-04 15:27:24 -070045 robot --removekeywords wuks -i sanity -i functional -e bbsim -e notready -d Log -V $WORKSPACE/${configBaseDir}/${configDeploymentDir}/${configFileName}.yaml -v POD_NAME:${configFileName} -v KUBERNETES_CONFIGS_DIR:$WORKSPACE/${configBaseDir}/${configKubernetesDir} functional/Voltha_PODTests.robot || true
46 //robot --removekeywords wuks -i PowerSwitch -i functional -e bbsim -e notready -d Log -T -V $WORKSPACE/${configBaseDir}/${configDeploymentDir}/${configFileName}.yaml -v POD_NAME:${configFileName} -v KUBERNETES_CONFIGS_DIR:$WORKSPACE/${configBaseDir}/${configKubernetesDir} functional/Voltha_FailureScenarios.robot || true
47 //robot --removekeywords wuks -i functional -e bbsim -e notready -d Log -T -V $WORKSPACE/${configBaseDir}/${configDeploymentDir}/${configFileName}.yaml -v POD_NAME:${configFileName} -v KUBERNETES_CONFIGS_DIR:$WORKSPACE/${configBaseDir}/${configKubernetesDir} functional/Voltha_ErrorScenarios.robot || true
Matteo Scandolo727c7972020-04-13 13:09:25 -070048 kubectl get pods --all-namespaces -o jsonpath="{range .items[*].status.containerStatuses[*]}{.image}{'\\t'}{.image}{'\\n'}" | sort | uniq
49 kubectl get pods --all-namespaces -o jsonpath="{range .items[*].status.containerStatuses[*]}{.image}{'\\t'}{.imageID}{'\\n'}" | sort | uniq
Suchitra Vemurida6dda92019-10-15 18:30:16 -070050 kubectl get nodes -o wide
51 kubectl get pods -n voltha -o wide
Suchitra Vemuribaed17e2019-08-30 15:22:09 -070052 """
53 }
54 }
55 stage('Publish test results') {
56 sh returnStdout: true, script: """
57 if [ -d RobotLogs ]; then rm -r RobotLogs; fi; mkdir RobotLogs;
58 mkdir RobotLogs/TestDoc || true
Suchitra Vemuri59003862019-10-01 21:59:11 -070059 cp -r $WORKSPACE/voltha-system-tests/tests/Log/* $WORKSPACE/RobotLogs || true
Kailashe7be87f2019-09-12 12:54:54 -070060 export KUBECONFIG=$WORKSPACE/${configBaseDir}/${configKubernetesDir}/${configFileName}.conf
61 ## get default pod logs
62 for pod in \$(kubectl get pods --no-headers | awk '{print \$1}');
63 do
Matteo Scandolo9988d262020-06-05 08:49:15 -070064 kubectl logs \$pod> $WORKSPACE/\$pod.log;
Kailashe7be87f2019-09-12 12:54:54 -070065 done
66 ## get voltha pod logs
67 for pod in \$(kubectl get pods --no-headers -n voltha | awk '{print \$1}');
68 do
69 if [[ \$pod == *"-api-"* ]]; then
70 kubectl logs \$pod arouter -n voltha > $WORKSPACE/\$pod.log;
71 else
72 kubectl logs \$pod -n voltha > $WORKSPACE/\$pod.log;
73 fi
74 done
Suchitra Vemuribaed17e2019-08-30 15:22:09 -070075 """
76 step([$class: 'RobotPublisher',
77 disableArchiveOutput: false,
78 logFileName: 'RobotLogs/log*.html',
79 otherFiles: '',
80 outputFileName: 'RobotLogs/output*.xml',
81 outputPath: '.',
82 passThreshold: 100,
83 reportFileName: 'RobotLogs/report*.html',
84 unstableThreshold: 0
Kailashe7be87f2019-09-12 12:54:54 -070085 ]);
86 archiveArtifacts artifacts: '*.log'
Suchitra Vemuribaed17e2019-08-30 15:22:09 -070087 }
88 currentBuild.result = 'SUCCESS'
89 } catch (err) {
90 currentBuild.result = 'FAILURE'
91 step([$class: 'Mailer', notifyEveryUnstableBuild: true, recipients: "${notificationEmail}", sendToIndividuals: false])
92 }
93 echo "RESULT: ${currentBuild.result}"
94 }
95}