X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=jjb%2Freleng-macros.yaml;h=7c0a9164318df0009cc234580f8e560e593c383e;hb=93a5304ef04620630cbd6de14694607048bf2aa3;hp=72e3a83443c5126291ae047fe0dd5b0ae8c8966f;hpb=d0c99aec12d4cf16f0c117ca4e2af49d0512e974;p=releng%2Fbuilder.git diff --git a/jjb/releng-macros.yaml b/jjb/releng-macros.yaml index 72e3a8344..7c0a91643 100644 --- a/jjb/releng-macros.yaml +++ b/jjb/releng-macros.yaml @@ -21,12 +21,14 @@ 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 - **/*.hprof + # TODO: **/*.hprof is too large, compress with xz first description: 'Space separated glob patterns for artifacts to archive into logs.opendaylight.org' - string: name: GERRIT_PROJECT @@ -39,7 +41,10 @@ - string: name: GERRIT_REFSPEC default: '{refspec}' - description: "GERRIT_REFSPEC parameter if not given by trigger" + 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) - string: name: STACK_NAME default: '$SILO-$JOB_NAME-$BUILD_NUMBER' @@ -55,35 +60,37 @@ https://docs.openstack.org/developer/python-openstackclient/ - parameter: - name: build-tag + name: patches-to-build-parameter parameters: - string: - name: BUILD_TAG + name: PATCHES_TO_BUILD default: '' - description: 'Tag in Git to checkout' + 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: controller-version-parameter + name: build-order-parameter parameters: - string: - name: ODL_VERSION - default: '{odl_version}' - description: 'Controller version (for use with openstacks networking_odl project)' + name: BUILD_ORDER + default: '{build-order}' + description: 'Build order for multipatch test when topic is used' - parameter: - name: patches-to-build-parameter + name: build-fast-parameter parameters: - string: - name: PATCHES_TO_BUILD - default: '' - description: | - Patches to add to distro in CSV project:changeset format (genius:32/53632/9,netvirt:59/50259/47) + name: BUILD_FAST + default: '{build-fast}' + description: 'Set true to build fast -Pq' - parameter: name: run-test-parameter parameters: - string: - name: RUNTEST + name: RUN_TEST default: '{run-test}' description: 'Set true to run test after build' @@ -95,22 +102,6 @@ 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' - - parameter: name: maven-exec parameters: @@ -157,19 +148,11 @@ skip-tag: true choosing-strategy: '{choosing-strategy}' -- wrapper: - name: build-timeout - wrappers: - - timeout: - type: absolute - timeout: 360 - fail: true - # 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, # in order to prevent Jenkins from starting only a subset and still voting Verified+1. # Arguments: -# server: name of gerrit server to listen to +# gerrit-server-name: name of gerrit server to listen to # project: pattern to match triggering projects # branch: triggering branch name # files: pattern to match triggering filepaths @@ -177,7 +160,7 @@ name: gerrit-trigger-patch-submitted triggers: - gerrit: - server-name: '{server}' + server-name: '{gerrit-server-name}' trigger-on: - patchset-created-event: exclude-drafts: true @@ -185,7 +168,7 @@ 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}' @@ -195,23 +178,32 @@ file-paths: - compare-type: ANT pattern: '{files}' + forbidden-file-paths: + - compare-type: ANT + pattern: '{forbidden-files}' # TODO: Unify argument names across gerrit-trigger-* macros. - trigger: name: gerrit-trigger-patch-merged triggers: - gerrit: - server-name: '{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}' branches: - branch-compare-type: 'ANT' branch-pattern: '**/{branch}' + file-paths: + - compare-type: ANT + pattern: '{files}' + forbidden-file-paths: + - compare-type: ANT + pattern: '{forbidden-files}' skip-vote: successful: true failed: true @@ -231,36 +223,6 @@ 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: '{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: archive-artifacts - publishers: - - archive: - artifacts: '{artifacts}' - allow-empty: true - fingerprint: true - latest-only: true - - publisher: name: email-notification publishers: @@ -285,23 +247,6 @@ send-to: - recipients -- publisher: - name: jacoco-report - publishers: - - jacoco: - exec-pattern: "**/**.exec" - class-pattern: "**/classes" - source-pattern: "**/src/main/java" - exclusion-pattern: "**/gen/**,**/generated-sources/**,**/yang-gen**,**/pax/**" - status-update: true - targets: - - branch: - healthy: 10 - unhealthy: 20 - - method: - healthy: 50 - unhealthy: 40 - - builder: name: opendaylight-infra-stack # opendaylight-infra-stack.sh has a required variable {stack-template} that @@ -311,22 +256,11 @@ - shell: !include-raw-escape: opendaylight-infra-copy-ssh-keys.sh - builder: - name: opendaylight-infra-push-gerrit-patch - # opendaylight-infra-push-gerrit-patch.sh allows a job to push a patch to - # Gerrit in an automated fashion. This is meant for tasks that creates - # the same patch regularly and needs the ability to detect if an unreviewed - # patch already exists. In which case it will update the existing patch. - # - # Note: This patch assumes the $WORKSPACE contains the project repo with - # the files changed already "git add" and waiting for a "git commit" call. - # - # This script requires the following JJB variables to be passed in: - # {project} Gerrit project-name - # {gerrit-topic} Gerrit topic, please make a unique topic. - # {gerrit-commit-message} Commit message to assign to commit. - # NOTE: Requires git review to be installed on node. + name: opendaylight-apex-stack + # opendaylight-apex-stack.sh has a required variable {stack-template} that + # must be passed into this macro. builders: - - shell: !include-raw: opendaylight-infra-push-gerrit-patch.sh + - shell: !include-raw: opendaylight-infra-stack.sh - builder: name: distribute-build-url @@ -351,82 +285,23 @@ 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: include-raw-generate-p2pom.sh - -- builder: - name: releng-update-p2composite-metadata - builders: - - shell: !include-raw: 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}' - -- builder: - name: releng-stage-release - builders: - - shell: !include-raw: include-raw-stage-release.sh +- publisher: + name: releng-openstack-stack-delete + publishers: + - postbuildscript: + builders: + - role: BOTH + build-on: + - ABORTED + - FAILURE + - SUCCESS + - UNSTABLE + build-steps: + - shell: | + #!/bin/bash -l + echo "Deleting $STACK_NAME" + openstack stack delete --yes "$STACK_NAME" + mark-unstable-if-failed: false - wrapper: # This wrapper is required for all jobs as it configures the wrappers @@ -438,7 +313,9 @@ files: - file-id: npmrc target: '$HOME/.npmrc' - - file-id: rackspace-heat + - file-id: pipconf + target: '$HOME/.config/pip/pip.conf' + - file-id: clouds-yaml target: '$HOME/.config/openstack/clouds.yaml' - timeout: type: absolute @@ -452,234 +329,18 @@ - openstack: single-use: true -- builder: - name: packer-validate - builders: - - config-file-provider: - files: - - file-id: 'packer-cloud-env' - variable: 'CLOUDENV' - - shell: | - cd packer - varfiles="../packer/vars/*" - templates="../packer/templates/*" - provision="../packer/provision/*.sh" - for v in $varfiles; do - [[ "${v##*/}" =~ ^(cloud-env.*)$ ]] && continue - for t in $templates; do - export PACKER_LOG="yes" && \ - export PACKER_LOG_PATH="packer-validate-${v##*/}-${t##*/}.log" && \ - packer.io validate -var-file=$CLOUDENV \ - -var-file=$v $t - if [ $? -ne 0 ]; then - break - fi - done - done - for p in $provision; do - /bin/bash -n $p > provision-validate-${p##*/}.log 2>&1 - done - - -- builder: - name: packer-build - builders: - - config-file-provider: - files: - - file-id: 'packer-cloud-env' - variable: 'CLOUDENV' - - shell: | - cd packer - export PACKER_LOG="yes" && \ - export PACKER_LOG_PATH="packer-build.log" && \ - packer.io build -color=false -var-file=$CLOUDENV \ - -var-file=../packer/vars/{platform}.json \ - -parallel=false \ - ../packer/templates/{template}.json - -- builder: - # TODO: Verify signature after downloading users public key from a locally created - # repository instead of the public keymesh. This requires a process in place to get ODL - # developers public keys into a local repository without increasing the job thoughput. - name: verify-gpg-signature - builders: - - shell: !include-raw: include-raw-verify-gpg-signatures.sh - -- builder: - name: opendaylight-infra-jjbini - builders: - - config-file-provider: - files: - - file-id: 'jjbini' - target: '$HOME/.config/jenkins_jobs/jenkins_jobs.ini' - -- builder: - name: distribution-check-wipe - # Step zero: Wipe file repositories up front. - builders: - - shell: | - echo "wipe r: the local Maven repository" - rm -rfv /tmp/r - echo "wipe n: the fake remote (Nexus) repository" - rm -rfv /tmp/n - echo "wipe t: the transient repository used in some manipulations" - rm -rfv /tmp/t - -- builder: - name: distribution-check-build-project - # Step one: Online build of the project, using local repository /tmp/r/ and deploying artifacts to /tmp/n/. - # Ordinary SingleFeatureTest failures are detected in the verify job, so we can use "q" profile here. - # Arguments: - # pom: Relative path to pom file to use. Typically '$GERRIT_PROJECT/pom.xml'. - builders: - - maven-target: - maven-version: 'mvn33' - pom: '{pom}' - goals: | - clean deploy dependency:tree - -DoutputFile=dependency_tree.txt - -Pq - -DaltDeploymentRepository=fake-nexus::default::file:///tmp/n/ - {mvn-opts} - java-opts: - - '-Xmx4096m -XX:MaxPermSize=1024m -Dmaven.compile.fork=true' - settings: 'integration-settings' - settings-type: cfp - global-settings: 'odl-global-settings' - global-settings-type: cfp - -- builder: - name: distribution-check-verify-groupid - # Step two: Verify all deployed artifacts belong to the project's groupId. - # This is done by moving the allowed directories out of /tmp/n and checking no files remained there. - # The correct directory is derived from $GERRIT_PROJECT. - # TODO: Verify all deployed artifacts are snapshots. - # Arguments: - # gerrit-project: Project name as nexus URI part. Typically '$GERRIT_PROJECT'. - builders: - - shell: | - mkdir -p /tmp/t/org/opendaylight/{gerrit-project} - mv /tmp/n/org/opendaylight/{gerrit-project}/* /tmp/t/org/opendaylight/{gerrit-project}/ - test -z "`find /tmp/n/ -type f`" || ( echo "ERROR: Mismatched groupId detected (see above)." && false ) - rm -rf /tmp/n - mv /tmp/t /tmp/n - -- builder: - name: distribution-check-download-deps - # Step three: Online build of integration distribution. - # This step is mainly used for downloading other project artifacts. - # Running SingleFeaturesTest here does not seem to be required, so -Pq is used again. - # Arguments: - # dist-pom: Relative path to pom file to use. 'distribution/pom.xml' is recommended. - builders: - - maven-target: - maven-version: 'mvn33' - pom: '{dist-pom}' - goals: | - clean install dependency:tree - -DoutputFile=dependency_tree.txt - -Pq - {mvn-opts} - java-opts: - - '-Xmx1024m -XX:MaxPermSize=256m -Dmaven.compile.fork=true' - settings: 'integration-settings' - settings-type: cfp - global-settings: 'odl-global-settings' - global-settings-type: cfp - -- builder: - name: distribution-check-delete-snapshots - # Step four: Delete snapshot artifacts from the local repository. - # This is critical to detect orphaned artifacts or missing project-internal dependency declarations. - # Also other files related to maven repository resolution are removed, - # and then empty directories are removed, in order to simplify debugging. - builders: - - shell: !include-raw-escape: integration-distribution-delete-snaphot-artifacts.sh - -- builder: - name: distribution-check-configure-remotes - # Now the ugly part. It seems that the only way to tell Maven 2+ - # which remote repositories to use is via settings.xml file. - # So we create such a file here, but it needs most of odlparent:settings.xml - builders: - - shell: | - echo ' - - - - opendaylight-release - - - opendaylight-mirror - opendaylight - https://nexus.opendaylight.org/content/repositories/public/ - never - false - - - - - opendaylight-plugin-mirror - opendaylight-plugin - https://nexus.opendaylight.org/content/repositories/public/ - never - false - - - - - file-snapshots - - - file-snapshots - file - file:///tmp/n/ - false - - - - - file-plugin-snapshots - file-plugin - file:///tmp/n/ - false - - - - - - file-snapshots - opendaylight-release - - - ' > fake_remotes.xml - # Notes: The settings are minimal in order to detect breakage scenarios, - # while allowing for the following quirks: - # * Some plugins seem to have hardcoded repos, for example check-license looks at repository.apache.org - # * Some plugin artifacts (related to surefire) are not downloaded when tests are skipped. - # * populate-local-repo looks at oss.sonatype.org and does not store things (like guava) to /tmp/r - -- builder: - name: distribution-check-repeat-build - # Step five: Repeat the distribution build but with the new settings. - # Here, only the project snapshot artifacts deployed to /tmp/n are available, - # which faithfully reproduces conditions in later verify-like job runs. - # We cannot use --offline, because: "Cannot access file (file:///tmp/n) in offline mode" - # This is where SingleFeatureTest is not skipped. - # Arguments: - # dist-pom: Relative path to pom file to use. 'distribution/pom.xml' is recommended. - builders: - - maven-target: - maven-version: 'mvn33' - pom: '{dist-pom}' - goals: | - clean install dependency:tree - -DoutputFile=dependency_tree.txt -s fake_remotes.xml - -Pq - -DskipTests=false - {mvn-opts} - java-opts: - - '-Xmx1024m -XX:MaxPermSize=256m -Dmaven.compile.fork=true' +- publisher: + name: opendaylight-infra-generate-csit-status-report + publishers: + - postbuildscript: + builders: + - role: BOTH + build-on: + - ABORTED + - FAILURE + - NOT_BUILT + - SUCCESS + - UNSTABLE + build-steps: + - shell: !include-raw: generate-csit-status-report.sh + mark-unstable-if-failed: true