X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=releng%2Fbuilder.git;a=blobdiff_plain;f=jjb%2Freleng-macros.yaml;h=e106e25599771e2f16ddef198f5ba0c298292aba;hp=6487231cb84ca48bb13e9cf97eb8ef653037bec7;hb=HEAD;hpb=9d38db6bfdd4ec9179596003fe2bd0b97d6a56bc diff --git a/jjb/releng-macros.yaml b/jjb/releng-macros.yaml index 6487231cb..cc4bfe4d7 100644 --- a/jjb/releng-macros.yaml +++ b/jjb/releng-macros.yaml @@ -4,7 +4,7 @@ name: opendaylight-infra-properties properties: - build-discarder: - days-to-keep: '{build-days-to-keep}' + days-to-keep: "{build-days-to-keep}" num-to-keep: 40 # Need to keep artifacts for at least 1 day as some projects need to # be able to validate their artifacts and only allowing limited @@ -17,140 +17,75 @@ parameters: - string: name: PROJECT - default: '{project}' - description: 'Parameter to identify an ODL Gerrit project' + default: "{project}" + description: "Parameter to identify an ODL Gerrit project" - string: name: ARCHIVE_ARTIFACTS # Before adding more here, beware of https://jira.linuxfoundation.org/browse/RELENG-280 default: > - {artifacts} - **/target/surefire-reports/*-output.txt - **/target/failsafe-reports/failsafe-summary.xml - **/hs_err_*.log - **/target/feature/feature.xml + {artifacts} + **/target/surefire-reports/*-output.txt + **/target/failsafe-reports/failsafe-summary.xml + **/hs_err_*.log + **/target/feature/feature.xml # TODO: **/*.hprof is too large, compress with xz first - description: 'Space separated glob patterns for artifacts to archive into logs.opendaylight.org' + description: | + Space separated glob patterns for artifacts to archive + into s3-logs.opendaylight.org/logs - string: name: GERRIT_PROJECT - default: '{project}' + default: "{project}" description: "GERRIT_PROJECT parameter if not given by trigger" - string: name: GERRIT_BRANCH - default: '{branch}' + default: "{branch}" description: "JJB configured GERRIT_BRANCH parameter" - string: name: GERRIT_REFSPEC - default: '{refspec}' + default: "{refspec}" description: | - Gerrit reference to checkout (ex: refs/heads/master, - refs/changes/48/61548/1 where 61548 is Gerrit change ID, 1 is - patch number and 48 is last two digits of change ID) + Gerrit reference to checkout (ex: refs/heads/master, + refs/changes/48/61548/1 where 61548 is Gerrit change ID, 1 is + patch number and 48 is last two digits of change ID) - string: name: STACK_NAME - default: '$SILO-$JOB_NAME-$BUILD_NUMBER' + default: "$SILO-$JOB_NAME-$BUILD_NUMBER" description: "Used by Heat to generate a unique stack & vm name" - string: name: OS_CLOUD - default: '{os-cloud}' - description: | - The name of a cloud configuration in clouds.yaml. OS_CLOUD is a - variable name that is significant to openstack client as a - environment variable. Please refer to the documentation for - further details. - https://docs.openstack.org/developer/python-openstackclient/ - -- parameter: - name: build-tag - parameters: - - string: - name: BUILD_TAG - default: '' - description: 'Tag in Git to checkout' - -- parameter: - name: controller-version-parameter - parameters: - - string: - name: ODL_VERSION - default: '{odl_version}' - description: 'Controller version (for use with openstacks networking_odl project)' - -- parameter: - name: patches-to-build-parameter - parameters: - - string: - name: PATCHES_TO_BUILD - default: '' + default: "{os-cloud}" description: | - Ordered list of patches to build in the format of project=changeset (checkout) or - project:changeset (cherry-pick) for example: genius=32/53632/9,netvirt:59/50259/47. - A topic is also allowed, for example: topic=binding-tlc-rpc - -- parameter: - name: build-order-parameter - parameters: - - string: - name: BUILD_ORDER - default: '{build-order}' - description: 'Build order for multipatch test when topic is used' - -- parameter: - name: build-fast-parameter - parameters: - - string: - name: BUILD_FAST - default: '{build-fast}' - description: 'Set true to build fast -Pq' - -- parameter: - name: run-test-parameter - parameters: - - string: - name: RUN_TEST - default: '{run-test}' - description: 'Set true to run test after build' + The name of a cloud configuration in clouds.yaml. OS_CLOUD is a + variable name that is significant to openstack client as a + environment variable. Please refer to the documentation for + further details. + https://docs.openstack.org/developer/python-openstackclient/ - parameter: name: distribution-branch-to-build-parameter parameters: - string: name: DISTRIBUTION_BRANCH_TO_BUILD - default: 'master' - description: 'distribution repo branch to build with' - -- parameter: - name: p2zip-parameter - parameters: - - string: - name: P2ZIP_URL - default: '' - description: 'Nexus staging profile id' - -- parameter: - name: stage-id-parameter - parameters: - - string: - name: STAGING_PROFILE_ID - default: '{stage-id}' - description: 'Nexus staging profile id' + default: "master" + description: "distribution repo branch to build with" - parameter: name: maven-exec parameters: - string: name: MVN - default: '/w/tools/hudson.tasks.Maven_MavenInstallation/{maven-version}/bin/mvn' - description: 'Maven selector to be used by shell scripts' + default: "/w/tools/hudson.tasks.Maven_MavenInstallation/{maven-version}/bin/mvn" + description: "Maven selector to be used by shell scripts" - scm: name: git-scm scm: - git: - credentials-id: 'opendaylight-jenkins-ssh' - url: '$GIT_BASE' - refspec: '' + credentials-id: "opendaylight-jenkins-ssh" + url: "$GIT_BASE" + refspec: "" branches: - - 'origin/{branch}' + - "origin/{branch}" skip-tag: true wipe-workspace: true @@ -158,11 +93,11 @@ name: git-scm-with-submodules scm: - git: - credentials-id: 'opendaylight-jenkins-ssh' - url: '$GIT_BASE' - refspec: '' + credentials-id: "opendaylight-jenkins-ssh" + url: "$GIT_BASE" + refspec: "" branches: - - 'refs/heads/{branch}' + - "refs/heads/{branch}" skip-tag: true wipe-workspace: true submodule: @@ -172,21 +107,13 @@ name: gerrit-trigger-scm scm: - git: - credentials-id: 'opendaylight-jenkins-ssh' - url: '$GIT_BASE' - refspec: '{refspec}' + credentials-id: "opendaylight-jenkins-ssh" + url: "$GIT_BASE" + refspec: "{refspec}" branches: - - 'origin/$GERRIT_BRANCH' + - "origin/$GERRIT_BRANCH" skip-tag: true - choosing-strategy: '{choosing-strategy}' - -- wrapper: - name: build-timeout - wrappers: - - timeout: - type: absolute - timeout: 360 - fail: true + choosing-strategy: "{choosing-strategy}" # This is a single macro to use for all jobs who vote on every (relevant) patch set. # Only 'recheck' trigger word is supported, it always triggers the full set of relevant jobs, @@ -200,7 +127,7 @@ name: gerrit-trigger-patch-submitted triggers: - gerrit: - server-name: '{gerrit-server-name}' + server-name: "{gerrit-server-name}" trigger-on: - patchset-created-event: exclude-drafts: true @@ -208,33 +135,42 @@ exclude-no-code-change: false - draft-published-event - comment-added-contains-event: - comment-contains-value: 'recheck$' + comment-contains-value: '^Patch Set[ ]+[0-9]+:([ ]+|[\n]+)(recheck|reverify)$' projects: - project-compare-type: ANT - project-pattern: '{project}' + project-pattern: "{project}" branches: - branch-compare-type: ANT - branch-pattern: '**/{branch}' + branch-pattern: "**/{branch}" file-paths: - compare-type: ANT - pattern: '{files}' + pattern: "{files}" + forbidden-file-paths: + - compare-type: REG_EXP + pattern: "{forbidden-files}" # TODO: Unify argument names across gerrit-trigger-* macros. - trigger: name: gerrit-trigger-patch-merged triggers: - gerrit: - server-name: '{gerrit-server-name}' + server-name: "{gerrit-server-name}" trigger-on: - change-merged-event - comment-added-contains-event: - comment-contains-value: 'remerge$' + comment-contains-value: "remerge$" projects: - - project-compare-type: 'ANT' - project-pattern: '{name}' + - project-compare-type: "ANT" + project-pattern: "{name}" branches: - - branch-compare-type: 'ANT' - branch-pattern: '**/{branch}' + - branch-compare-type: "ANT" + branch-pattern: "**/{branch}" + file-paths: + - compare-type: ANT + pattern: "{files}" + forbidden-file-paths: + - compare-type: REG_EXP + pattern: "{forbidden-files}" skip-vote: successful: true failed: true @@ -254,102 +190,30 @@ gerrit-build-unstable-codereview-value: 0 gerrit-build-notbuilt-codereview-value: 0 -# TODO: Unify argument names across gerrit-trigger-* macros. -- trigger: - name: gerrit-trigger-patch-sonar - triggers: - - gerrit: - server-name: '{gerrit-server-name}' - trigger-on: - - comment-added-contains-event: - comment-contains-value: 'run-sonar' - projects: - - project-compare-type: 'ANT' - project-pattern: '{name}' - branches: - - branch-compare-type: 'ANT' - branch-pattern: '**/master' - skip-vote: - successful: true - failed: true - unstable: true - notbuilt: true - - publisher: name: email-notification publishers: - email-ext: - recipients: '{email-recipients}' - reply-to: '' + recipients: "{email-recipients}" + reply-to: "" content-type: default - subject: '{email-prefix} $PROJECT_NAME - Build # $BUILD_NUMBER - $BUILD_STATUS!' + subject: "{email-prefix} $PROJECT_NAME - Build # $BUILD_NUMBER - $BUILD_STATUS!" body: | - $PROJECT_NAME - Build # $BUILD_NUMBER - $BUILD_STATUS: + $PROJECT_NAME - Build # $BUILD_NUMBER - $BUILD_STATUS: - Please refer to the logs server URL for console logs when possible - and use the Jenkins Build URL as a last resort. + Please refer to the logs server URL for console logs when possible + and use the Jenkins Build URL as a last resort. - Console Logs URL: - https://logs.opendaylight.org/$SILO/$JENKINS_HOSTNAME/$JOB_NAME/$BUILD_NUMBER + Console Logs URL: + https://s3-logs.opendaylight.org/logs/$SILO/$JENKINS_HOSTNAME/$JOB_NAME/$BUILD_NUMBER - Jenkins Build URL: - $BUILD_URL + Jenkins Build URL: + $BUILD_URL unstable: true fixed: true send-to: - recipients - -- builder: - # Installs the openstack cli into a virtualenv at /tmp/v/openstack - name: odl-openstack-install - builders: - - shell: !include-raw: odl-openstack-install.sh - -- builder: - name: odl-openstack-check-image-protection - builders: - - shell: !include-raw: odl-openstack-check-image-protection.sh - -- builder: - name: odl-openstack-cleanup-old-images - builders: - - shell: !include-raw: odl-openstack-cleanup-old-images.sh - -- builder: - name: odl-openstack-cleanup-orphaned-nodes - builders: - - shell: !include-raw: odl-openstack-cleanup-orphaned-nodes.sh - -- builder: - name: odl-openstack-cleanup-stale-nodes - builders: - - shell: !include-raw: odl-openstack-cleanup-stale-nodes.sh - -- builder: - name: odl-openstack-cleanup-stale-stacks - builders: - - shell: !include-raw: odl-openstack-cleanup-stale-stacks.sh - -- builder: - name: odl-openstack-cleanup-stale-volumes - builders: - - shell: !include-raw: odl-openstack-cleanup-stale-volumes.sh - -- builder: - # Deploys a maven site to Nexus using lftools nexus-zip command - name: opendaylight-infra-deploy-maven-site - builders: - - lf-provide-maven-settings: - global-settings-file: global-settings - settings-file: '{settings-file}' - - lf-infra-create-netrc: - server-id: opendaylight-site - - shell: !include-raw-escape: - - global-jjb/shell/lftools-install.sh - - opendaylight-infra-deploy-maven-site.sh - - lf-provide-maven-settings-cleanup - - builder: name: opendaylight-infra-stack # opendaylight-infra-stack.sh has a required variable {stack-template} that @@ -374,108 +238,12 @@ - builder: name: wipe-org-opendaylight-repo builders: - - shell: 'if [ -d /tmp/r/org/opendaylight ]; then rm -rf /tmp/r/org/opendaylight; fi' + - shell: "if [ -d /tmp/r/org/opendaylight ]; then rm -rf /tmp/r/org/opendaylight; fi" - builder: name: wipe-local-maven-repo builders: - - shell: 'if [ -d /tmp/r ]; then rm -rf /tmp/r; fi' - -- builder: - name: jacoco-nojava-workaround - builders: - - shell: 'mkdir -p $WORKSPACE/target/classes $WORKSPACE/jacoco/classes' - -- builder: - name: check-clm - builders: - - sonatype-clm: - application-name: '{application-name}' - -- builder: - name: releng-check-unicode - builders: - - shell: | - $WORKSPACE/scripts/check-unicode.sh jjb/ - -- builder: - name: provide-maven-settings - builders: - - config-file-provider: - files: - - file-id: '{global-settings-file}' - variable: 'GLOBAL_SETTINGS_FILE' - - file-id: '{settings-file}' - variable: 'SETTINGS_FILE' - -- builder: - name: releng-fetch-p2zip-if-necessary - builders: - - shell: | - # Cleanup any existing zips and metadata before we download the new update site - rm -f *.zip *.xml - - conditional-step: - condition-kind: strings-match - condition-string1: '$P2ZIP_URL' - condition-string2: '' - condition-basedir: workspace - steps: - # TODO: Figure out latest snapshot version number to pull rather than hardcoding 1.1.1-SNAPSHOT - - maven-target: - maven-version: '{maven-version}' - goals: > - org.apache.maven.plugins:maven-dependency-plugin:get - org.apache.maven.plugins:maven-dependency-plugin:copy - -V -B - -Dartifact=org.opendaylight.yangide:org.opendaylight.yangide.update-site:1.1.1-SNAPSHOT:zip - -DoutputDirectory=$WORKSPACE - settings: '{settings}' - global-settings: '{global-settings}' - -- builder: - name: releng-generate-p2pom - builders: - - shell: !include-raw: generate-p2pom.sh - -- builder: - name: releng-update-p2composite-metadata - builders: - - shell: !include-raw: update-p2composite-metadata.sh - - conditional-step: - condition-kind: file-exists - condition-filename: deploy-composite-repo.xml - condition-basedir: workspace - steps: - - maven-target: - maven-version: '{maven-version}' - pom: 'deploy-composite-repo.xml' - goals: 'clean deploy -V -B -Dmaven.repo.local=/tmp/r' - settings: '{settings}' - global-settings: '{global-settings}' - -- publisher: - name: releng-openstack-stack-delete - publishers: - - postbuildscript: - builders: - - role: BOTH - build-on: - - ABORTED - - FAILURE - - SUCCESS - - UNSTABLE - build-steps: - - shell: | - #!/bin/bash - echo "Deleting $STACK_NAME" - source "/tmp/v/openstack/bin/activate" - openstack stack delete --yes "$STACK_NAME" - mark-unstable-if-failed: false - -- builder: - name: releng-stage-release - builders: - - shell: !include-raw: stage-release.sh + - shell: "if [ -d /tmp/r ]; then rm -rf /tmp/r; fi" - wrapper: # This wrapper is required for all jobs as it configures the wrappers @@ -486,20 +254,20 @@ - config-file-provider: files: - file-id: npmrc - target: '$HOME/.npmrc' + target: "$HOME/.npmrc" - file-id: pipconf - target: '$HOME/.config/pip/pip.conf' + target: "$HOME/.config/pip/pip.conf" - file-id: clouds-yaml - target: '$HOME/.config/openstack/clouds.yaml' + target: "$HOME/.config/openstack/clouds.yaml" - timeout: type: absolute - timeout: '{build-timeout}' - timeout-var: 'BUILD_TIMEOUT' + timeout: "{build-timeout}" + timeout-var: "BUILD_TIMEOUT" fail: true - timestamps - ssh-agent-credentials: users: - - 'opendaylight-jenkins-ssh' + - "opendaylight-jenkins-ssh" - openstack: single-use: true @@ -516,5 +284,5 @@ - SUCCESS - UNSTABLE build-steps: - - shell: !include-raw: generate-csit-status-report.sh + - shell: !include-raw-escape: generate-csit-status-report.sh mark-unstable-if-failed: true