| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 1 | package com.mirantis.mk | 
|  | 2 |  | 
|  | 3 | /** | 
|  | 4 | * | 
|  | 5 | * Debian functions | 
|  | 6 | * | 
|  | 7 | */ | 
|  | 8 |  | 
|  | 9 | def cleanup(image="debian:sid") { | 
|  | 10 | def common = new com.mirantis.mk.Common() | 
|  | 11 | def img = docker.image(image) | 
|  | 12 |  | 
|  | 13 | workspace = common.getWorkspace() | 
|  | 14 | sh("docker run -e DEBIAN_FRONTEND=noninteractive -v ${workspace}:${workspace} -w ${workspace} --rm=true --privileged ${image} /bin/bash -c 'rm -rf build-area || true'") | 
|  | 15 | } | 
|  | 16 |  | 
|  | 17 | /* | 
|  | 18 | * Build binary Debian package from existing dsc | 
|  | 19 | * | 
|  | 20 | * @param file  dsc file to build | 
|  | 21 | * @param image Image name to use for build (default debian:sid) | 
|  | 22 | */ | 
|  | 23 | def buildBinary(file, image="debian:sid", extraRepoUrl=null, extraRepoKeyUrl=null) { | 
|  | 24 | def common = new com.mirantis.mk.Common() | 
| Filip Pytloun | 81c864d | 2017-03-21 15:19:30 +0100 | [diff] [blame] | 25 | def jenkinsUID = common.getJenkinsUid() | 
|  | 26 | def jenkinsGID = common.getJenkinsGid() | 
|  | 27 |  | 
| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 28 | def pkg = file.split('/')[-1].split('_')[0] | 
|  | 29 | def img = docker.image(image) | 
|  | 30 |  | 
|  | 31 | workspace = common.getWorkspace() | 
|  | 32 | sh("""docker run -e DEBIAN_FRONTEND=noninteractive -v ${workspace}:${workspace} -w ${workspace} --rm=true --privileged ${image} /bin/bash -c ' | 
|  | 33 | which eatmydata || (apt-get update && apt-get install -y eatmydata) && | 
|  | 34 | export LD_LIBRARY_PATH=\${LD_LIBRARY_PATH:+"\$LD_LIBRARY_PATH:"}/usr/lib/libeatmydata && | 
|  | 35 | export LD_PRELOAD=\${LD_PRELOAD:+"\$LD_PRELOAD "}libeatmydata.so && | 
|  | 36 | [[ -z "${extraRepoUrl}" && "${extraRepoUrl}" != "null" ]] || echo "${extraRepoUrl}" >/etc/apt/sources.list.d/extra.list && | 
|  | 37 | [[ -z "${extraRepoKeyUrl}" && "${extraRepoKeyUrl}" != "null" ]] || ( | 
|  | 38 | which curl || (apt-get update && apt-get install -y curl) && | 
|  | 39 | curl --insecure -ss -f "${extraRepoKeyUrl}" | apt-key add - | 
|  | 40 | ) && | 
| Filip Pytloun | 81c864d | 2017-03-21 15:19:30 +0100 | [diff] [blame] | 41 | apt-get update && apt-get install -y build-essential devscripts equivs sudo && | 
|  | 42 | groupadd -g ${jenkinsGID} jenkins && | 
|  | 43 | useradd -s /bin/bash --uid ${jenkinsUID} --gid ${jenkinsGID} -m jenkins && | 
| Filip Pytloun | ff82fc0 | 2017-03-27 12:17:05 +0200 | [diff] [blame] | 44 | sudo -H -E -u jenkins dpkg-source -x ${file} build-area/${pkg} && cd build-area/${pkg} && | 
| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 45 | mk-build-deps -t "apt-get -o Debug::pkgProblemResolver=yes -y" -i debian/control | 
| Filip Pytloun | ff82fc0 | 2017-03-27 12:17:05 +0200 | [diff] [blame] | 46 | sudo -H -E -u jenkins debuild --no-lintian -uc -us -b'""") | 
| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 47 | } | 
|  | 48 |  | 
|  | 49 | /* | 
|  | 50 | * Build source package from directory | 
|  | 51 | * | 
|  | 52 | * @param dir   Tree to build | 
|  | 53 | * @param image Image name to use for build (default debian:sid) | 
|  | 54 | * @param snapshot Generate snapshot version (default false) | 
|  | 55 | */ | 
|  | 56 | def buildSource(dir, image="debian:sid", snapshot=false, gitEmail='jenkins@dummy.org', gitName='Jenkins', revisionPostfix="") { | 
|  | 57 | def isGit | 
|  | 58 | try { | 
|  | 59 | sh("test -d ${dir}/.git") | 
|  | 60 | isGit = true | 
|  | 61 | } catch (Exception e) { | 
|  | 62 | isGit = false | 
|  | 63 | } | 
|  | 64 |  | 
|  | 65 | if (isGit == true) { | 
|  | 66 | buildSourceGbp(dir, image, snapshot, gitEmail, gitName, revisionPostfix) | 
|  | 67 | } else { | 
|  | 68 | buildSourceUscan(dir, image) | 
|  | 69 | } | 
|  | 70 | } | 
|  | 71 |  | 
|  | 72 | /* | 
|  | 73 | * Build source package, fetching upstream code using uscan | 
|  | 74 | * | 
|  | 75 | * @param dir   Tree to build | 
|  | 76 | * @param image Image name to use for build (default debian:sid) | 
|  | 77 | */ | 
|  | 78 | def buildSourceUscan(dir, image="debian:sid") { | 
|  | 79 | def common = new com.mirantis.mk.Common() | 
|  | 80 | def img = docker.image(image) | 
|  | 81 | workspace = common.getWorkspace() | 
|  | 82 | sh("""docker run -e DEBIAN_FRONTEND=noninteractive -v ${workspace}:${workspace} -w ${workspace} --rm=true --privileged ${image} /bin/bash -c ' | 
|  | 83 | apt-get update && apt-get install -y build-essential devscripts && | 
|  | 84 | cd ${dir} && uscan --download-current-version && | 
|  | 85 | dpkg-buildpackage -S -nc -uc -us'""") | 
|  | 86 | } | 
|  | 87 |  | 
|  | 88 | /* | 
|  | 89 | * Build source package using git-buildpackage | 
|  | 90 | * | 
|  | 91 | * @param dir   Tree to build | 
|  | 92 | * @param image Image name to use for build (default debian:sid) | 
|  | 93 | * @param snapshot Generate snapshot version (default false) | 
|  | 94 | */ | 
| Filip Pytloun | ff82fc0 | 2017-03-27 12:17:05 +0200 | [diff] [blame] | 95 | def buildSourceGbp(dir, image="debian:sid", snapshot=false, gitName='Jenkins', gitEmail='jenkins@dummy.org', revisionPostfix="") { | 
| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 96 | def common = new com.mirantis.mk.Common() | 
| Filip Pytloun | 81c864d | 2017-03-21 15:19:30 +0100 | [diff] [blame] | 97 | def jenkinsUID = common.getJenkinsUid() | 
|  | 98 | def jenkinsGID = common.getJenkinsGid() | 
| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 99 |  | 
|  | 100 | if (! revisionPostfix) { | 
|  | 101 | revisionPostfix = "" | 
|  | 102 | } | 
|  | 103 |  | 
|  | 104 | def img = docker.image(image) | 
|  | 105 | workspace = common.getWorkspace() | 
|  | 106 | sh("""docker run -e DEBIAN_FRONTEND=noninteractive -e DEBFULLNAME='${gitName}' -e DEBEMAIL='${gitEmail}' -v ${workspace}:${workspace} -w ${workspace} --rm=true --privileged ${image} /bin/bash -exc ' | 
|  | 107 | which eatmydata || (apt-get update && apt-get install -y eatmydata) && | 
|  | 108 | export LD_LIBRARY_PATH=\${LD_LIBRARY_PATH:+"\$LD_LIBRARY_PATH:"}/usr/lib/libeatmydata && | 
|  | 109 | export LD_PRELOAD=\${LD_PRELOAD:+"\$LD_PRELOAD "}libeatmydata.so && | 
|  | 110 | apt-get update && apt-get install -y build-essential git-buildpackage sudo && | 
|  | 111 | groupadd -g ${jenkinsGID} jenkins && | 
|  | 112 | useradd -s /bin/bash --uid ${jenkinsUID} --gid ${jenkinsGID} -m jenkins && | 
|  | 113 | cd ${dir} && | 
| Filip Pytloun | ff82fc0 | 2017-03-27 12:17:05 +0200 | [diff] [blame] | 114 | sudo -H -E -u jenkins git config --global user.name "${gitName}" && | 
|  | 115 | sudo -H -E -u jenkins git config --global user.email "${gitEmail}" && | 
| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 116 | [[ "${snapshot}" == "false" ]] || ( | 
|  | 117 | VERSION=`dpkg-parsechangelog --count 1 | grep Version: | sed "s,Version: ,,g"` && | 
|  | 118 | UPSTREAM_VERSION=`echo \$VERSION | cut -d "-" -f 1` && | 
|  | 119 | REVISION=`echo \$VERSION | cut -d "-" -f 2` && | 
|  | 120 | TIMESTAMP=`date +%Y%m%d%H%M` && | 
|  | 121 | if [[ "`cat debian/source/format`" = *quilt* ]]; then | 
|  | 122 | UPSTREAM_BRANCH=`(grep upstream-branch debian/gbp.conf || echo master) | cut -d = -f 2 | tr -d " "` && | 
|  | 123 | UPSTREAM_REV=`git rev-parse --short origin/\$UPSTREAM_BRANCH` && | 
|  | 124 | NEW_UPSTREAM_VERSION="\$UPSTREAM_VERSION+\$TIMESTAMP.\$UPSTREAM_REV" && | 
|  | 125 | NEW_VERSION=\$NEW_UPSTREAM_VERSION-\$REVISION$revisionPostfix && | 
|  | 126 | echo "Generating new upstream version \$NEW_UPSTREAM_VERSION" && | 
| Filip Pytloun | ff82fc0 | 2017-03-27 12:17:05 +0200 | [diff] [blame] | 127 | sudo -H -E -u jenkins git tag \$NEW_UPSTREAM_VERSION origin/\$UPSTREAM_BRANCH && | 
|  | 128 | sudo -H -E -u jenkins git merge -X theirs \$NEW_UPSTREAM_VERSION | 
| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 129 | else | 
|  | 130 | NEW_VERSION=\$VERSION+\$TIMESTAMP.`git rev-parse --short HEAD`$revisionPostfix | 
|  | 131 | fi && | 
| Filip Pytloun | ff82fc0 | 2017-03-27 12:17:05 +0200 | [diff] [blame] | 132 | sudo -H -E -u jenkins gbp dch --auto --multimaint-merge --ignore-branch --new-version=\$NEW_VERSION --distribution `lsb_release -c -s` --force-distribution && | 
|  | 133 | sudo -H -E -u jenkins git add -u debian/changelog && | 
|  | 134 | sudo -H -E -u jenkins git commit -m "New snapshot version \$NEW_VERSION" | 
| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 135 | ) && | 
| Filip Pytloun | ff82fc0 | 2017-03-27 12:17:05 +0200 | [diff] [blame] | 136 | sudo -H -E -u jenkins gbp buildpackage -nc --git-force-create --git-notify=false --git-ignore-branch --git-ignore-new --git-verbose --git-export-dir=../build-area -sa -S -uc -us '""") | 
| Jakub Josef | 79ecec3 | 2017-02-17 14:36:28 +0100 | [diff] [blame] | 137 | } | 
|  | 138 |  | 
|  | 139 | /* | 
|  | 140 | * Run lintian checks | 
|  | 141 | * | 
|  | 142 | * @param changes   Changes file to test against | 
|  | 143 | * @param profile   Lintian profile to use (default debian) | 
|  | 144 | * @param image     Image name to use for build (default debian:sid) | 
|  | 145 | */ | 
|  | 146 | def runLintian(changes, profile="debian", image="debian:sid") { | 
|  | 147 | def common = new com.mirantis.mk.Common() | 
|  | 148 | def img = docker.image(image) | 
|  | 149 | workspace = common.getWorkspace() | 
|  | 150 | sh("""docker run -e DEBIAN_FRONTEND=noninteractive -v ${workspace}:${workspace} -w ${workspace} --rm=true --privileged ${image} /bin/bash -c ' | 
|  | 151 | apt-get update && apt-get install -y lintian && | 
|  | 152 | lintian -Ii -E --pedantic --profile=${profile} ${changes}'""") | 
|  | 153 | } | 
| chnyda | 4e5ac79 | 2017-03-14 15:24:18 +0100 | [diff] [blame] | 154 |  | 
|  | 155 | /* | 
|  | 156 | * Import gpg key | 
|  | 157 | * | 
|  | 158 | * @param privateKeyCredId   Public key jenkins credential id | 
|  | 159 | */ | 
|  | 160 | def importGpgKey(privateKeyCredId) | 
|  | 161 | { | 
|  | 162 | def common = new com.mirantis.mk.Common() | 
|  | 163 | def workspace = common.getWorkspace() | 
|  | 164 | def privKey = common.getCredentials(privateKeyCredId, "key") | 
|  | 165 | def private_key = privKey.privateKeySource.privateKey | 
| chnyda | c684645 | 2017-03-21 16:50:43 +0100 | [diff] [blame] | 166 | def gpg_key_id = common.getCredentials(privateKeyCredId, "key").username | 
|  | 167 | def retval = sh(script: "export GNUPGHOME=${workspace}/.gnupg; gpg --list-secret-keys | grep ${gpg_key_id}", returnStatus: true) | 
|  | 168 | if (retval) { | 
|  | 169 | writeFile file:"${workspace}/private.key", text: private_key | 
|  | 170 | sh(script: "gpg --no-tty --allow-secret-key-import --homedir ${workspace}/.gnupg --import ./private.key") | 
|  | 171 | } | 
| chnyda | 4e5ac79 | 2017-03-14 15:24:18 +0100 | [diff] [blame] | 172 | } | 
|  | 173 |  | 
|  | 174 | /* | 
|  | 175 | * upload source package to launchpad | 
|  | 176 | * | 
|  | 177 | * @param ppaRepo   ppa repository on launchpad | 
|  | 178 | * @param dirPath repository containing the source packages | 
|  | 179 | */ | 
|  | 180 |  | 
|  | 181 | def uploadPpa(ppaRepo, dirPath, privateKeyCredId) { | 
|  | 182 |  | 
|  | 183 | def common = new com.mirantis.mk.Common() | 
|  | 184 | def workspace = common.getWorkspace() | 
|  | 185 | def gpg_key_id = common.getCredentials(privateKeyCredId, "key").username | 
|  | 186 |  | 
|  | 187 | dir(dirPath) | 
|  | 188 | { | 
|  | 189 | def images = findFiles(glob: "*.orig*.tar.gz") | 
|  | 190 | for (int i = 0; i < images.size(); ++i) { | 
|  | 191 | def name = images[i].getName() | 
|  | 192 | def orig_sha1 = common.cutOrDie("sha1sum ${name}", 0) | 
|  | 193 | def orig_sha256 = common.cutOrDie("sha256sum ${name}", 0) | 
|  | 194 | def orig_md5 = common.cutOrDie("md5sum ${name}", 0) | 
|  | 195 | def orig_size = common.cutOrDie("ls -l ${name}", 4) | 
|  | 196 |  | 
| chnyda | 5d1e97f | 2017-03-17 15:53:47 +0100 | [diff] [blame] | 197 | def retval = sh(script: "wget --quiet -O orig-tmp https://launchpad.net/ubuntu/+archive/primary/+files/${name}", returnStatus: true) | 
| chnyda | 4e5ac79 | 2017-03-14 15:24:18 +0100 | [diff] [blame] | 198 | if (retval == 0) { | 
|  | 199 | sh("mv orig-tmp ${name}") | 
|  | 200 | def new_sha1 = common.cutOrDie("sha1sum ${name}", 0) | 
|  | 201 | def new_sha256 = common.cutOrDie("sha256sum ${name}", 0) | 
|  | 202 | def new_md5 = common.cutOrDie("md5sum ${name}", 0) | 
|  | 203 | def new_size = common.cutOrDie("ls -l ${name}", 4) | 
|  | 204 |  | 
|  | 205 | sh("sed -i -e s,$orig_sha1,$new_sha1,g -e s,$orig_sha256,$new_sha256,g -e s,$orig_size,$new_size,g -e s,$orig_md5,$new_md5,g *.dsc") | 
| chnyda | 3c93ff6 | 2017-03-23 10:11:36 +0100 | [diff] [blame] | 206 | sh("sed -i -e s,$orig_sha1,$new_sha1,g -e s,$orig_sha256,$new_sha256,g -e s,$orig_size,$new_size,g -e s,$orig_md5,$new_md5,g *_source.changes") | 
| chnyda | 4e5ac79 | 2017-03-14 15:24:18 +0100 | [diff] [blame] | 207 | } | 
| chnyda | 4e5ac79 | 2017-03-14 15:24:18 +0100 | [diff] [blame] | 208 | } | 
| chnyda | 34e5c94 | 2017-03-22 18:06:06 +0100 | [diff] [blame] | 209 | sh("export GNUPGHOME=${workspace}/.gnupg; debsign --re-sign -k ${gpg_key_id} *_source.changes") | 
|  | 210 | sh("export GNUPGHOME=${workspace}/.gnupg; dput -f \"ppa:${ppaRepo}\" *_source.changes") | 
| chnyda | 4e5ac79 | 2017-03-14 15:24:18 +0100 | [diff] [blame] | 211 | } | 
| Filip Pytloun | fbbd168 | 2017-03-17 22:48:04 +0100 | [diff] [blame] | 212 | } |