blob: 2fdcc6e9dbecbf1854b397f207cb4eb915dac92e [file] [log] [blame]
Kailash Khalasic1a90f12018-09-13 13:13:22 -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}") {
You Wange3214b92018-10-11 10:59:00 -070016 timeout (200) {
Kailash Khalasic1a90f12018-09-13 13:13:22 -070017 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}"
You Wang59ded6c2018-10-05 17:43:44 -070021 deployment_config = readYaml file: "${configBaseDir}/${configDeploymentDir}/${configFileName}.yaml"
Kailash Khalasic1a90f12018-09-13 13:13:22 -070022 }
23 stage('Download Cord-Tester Repo') {
24 timeout(2) {
25 sh returnStdout: true, script: """
You Wang59ded6c2018-10-05 17:43:44 -070026 rm -rf helm-charts cord-tester
27 git clone -b ${branch} ${cordRepoUrl}/helm-charts
Kailash Khalasic1a90f12018-09-13 13:13:22 -070028 git clone -b ${branch} ${cordRepoUrl}/cord-tester
29 """
30 }
31 }
32 stage('Test Configurations') {
33 timeout(10) {
34 sh """
35 export KUBECONFIG=$WORKSPACE/${configBaseDir}/${configKubernetesDir}/${configFileName}.conf
36 cd $WORKSPACE/cord-tester/src/test/cord-api/Properties/
37 sed -i \"s/^\\(SERVER_IP = \\).*/\\1\'${deployment_config.nodes[0].ip}\'/\" RestApiProperties.py
38 sed -i \"s/^\\(SERVER_PORT = \\).*/\\1\'30006\'/\" RestApiProperties.py
39 sed -i \"s/^\\(XOS_USER = \\).*/\\1\'admin@opencord.org\'/\" RestApiProperties.py
40 sed -i \"s/^\\(XOS_PASSWD = \\).*/\\1\'letmein\'/\" RestApiProperties.py
41 cd $WORKSPACE/cord-tester/src/test/cord-api/Tests/
42 rm -rf Log/ || true
43 """
44 }
45 }
46 stage('Subscriber Validation and Ping Tests') {
You Wange3214b92018-10-11 10:59:00 -070047 timeout(180) {
Kailash Khalasic1a90f12018-09-13 13:13:22 -070048 sh """
49 export KUBECONFIG=$WORKSPACE/${configBaseDir}/${configKubernetesDir}/${configFileName}.conf
50 cd $WORKSPACE/cord-tester/src/test/cord-api/Tests/
You Wang59ded6c2018-10-05 17:43:44 -070051 pybot -d Log -T -l log-ATT_Test001 -V $WORKSPACE/${configBaseDir}/${configDeploymentDir}/${configFileName}.yaml -v POD_NAME:${configFileName} -v KUBERNETES_CONFIGS_DIR:$WORKSPACE/${configBaseDir}/${configKubernetesDir} -v HELM_CHARTS_DIR:$WORKSPACE/helm-charts WorkflowValidations/ATT_Test001.robot || true
Kailash Khalasic1a90f12018-09-13 13:13:22 -070052 """
53 }
54 }
Kailash Khalasic233b222018-10-12 12:26:26 -070055 stage ('Display Kafka Events') {
56 timeout(5) {
57 sh """
58 CORD_KAFKA_IP=\$(kubectl exec cord-kafka-0 -- ip a | grep -oE "([0-9]{1,3}\\.){3}[0-9]{1,3}\\b" | grep 192)
59 kafkacat -e -C -b \$CORD_KAFKA_IP -t onu.events -f 'Topic %t [%p] at offset %o: key %k: %s\n >0'
60 kafkacat -e -C -b \$CORD_KAFKA_IP -t authentication.events -f 'Topic %t [%p] at offset %o: key %k: %s\n >0'
61 kafkacat -e -C -b \$CORD_KAFKA_IP -t dhcp.events -f 'Topic %t [%p] at offset %o: key %k: %s\n >0'
62 """
63 }
64 }
Kailash Khalasic1a90f12018-09-13 13:13:22 -070065 stage('Publish test results') {
66 sh returnStdout: true, script: """
67 if [ -d RobotLogs ]; then rm -r RobotLogs; fi; mkdir RobotLogs;
68 mkdir RobotLogs/TestDoc || true
69 cp -r $WORKSPACE/cord-tester/src/test/robot/Log/* $WORKSPACE/RobotLogs || true
Kailash Khalasic233b222018-10-12 12:26:26 -070070 for pod in \$(kubectl get pods --no-headers | awk '{print \$1}');
71 do
72 kubectl logs \$pod > $WORKSPACE/\$pod.log;
73 done
74 for pod in \$(kubectl get pods -n voltha --no-headers | awk '{print \$1}');
75 do
76 kubectl logs \$pod > $WORKSPACE/\$pod.log;
77 done
Kailash Khalasic1a90f12018-09-13 13:13:22 -070078 cp -r $WORKSPACE/cord-tester/src/test/cord-api/Tests/Log/* $WORKSPACE/RobotLogs || true
Kailash Khalasic233b222018-10-12 12:26:26 -070079 sudo chown cord:cord $WORKSPACE/*log
Kailash Khalasic1a90f12018-09-13 13:13:22 -070080 """
Kailash Khalasic233b222018-10-12 12:26:26 -070081 archiveArtifacts artifacts: '*log'
Kailash Khalasic1a90f12018-09-13 13:13:22 -070082 step([$class: 'RobotPublisher',
83 disableArchiveOutput: false,
84 logFileName: 'RobotLogs/log*.html',
85 otherFiles: '',
86 outputFileName: 'RobotLogs/output*.xml',
87 outputPath: '.',
88 passThreshold: 100,
89 reportFileName: 'RobotLogs/report*.html',
90 unstableThreshold: 0
91 ])
92 }
93 currentBuild.result = 'SUCCESS'
94 } catch (err) {
95 currentBuild.result = 'FAILURE'
96 step([$class: 'Mailer', notifyEveryUnstableBuild: true, recipients: "${notificationEmail}", sendToIndividuals: false])
97 }
98 echo "RESULT: ${currentBuild.result}"
99 }
100}