1 /* Copyright 2017 Sandvine
5 * Licensed under the Apache License, Version 2.0 (the "License"); you may
6 * not use this file except in compliance with the License. You may obtain
7 * a copy of the License at
9 * http://www.apache.org/licenses/LICENSE-2.0
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
13 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
14 * License for the specific language governing permissions and limitations
18 def get_archive(artifactory_server, mdg, branch, build_name, build_number, pattern='*') {
19 server = Artifactory.server artifactory_server
21 println("retrieve archive for ${mdg}/${branch}/${build_name}/${build_number}/${pattern}")
23 // if the build name does not contain merge, then this is a patchset/staging job
24 if (!build_name.contains('merge')) {
27 def repo_prefix = 'osm-'
28 def downloadSpec = """{
32 "pattern": "${repo_prefix}${mdg}/${branch}/${build_number}/${pattern}"
37 println("Searching Artifactory with ${downloadSpec}")
39 def results = server.download(downloadSpec)
40 // Save the list of URLs that we need to pass to the dockerfiles for build
41 def debian_packages = []
42 for ( result in results.getDependencies()) {
43 if (result.remotePath.contains(".deb")) {
44 debian_packages.add(result.remotePath)
48 // workaround. flatten repo to remove specific build num from the directory
49 sh "cp -R ${branch}/${build_number}/* ."
50 sh "rm -rf ${branch}/${build_number}"
52 return debian_packages
55 def get_env_value(build_env_file,key) {
56 return sh(returnStdout:true, script: "cat ${build_env_file} | awk -F= '/${key}/{print \$2}'").trim()
59 def lxc_run(container_name,cmd) {
60 return sh(returnStdout: true, script: "lxc exec ${container_name} -- ${cmd}").trim()
63 def lxc_file_push(container_name,file,destination) {
64 return sh(returnStdout: true, script: "lxc file push ${file} ${container_name}/${destination}").trim()
67 // start a http server
68 // return the http server URL
69 def start_http_server(repo_dir,server_name,port) {
70 sh "docker run -dit --name ${server_name} -p ${port}:80 -v ${repo_dir}:/usr/local/apache2/htdocs/ httpd:2.4"
71 def http_server_ip = sh(returnStdout:true, script: "docker inspect --format '{{ .NetworkSettings.IPAddress }}' ${server_name}").trim()
72 return "http://${http_server_ip}/"
75 def lxc_get_file(container_name,file,destination) {
76 sh "lxc file pull ${container_name}/${file} ${destination}"
79 def systest_run(container_name, test, source_rc = null) {
80 // need to get the SO IP inside the running container
81 so_ip = lxc_run(container_name,"lxc list SO-ub -c 4|grep eth0 |awk '{print \$2}'")
82 ro_ip = lxc_run(container_name,"lxc list RO -c 4|grep eth0 |awk '{print \$2}'")
83 //container_ip = get_ip_from_container(container_name)
86 pre_source = "/tmp/" + source_rc.substring(source_rc.lastIndexOf('/')+1)
88 lxc_file_push(container_name,source_rc,pre_source)
89 result = lxc_run(container_name, "sh -c '. ${pre_source}; make -C devops/systest OSM_HOSTNAME=${so_ip} OSM_RO_HOSTNAME=${ro_ip} ${test}'")
94 result = lxc_run(container_name, "make -C devops/systest OSM_HOSTNAME=${so_ip} OSM_RO_HOSTNAME=${ro_ip} ${test}")
97 lxc_get_file(container_name, "/root/devops/systest/reports/pytest-${test}.xml",'.')
100 def get_ip_from_container( container_name ) {
101 return sh(returnStdout: true, script: "lxc list ${container_name} -c 4|grep eth0 |awk '{print \$2}'").trim()
104 def archive(artifactory_server,mdg,branch,status) {
105 server = Artifactory.server artifactory_server
108 //def properties = "branch=${branch};status=${status}"
109 def repo_prefix = 'osm-'
111 // if the build name does not contain merge, then this is a patchset/staging job
112 if ( !JOB_NAME.contains('merge') ) {
115 def uploadSpec = """{
118 "pattern": "dists/*.gz",
119 "target": "${repo_prefix}${mdg}/${branch}/${BUILD_NUMBER}/",
120 "props": "${properties}",
124 "pattern": "dists/*Packages",
125 "target": "${repo_prefix}${mdg}/${branch}/${BUILD_NUMBER}/",
126 "props": "${properties}",
130 "pattern": "pool/*/*.deb",
131 "target": "${repo_prefix}${mdg}/${branch}/${BUILD_NUMBER}/",
132 "props": "${properties}",
136 "pattern": "changelog/*",
137 "target": "${repo_prefix}${mdg}/${branch}/${BUILD_NUMBER}/",
138 "props": "${properties}",
143 buildInfo = server.upload(uploadSpec)
144 //buildInfo.retention maxBuilds: 4
145 //buildInfo.retention deleteBuildArtifacts: false
147 server.publishBuildInfo(buildInfo)
149 // store the build environment into the jenkins artifact storage
151 archiveArtifacts artifacts: "build.env", fingerprint: true
155 //CANNOT use build promotion with OSS version of artifactory
156 // For now, will publish downloaded artifacts into a new repo.
157 def promote_build(artifactory_server,mdg,branch,buildInfo) {
158 println("Promoting build: mdg: ${mdg} branch: ${branch} build: ${buildInfo.name}/${buildInfo.number}")
160 server = Artifactory.server artifactory_server
162 //def properties = "branch=${branch};status=${status}"
163 def repo_prefix = 'osm-'
164 def build_name = "${mdg}-stage_2 :: ${branch}"
166 def promotionConfig = [
167 // Mandatory parameters
168 "buildName" : buildInfo.name,
169 "buildNumber" : buildInfo.number,
170 'targetRepo' : 'osm-release',
172 // Optional parameters
173 'comment' : 'this is the promotion comment',
174 'sourceRepo' : "${repo_prefix}${mdg}",
175 'status' : 'Testing',
176 'includeDependencies': true,
178 // 'failFast' is true by default.
179 // Set it to false, if you don't want the promotion to abort upon receiving the first error.
183 server.promote promotionConfig
186 def get_mdg_from_project(project) {
187 // split the project.
188 def values = project.split('/')
189 if ( values.size() > 1 ) {
192 // no prefix, likely just the project name then