blob: 6405553fbf070e79db8c27122b825b62c1d9ffc1 [file] [log] [blame]
Kailashc8170bb2019-03-26 10:06:55 -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// chart-api-test-helm.groovy
16// Checks functionality of the helm-chart, without overriding the version/tag used
17
18pipeline {
19
20 /* no label, executor is determined by JJB */
21 agent {
Zack Williamsb3292082019-10-11 17:15:18 -070022 label "${params.buildNode}"
Kailashc8170bb2019-03-26 10:06:55 -070023 }
24
25 stages {
26
27 stage('repo') {
28 steps {
29 checkout(changelog: false, \
30 poll: false,
31 scm: [$class: 'RepoScm', \
32 manifestRepositoryUrl: "${params.manifestUrl}", \
33 manifestBranch: "${params.manifestBranch}", \
34 currentBranch: true, \
35 destinationDir: 'cord', \
36 forceSync: true,
37 resetFirst: true, \
38 quiet: true, \
39 jobs: 4, \
40 showAllChanges: true] \
41 )
42 }
43 }
44
Scott Baker17a3cb52019-03-28 14:35:01 -070045 stage('patch') {
46 steps {
47 sh '''
48 pushd cord
Zack Williamsde1c6212020-02-24 17:00:17 -070049 PROJECT_PATH=\$(xmllint --xpath "string(//project[@name=\\\"${gerritProject}\\\"]/@path)" .repo/manifests/default.xml)
Scott Baker17a3cb52019-03-28 14:35:01 -070050 repo download "\$PROJECT_PATH" "${gerritChangeNumber}/${gerritPatchsetNumber}"
51 popd
52 '''
53 }
54 }
55
Kailashc8170bb2019-03-26 10:06:55 -070056 stage('minikube') {
57 steps {
58 /* see https://github.com/kubernetes/minikube/#linux-continuous-integration-without-vm-support */
59 sh '''
60 export MINIKUBE_WANTUPDATENOTIFICATION=false
61 export MINIKUBE_WANTREPORTERRORPROMPT=false
62 export CHANGE_MINIKUBE_NONE_USER=true
63 export MINIKUBE_HOME=$HOME
64 mkdir -p $HOME/.kube || true
65 touch $HOME/.kube/config
66 export KUBECONFIG=$HOME/.kube/config
67 sudo -E /usr/bin/minikube start --vm-driver=none
68 '''
69 script {
70 timeout(3) {
71 waitUntil {
72 sleep 5
73 def kc_ret = sh script: "kubectl get po", returnStatus: true
74 return (kc_ret == 0);
75 }
76 }
77 }
78 }
79 }
80
81 stage('helm') {
82 steps {
83 sh '''
84 helm init
85 sleep 60
86 helm repo add incubator https://kubernetes-charts-incubator.storage.googleapis.com/
Daniele Moro4df75772020-02-14 15:14:48 -080087 helm repo add cord https://charts.opencord.org
Kailashc8170bb2019-03-26 10:06:55 -070088 '''
89 }
90 }
91
92 stage ('Build XOS Core and TestService') {
93 steps {
94 sh """
95 #!/usr/bin/env bash
96 set -eu -o pipefail
97
Scott Baker17a3cb52019-03-28 14:35:01 -070098 export DOCKER_REPOSITORY=xosproject/
99 export DOCKER_TAG=\$(cat $WORKSPACE/cord/orchestration/xos/VERSION)
Zack Williamsae8b48b2019-04-16 15:00:37 -0700100 export DOCKER_BUILD_ARGS=--no-cache
Scott Baker17a3cb52019-03-28 14:35:01 -0700101
Zack Williamsae8b48b2019-04-16 15:00:37 -0700102 cd $WORKSPACE/cord/orchestration/xos
103 make docker-build
104
Kailashc8170bb2019-03-26 10:06:55 -0700105 cd $WORKSPACE/cord/orchestration/xos/testservice
Zack Williamsae8b48b2019-04-16 15:00:37 -0700106 make docker-build
Kailashc8170bb2019-03-26 10:06:55 -0700107 """
108 }
109 }
110
111 stage('Install XOS w/TestService') {
112 steps {
113 sh """
114 #!/usr/bin/env bash
115 set -eu -o pipefail
116
Scott Baker17a3cb52019-03-28 14:35:01 -0700117 export DOCKER_TAG=\$(cat $WORKSPACE/cord/orchestration/xos/VERSION)
118
Kailashc8170bb2019-03-26 10:06:55 -0700119 pushd cord/helm-charts
120 helm dep update xos-core
Scott Baker17a3cb52019-03-28 14:35:01 -0700121 helm install --set images.xos_core.tag=\$DOCKER_TAG,images.xos_core.pullPolicy=Never xos-core -n xos-core
Kailashc8170bb2019-03-26 10:06:55 -0700122
Kailashc8170bb2019-03-26 10:06:55 -0700123 helm-repo-tools/wait_for_pods.sh
124
125 #install testservice
Kailashfe840382019-03-26 21:11:09 -0700126 cd $WORKSPACE/cord/orchestration/xos/testservice/helm-charts
Scott Baker17a3cb52019-03-28 14:35:01 -0700127 helm install --set testservice_synchronizerImage=xosproject/testservice-synchronizer:\$DOCKER_TAG \
128 --set imagePullPolicy=Never \
129 testservice -n testservice
Kailashc8170bb2019-03-26 10:06:55 -0700130 popd
131 """
132 }
133 }
134 stage('Wait for Core') {
135 steps {
136 sh """
Kailashfe840382019-03-26 21:11:09 -0700137 #!/usr/bin/env bash
138 set -ex -o pipefail
139
Kailashc8170bb2019-03-26 10:06:55 -0700140 #wait for xos-core and models to be loaded
141 timeout 300 bash -c "until http -a admin@opencord.org:letmein GET http://127.0.0.1:30001/xosapi/v1/core/sites |jq '.items[0].name'|grep -q mysite; do echo 'Waiting for API To be up'; sleep 10; done"
142 """
143 }
144 }
145 stage('Test Core') {
146 steps {
147 sh """
148 #!/usr/bin/env bash
149 set -eu -o pipefail
150 pushd cord/test/cord-tester/src/test/cord-api/
151 source setup_venv.sh
Zack Williamsae8b48b2019-04-16 15:00:37 -0700152
Kailashc8170bb2019-03-26 10:06:55 -0700153 cd Tests/xos-test-service
154 robot -e notready test-service.robot || true
155 popd
156 """
157 }
158 }
Daniele Morodcf10ba2020-02-24 10:36:09 -0800159 stage ('Archive Artifacts') {
160 when { expression { return params.ArchiveLogs } }
161 steps {
162 sh '''
163 kubectl get pods --all-namespaces
164 ## get default pod logs
165 for pod in \$(kubectl get pods --no-headers | awk '{print \$1}');
166 do
167 kubectl logs \$pod> $WORKSPACE/\$pod.log;
168 done
169 '''
170 }
171 }
Kailashc8170bb2019-03-26 10:06:55 -0700172 }
173 post {
174 always {
175 sh """
176 kubectl get pods --all-namespaces
177
178 # copy robot logs
179 if [ -d RobotLogs ]; then rm -r RobotLogs; fi; mkdir RobotLogs
Kailashfe840382019-03-26 21:11:09 -0700180 cp -r $WORKSPACE/cord/test/cord-tester/src/test/cord-api/Tests/xos-test-service/*ml ./RobotLogs
Kailashc8170bb2019-03-26 10:06:55 -0700181 echo "# removing helm deployments"
182 kubectl get pods
183 helm list
184
185 for hchart in \$(helm list -q);
186 do
187 echo "## Purging chart: \${hchart} ##"
188 helm delete --purge "\${hchart}"
189 done
190
191 sudo minikube delete
192 """
193 step([$class: 'RobotPublisher',
194 disableArchiveOutput: false,
195 logFileName: 'RobotLogs/log*.html',
196 otherFiles: '',
197 outputFileName: 'RobotLogs/output*.xml',
198 outputPath: '.',
199 passThreshold: 100,
200 reportFileName: 'RobotLogs/report*.html',
201 unstableThreshold: 0]);
Daniele Morodcf10ba2020-02-24 10:36:09 -0800202 archiveArtifacts artifacts: '*.log'
Kailashc8170bb2019-03-26 10:06:55 -0700203 step([$class: 'Mailer', notifyEveryUnstableBuild: true, recipients: "kailash@opennetworking.org, teo@opennetworking.org", sendToIndividuals: false])
204
205 }
206 }
207}