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 && |
| 44 | sudo -H -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 | 81c864d | 2017-03-21 15:19:30 +0100 | [diff] [blame] | 46 | sudo -H -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 | */ |
| 95 | def buildSourceGbp(dir, image="debian:sid", snapshot=false, gitEmail='jenkins@dummy.org', gitName='Jenkins', revisionPostfix="") { |
| 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} && |
| 114 | sudo -H -u jenkins git config --global user.name "${gitName}" && |
| 115 | sudo -H -u jenkins git config --global user.email "${gitEmail}" && |
| 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" && |
| 127 | sudo -H -u jenkins git tag \$NEW_UPSTREAM_VERSION origin/\$UPSTREAM_BRANCH && |
| 128 | sudo -H -u jenkins git merge -X theirs \$NEW_UPSTREAM_VERSION |
| 129 | else |
| 130 | NEW_VERSION=\$VERSION+\$TIMESTAMP.`git rev-parse --short HEAD`$revisionPostfix |
| 131 | fi && |
| 132 | sudo -H -u jenkins gbp dch --auto --multimaint-merge --ignore-branch --new-version=\$NEW_VERSION --distribution `lsb_release -c -s` --force-distribution && |
| 133 | sudo -H -u jenkins git add -u debian/changelog && |
| 134 | sudo -H -u jenkins git commit -m "New snapshot version \$NEW_VERSION" |
| 135 | ) && |
Filip Pytloun | fbc13fa | 2017-03-21 16:00:26 +0100 | [diff] [blame^] | 136 | sudo -H -u jenkins gbp buildpackage -nc --git-force-create --git-notify=false --git-ignore-branch --git-ignore-new --git-verbose --git-export-dir=../build-area -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 | 9ee49a4 | 2017-03-15 09:31:33 +0100 | [diff] [blame] | 166 | writeFile file:"${workspace}/private.key", text: private_key |
chnyda | 96f974d | 2017-03-15 18:01:15 +0100 | [diff] [blame] | 167 | sh(script: "gpg --no-tty --allow-secret-key-import --homedir ${workspace}/.gnupg --import ./private.key") |
chnyda | 4e5ac79 | 2017-03-14 15:24:18 +0100 | [diff] [blame] | 168 | } |
| 169 | |
| 170 | /* |
| 171 | * upload source package to launchpad |
| 172 | * |
| 173 | * @param ppaRepo ppa repository on launchpad |
| 174 | * @param dirPath repository containing the source packages |
| 175 | */ |
| 176 | |
| 177 | def uploadPpa(ppaRepo, dirPath, privateKeyCredId) { |
| 178 | |
| 179 | def common = new com.mirantis.mk.Common() |
| 180 | def workspace = common.getWorkspace() |
| 181 | def gpg_key_id = common.getCredentials(privateKeyCredId, "key").username |
| 182 | |
| 183 | dir(dirPath) |
| 184 | { |
| 185 | def images = findFiles(glob: "*.orig*.tar.gz") |
| 186 | for (int i = 0; i < images.size(); ++i) { |
| 187 | def name = images[i].getName() |
| 188 | def orig_sha1 = common.cutOrDie("sha1sum ${name}", 0) |
| 189 | def orig_sha256 = common.cutOrDie("sha256sum ${name}", 0) |
| 190 | def orig_md5 = common.cutOrDie("md5sum ${name}", 0) |
| 191 | def orig_size = common.cutOrDie("ls -l ${name}", 4) |
| 192 | |
chnyda | 5d1e97f | 2017-03-17 15:53:47 +0100 | [diff] [blame] | 193 | 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] | 194 | if (retval == 0) { |
| 195 | sh("mv orig-tmp ${name}") |
| 196 | def new_sha1 = common.cutOrDie("sha1sum ${name}", 0) |
| 197 | def new_sha256 = common.cutOrDie("sha256sum ${name}", 0) |
| 198 | def new_md5 = common.cutOrDie("md5sum ${name}", 0) |
| 199 | def new_size = common.cutOrDie("ls -l ${name}", 4) |
| 200 | |
| 201 | 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") |
| 202 | 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 *.changes") |
| 203 | } |
chnyda | 4e5ac79 | 2017-03-14 15:24:18 +0100 | [diff] [blame] | 204 | } |
Filip Pytloun | fbbd168 | 2017-03-17 22:48:04 +0100 | [diff] [blame] | 205 | sh("export GNUPGHOME=${workspace}/.gnupg; debsign --re-sign -k ${gpg_key_id} *.changes") |
| 206 | sh("export GNUPGHOME=${workspace}/.gnupg; dput -f \"ppa:${ppaRepo}\" *.changes") |
chnyda | 4e5ac79 | 2017-03-14 15:24:18 +0100 | [diff] [blame] | 207 | } |
Filip Pytloun | fbbd168 | 2017-03-17 22:48:04 +0100 | [diff] [blame] | 208 | } |