[PATCH] jenkins: Add build jobs
Samuel Mendoza-Jonas
sam at mendozajonas.com
Thu Jul 26 11:24:30 AEST 2018
On Wed, 2018-05-23 at 17:25 -0700, Geoff Levand wrote:
> Adds two Jenkins pipeline jobs pb-upstream-trigger and pb-build-matrix.
> pb-upstream-trigger checks for upstream updates and runs
> pb-build-matrix. pb-build-matrix builds a pb-builder image and runs the
> build-pb script.
>
> Signed-off-by: Geoff Levand <geoff at infradead.org>
Thanks, merged as a30e4ac.
I have some changes in mind such as passing through proxy information and
configure options but I'll submit them once I've ironed out my own
Jenkins issues :)
> ---
> Hi Sam,
>
> Here is a first cut at Jenkins pipeline support. The Jenkins
> master will need the plugins: build-timeout, copyartifact, git,
> pipeline, ssh-agent, workflow-aggregator, and maybe some others.
>
> The matrix job expects worker nodes to have labels to indicate
> the machine arch; amd64, arm64, etc., and the 'docker' tag to
> indicate that the Jenkins account can run docker commands.
>
> Now I have the default values for BUILD_ARCH_LIST and GIT_URL
> hard coded into the jobs, but I think having a site specific
> profile file that gets loaded would be a better solution as not
> all sites will have say an arm64 Jenkins worker node. Maybe
> you would want to put something like 'ppc64le' in yours...
>
> Please consider.
>
> -Geoff
>
> jenkins/pb-build-matrix.groovy | 81 ++++++++++++++++++++++++++++++++++++++
> jenkins/pb-upstream-trigger.groovy | 24 +++++++++++
> 2 files changed, 105 insertions(+)
> create mode 100644 jenkins/pb-build-matrix.groovy
> create mode 100644 jenkins/pb-upstream-trigger.groovy
>
> diff --git a/jenkins/pb-build-matrix.groovy b/jenkins/pb-build-matrix.groovy
> new file mode 100644
> index 0000000..7547612
> --- /dev/null
> +++ b/jenkins/pb-build-matrix.groovy
> @@ -0,0 +1,81 @@
> +#!groovy
> +// Builds pb-builder image and runs build-pb script.
> +//
> +// The `jenkins` user must be in the `docker` user group.
> +// Requires nodes with labels: `amd64`, `arm64`, `docker`.
> +// Required plugins: build-timeout, copyartifact, git, pipeline, ssh-agent,
> +// workflow-aggregator.
> +
> +properties([
> + buildDiscarder(logRotator(daysToKeepStr: '30', numToKeepStr: '5')),
> + parameters([
> + string(name: 'BUILD_ARCH_LIST',
> + defaultValue: 'amd64 arm64',
> + description: 'List of Jenkins node architectures to build on.'),
> + booleanParam(name: 'DOCKER_PURGE',
> + defaultValue: false,
> + description: 'Remove existing pb-builder docker image and rebuild.'),
> + booleanParam(name: 'DRY_RUN',
> + defaultValue: false,
> + description: 'Dry run, do not build.'),
> + string(name: 'GIT_URL',
> + defaultValue: 'git://ozlabs.org/petitboot',
> + description: 'URL of petitboot git repository.'),
> + ])
> +])
> +
> +def build_pb = { String _build_arch, Boolean _dry_run, String _git_url,
> + Boolean _purge
> + ->
> + String build_arch = _build_arch
> + Boolean dry_run = _dry_run
> + String git_url = _git_url
> + Boolean purge = _purge
> + String builder_args = ""
> + String pb_args = ""
> +
> + if (dry_run) {
> + builder_args += " --dry-run"
> + pb_args += " --dry-run"
> + }
> + if (purge) {
> + builder_args += " --purge"
> + }
> +
> + // timeout if no build_arch node is available.
> + timeout(time: 15, unit: 'MINUTES') {
> + node("${build_arch} && docker") {
> + git(poll: false, changelog: false, url: git_url)
> +
> + stage("[${build_arch}--build-builder]") {
> + sh("""./docker/build-builder --verbose ${builder_args}""")
> + }
> + stage("[${build_arch}--build-pb]") {
> + sh("""./docker/build-pb --verbose --check ${pb_args}""")
> + }
> + stage('Post-build') {
> + String result_file = "${BUILD_TAG}-${build_arch}-test-results.tar.xz"
> + String test_info = """build_arch=${build_arch}
> + BUILD_URL=${BUILD_URL}
> + BUILD_TAG=${BUILD_TAG}
> + GIT_URL=${GIT_URL}
> + """
> +
> + writeFile(file: 'test-info.txt', text: test_info)
> + sh("tar -cJf ${result_file} test-info.txt test-suite.log \
> + \$(find test -name '*.log')")
> + archiveArtifacts "${result_file}"
> + }
> + }
> + }
> +}
> +
> +def build_map = [:]
> +build_map.failFast = false
> +
> +for (build_arch in params.BUILD_ARCH_LIST.split()) {
> + build_map[build_arch] = build_pb.curry(build_arch, params.DRY_RUN,
> + params.GIT_URL, params.DOCKER_PURGE)
> +}
> +
> +parallel build_map
> diff --git a/jenkins/pb-upstream-trigger.groovy b/jenkins/pb-upstream-trigger.groovy
> new file mode 100644
> index 0000000..ab67e74
> --- /dev/null
> +++ b/jenkins/pb-upstream-trigger.groovy
> @@ -0,0 +1,24 @@
> +#!groovy
> +// Check for upstream updates and run builds.
> +
> +properties([
> + buildDiscarder(logRotator(daysToKeepStr: '30', numToKeepStr: '5')),
> + pipelineTriggers([pollSCM('H/30 * * * *')]),
> + parameters([
> + string(name: 'GIT_URL',
> + defaultValue: 'git://ozlabs.org/petitboot',
> + description: 'URL of petitboot git repository.'),
> + ])
> +])
> +
> +stage('Build') {
> + node {
> + git(poll: true, changelog: false, url: params.GIT_URL)
> + build(
> + job: 'pb-build-matrix',
> + parameters: [
> + string(name: 'GIT_URL', value: params.GIT_URL),
> + ],
> + )
> + }
> +}
More information about the Petitboot
mailing list