blob: ba36b66c701bd53808c8637abaf2fe08a5005a47 [file] [log] [blame]
Kailashaad71012019-08-27 10:36:53 -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
15// voltha-2.x e2e tests
16// uses kind-voltha to deploy voltha-2.X
17// uses bbsim to simulate OLT/ONUs
18
19pipeline {
20
21 /* no label, executor is determined by JJB */
22 agent {
23 label "${params.executorNode}"
24 }
25 options {
Kailash2365ea82019-09-10 11:09:58 -070026 timeout(time: 120, unit: 'MINUTES')
Kailashaad71012019-08-27 10:36:53 -070027 }
28
29 stages {
30
31 stage('Repo') {
32 steps {
33 checkout(changelog: false, \
34 poll: false,
35 scm: [$class: 'RepoScm', \
36 manifestRepositoryUrl: "${params.manifestUrl}", \
37 manifestBranch: "${params.manifestBranch}", \
38 currentBranch: true, \
39 destinationDir: 'voltha', \
40 forceSync: true,
41 resetFirst: true, \
42 quiet: true, \
43 jobs: 4, \
44 showAllChanges: true] \
45 )
46 }
47 }
48 stage('Patch') {
49 steps {
50 sh """
51 pushd voltha
52 PROJECT_PATH=\$(xmllint --xpath "string(//project[@name=\\\"${gerritProject}\\\"]/@path)" .repo/manifest.xml)
53 repo download "\$PROJECT_PATH" "${gerritChangeNumber}/${gerritPatchsetNumber}"
54 popd
55 """
56 }
57 }
58 stage('Create K8s Cluster') {
59 steps {
60 sh """
61 git clone https://gerrit.opencord.org/voltha-system-tests
62 git clone https://github.com/ciena/kind-voltha.git
63 cd kind-voltha/
Kailash9eac2732019-09-03 18:05:48 -070064 DEPLOY_K8S=y JUST_K8S=y FANCY=0 ./voltha up
Kailashaad71012019-08-27 10:36:53 -070065 """
66 }
67 }
68
69 stage('Build Images') {
70 steps {
71 sh """
72 cd $WORKSPACE/voltha/${gerritProject}/
Kailash9eac2732019-09-03 18:05:48 -070073 make DOCKER_REPOSITORY=voltha/ DOCKER_TAG=citest docker-build
Kailashaad71012019-08-27 10:36:53 -070074 """
75 }
76 }
77
78 stage('Push Images') {
79 steps {
80 sh '''
81 export GOROOT=/usr/local/go
82 export GOPATH=\$(pwd)
83 export TYPE=minimal
84 export KUBECONFIG="$(./bin/kind get kubeconfig-path --name="voltha-minimal")"
85 export VOLTCONFIG="/home/jenkins/.volt/config-minimal"
Kailasheadb2e22019-09-05 10:30:06 -070086 export PATH=/w/workspace/${gerritProject}_sanity-system-test/kind-voltha/bin:$PATH
Kailashaad71012019-08-27 10:36:53 -070087 docker images | grep citest
88 for image in \$(docker images -f "reference=*/*citest" --format "{{.Repository}}"); do echo "Pushing \$image to nodes"; kind load docker-image \$image:citest --name voltha-\$TYPE --nodes voltha-\$TYPE-worker,voltha-\$TYPE-worker2; done
89 '''
90 }
91 }
92 stage('Deploy Voltha') {
93 steps {
94 sh """
Kailash25f7a702019-09-05 11:43:11 -070095 HELM_FLAG="--set defaults.image_tag=voltha-2.1 "
Kailashaad71012019-08-27 10:36:53 -070096
97 if [ "${gerritProject}" = "voltha-go" ]; then
98 HELM_FLAG+="-f $WORKSPACE/voltha-system-tests/tests/data/ci-test.yaml"
99 fi
100
101 if [ "${gerritProject}" = "voltha-openolt-adapter" ]; then
102 HELM_FLAG+="--set images.adapter_open_olt.tag=citest,images.adapter_open_olt.pullPolicy=Never"
103 fi
104
105 if [ "${gerritProject}" = "voltha-openonu-adapter" ]; then
106 HELM_FLAG+="--set images.adapter_open_onu.tag=citest,images.adapter_open_onu.pullPolicy=Never"
107 fi
108
Andy Bavierc4183ba2019-09-30 15:40:18 -0700109 if [ "${gerritProject}" = "voltha-bbsim" ]; then
110 HELM_FLAG+="--set images.bbsim.tag=citest,images.bbsim.pullPolicy=Never"
111 fi
112
Scott Baker9ac23712019-10-02 09:26:50 -0700113 if [ "${gerritProject}" = "voltha-api-server" ]; then
114 HELM_FLAG+="--set images.afrouter.tag=citest,images.afrouter.pullPolicy=Never,images.afrouterd.tag=citest,images.afrouterd.pullPolicy=Never"
115 fi
116
Kailashaad71012019-08-27 10:36:53 -0700117 cd kind-voltha/
Kailashda9b6562019-09-03 12:48:31 -0700118 echo \$HELM_FLAG
119 EXTRA_HELM_FLAGS=\$HELM_FLAG VOLTHA_LOG_LEVEL=DEBUG TYPE=minimal WITH_RADIUS=y WITH_BBSIM=y INSTALL_ONOS_APPS=y CONFIG_SADIS=y FANCY=0 ./voltha up
Kailashaad71012019-08-27 10:36:53 -0700120 """
121 }
122 }
123
124 stage('Run E2E Tests') {
125 steps {
126 sh '''
127 cd kind-voltha/
128 export KUBECONFIG="$(./bin/kind get kubeconfig-path --name="voltha-minimal")"
129 export VOLTCONFIG="/home/jenkins/.volt/config-minimal"
Kailasheadb2e22019-09-05 10:30:06 -0700130 export PATH=/w/workspace/${gerritProject}_sanity-system-test/kind-voltha/bin:$PATH
Kailashaad71012019-08-27 10:36:53 -0700131 cd $WORKSPACE/voltha-system-tests/tests/sanity
Kailash184cbea2019-09-11 13:54:47 -0700132 robot -v ONOS_REST_PORT:8181 -v ONOS_SSH_PORT:8101 -e notready --critical sanity --noncritical VOL-1705 -v num_onus:1 sanity.robot || true
Kailashaad71012019-08-27 10:36:53 -0700133 '''
134 }
135 }
136 }
137
138 post {
139 always {
140 sh '''
141 # copy robot logs
142 if [ -d RobotLogs ]; then rm -r RobotLogs; fi; mkdir RobotLogs
143 cp -r $WORKSPACE/voltha-system-tests/tests/sanity/*ml ./RobotLogs || true
144 cd kind-voltha/
145 cp install-minimal.log $WORKSPACE/
146 export KUBECONFIG="$(./bin/kind get kubeconfig-path --name="voltha-minimal")"
147 export VOLTCONFIG="/home/jenkins/.volt/config-minimal"
Kailasheadb2e22019-09-05 10:30:06 -0700148 export PATH=/w/workspace/${gerritProject}_sanity-system-test/kind-voltha/bin:$PATH
Kailashaad71012019-08-27 10:36:53 -0700149 kubectl get pods --all-namespaces -o jsonpath="{..image}" |tr -s "[[:space:]]" "\n" | sort | uniq -c
150 kubectl get nodes -o wide
151 kubectl get pods -o wide
152 kubectl get pods -n voltha -o wide
153 ## get default pod logs
154 for pod in \$(kubectl get pods --no-headers | awk '{print \$1}');
155 do
156 if [[ \$pod == *"onos"* && \$pod != *"onos-service"* ]]; then
157 kubectl logs \$pod onos> $WORKSPACE/\$pod.log;
158 else
159 kubectl logs \$pod> $WORKSPACE/\$pod.log;
160 fi
161 done
162 ## get voltha pod logs
163 for pod in \$(kubectl get pods --no-headers -n voltha | awk '{print \$1}');
164 do
165 if [[ \$pod == *"-api-"* ]]; then
166 kubectl logs \$pod arouter -n voltha > $WORKSPACE/\$pod.log;
167 else
168 kubectl logs \$pod -n voltha > $WORKSPACE/\$pod.log;
169 fi
170 done
Kailash2365ea82019-09-10 11:09:58 -0700171 ## clean up node
Andy Bavier3a58ba32019-09-20 16:31:40 -0700172 WAIT_ON_DOWN=y ./voltha down
Kailash2365ea82019-09-10 11:09:58 -0700173 cd $WORKSPACE/
174 rm -rf kind-voltha/ voltha-system-tests/ || true
Kailashaad71012019-08-27 10:36:53 -0700175 '''
176 step([$class: 'RobotPublisher',
177 disableArchiveOutput: false,
178 logFileName: 'RobotLogs/log*.html',
179 otherFiles: '',
180 outputFileName: 'RobotLogs/output*.xml',
181 outputPath: '.',
182 passThreshold: 80,
183 reportFileName: 'RobotLogs/report*.html',
184 unstableThreshold: 0]);
185 archiveArtifacts artifacts: '*.log'
186
187 }
188 }
189}