X-Git-Url: https://gerrit.linuxfoundation.org/infra/gitweb?a=blobdiff_plain;f=jjb%2Flf-macros.yaml;h=ba419c691df142406f4794b1ab0200d5e334a8d8;hb=961ef4327102f60f1d81e91b73027f032e144d6e;hp=5480f03128202da3ef9ef782f059b2d0289019b5;hpb=f2d509dec375118ad366e929930b0716132850c3;p=releng%2Fglobal-jjb.git diff --git a/jjb/lf-macros.yaml b/jjb/lf-macros.yaml index 5480f031..ba419c69 100644 --- a/jjb/lf-macros.yaml +++ b/jjb/lf-macros.yaml @@ -86,6 +86,19 @@ - shell: !include-raw: - ../shell/packer-clear-credentials.sh +- builder: + name: lf-infra-push-gerrit-patch + builders: + - inject: + properties-content: | + PROJECT='{project}' + GERRIT_COMMIT_MESSAGE='{gerrit-commit-message}' + GERRIT_HOST='{gerrit-host}' + GERRIT_TOPIC='{gerrit-topic}' + GERRIT_USER='{gerrit-user}' + REVIEWERS_EMAIL='{reviewers-email}' + - shell: !include-raw-escape: ../shell/gerrit-push-patch.sh + - builder: name: lf-infra-sysstat builders: @@ -137,6 +150,20 @@ - file-id: '{settings-file}' variable: 'SETTINGS_FILE' +- builder: + name: lf-provide-sigul-configuration + # Push configuration files to interact with sigul + builders: + - config-file-provider: + files: + - file-id: sigul-config + variable: SIGUL_CONFIG + - file-id: sigul-password + variable: SIGUL_PASSWORD + - file-id: sigul-pki + variable: SIGUL_PKI + - shell: !include-raw-escape: ../shell/sigul-configuration.sh + - builder: name: lf-pip-install builders: @@ -151,21 +178,29 @@ #!/bin/bash set +e # DO NOT cause build failure if any of the rm calls fail. - rm "$GLOBAL_SETTINGS_FILE" "$SETTINGS_FILE" + rm -f "$GLOBAL_SETTINGS_FILE" "$SETTINGS_FILE" # In some cases we use the lf-provide-maven-settings macro to produce # a "$HOME/.netrc" file containing credentials. Remove that file here # too if it exists. - rm "$HOME/.netrc" + rm -f "$HOME/.netrc" # DO NOT fail build if any of the above lines fail. exit 0 +- builder: + name: lf-provide-sigul-configuration-cleanup + # Clear sigul configuration files after we're done using them + builders: + - shell: !include-raw-escape: ../shell/sigul-configuration-cleanup.sh + - builder: name: lf-rtd-trigger-build builders: - inject: - properties-content: RTD_PROJECT={rtd-project} + properties-content: | + RTD_BUILD_URL={rtd-build-url} + RTD_TOKEN={rtd-token} - shell: !include-raw-escape: ../shell/rtd-trigger-build.sh - builder: @@ -177,6 +212,23 @@ - ../shell/tox-install.sh - ../shell/rtd-verify.sh +- builder: + name: lf-sigul-install + # Requires that Jenkins be configured with SIGUL_BRIDGE_IP as a global + # Environment variable + builder: + - shell: !include-raw-escape: ../shell/sigul-install.sh + +- builder: + name: lf-infra-provide-docker-cleanup + builders: + - shell: | + #!/bin/bash + set +e # DO NOT cause build failure if docker rmi fails + docker rmi -f $(docker images -a -q) + exit 0 + + ############## # PARAMETERS # ############## @@ -204,6 +256,7 @@ name: MVN # Sets an env var for shell scripts to be able to call the dynamically # installed maven without having to calculate the path themselves. + # yamllint disable-line rule:line-length default: '/w/tools/hudson.tasks.Maven_MavenInstallation/{mvn-version}/bin/mvn' description: 'Maven selector to be used by shell scripts' - string: @@ -236,9 +289,8 @@ name: PROJECT default: '{project}' description: | - Parameter to identify a Gerrit project. This is typically the - project repo path as exists in Gerrit. - For example: ofextensions/circuitsw + Parameter to identify a SCM project to build. This is typically + the project repo path. For example: ofextensions/circuitsw - string: name: STREAM default: '{stream}' @@ -250,28 +302,40 @@ name: GERRIT_PROJECT default: '{project}' description: | - Parameter to identify Gerrit project. This is typically the - project repo path as exists in Gerrit. - For example: ofextensions/circuitsw + Gerrit Trigger provided parameter to identify Gerrit project that + triggered the build. This is typically the project repo path as + exists in Gerrit. For example: ofextensions/circuitsw - Note that Gerrit will override this parameter automatically if a - job is triggered by Gerrit. + If using Gerrit, in a manual build this should match the PROJECT + parameter above. - string: name: GERRIT_BRANCH default: '{branch}' description: | - Parameter to identify a Gerrit branch. + Gerrit Trigger provided parameter to identify a Gerrit branch. - Note that Gerrit will override this parameter automatically if a - job is triggered by Gerrit. + If using Gerrit, in a manual build override with the branch to + build against. - string: name: GERRIT_REFSPEC default: 'refs/heads/{branch}' description: | - Parameter to identify a refspec when pulling from Gerrit. + Gerrit Trigger provided parameter to identify a refspec to fetch + from Gerrit. + + If using Gerrit, in a manual build override with a refspec. + https://git-scm.com/book/en/v2/Git-Internals-The-Refspec + For example: 'refs/heads/master' + - string: + name: sha1 + default: 'origin/{branch}' + description: | + GitHub PR Trigger provided parameter for specifying the commit + to checkout. - Note that Gerrit will override this parameter automatically if a - job is triggered by Gerrit. + If using GitHub, in a manual build override with a branch path or + sha1 hash to a specific commit. For example: 'origin/master' + # Tools - string: name: LFTOOLS_VERSION default: '{lftools-version}' @@ -333,6 +397,7 @@ exec-pattern: "**/**.exec" class-pattern: "**/classes" source-pattern: "**/src/main/java" + # yamllint disable-line rule:line-length exclusion-pattern: "**/gen/**,**/generated-sources/**,**/yang-gen**,**/pax/**" status-update: true targets: @@ -353,11 +418,17 @@ publishers: - postbuildscript: builders: - - lf-infra-sysstat - - lf-infra-ship-logs - script-only-if-succeeded: false - script-only-if-failed: false - mark-unstable-if-failed: false + - role: BOTH + build-on: + - ABORTED + - FAILURE + - NOT_BUILT + - SUCCESS + - UNSTABLE + build-steps: + - lf-infra-sysstat + - lf-infra-ship-logs + mark-unstable-if-failed: true - workspace-cleanup: exclude: # Do not clean up *.jenkins-trigger files for jobs that use a @@ -391,6 +462,8 @@ credentials-id: '{jenkins-ssh-credential}' url: '{url}' refspec: '{refspec}' + branches: + - '{branch}' skip-tag: true wipe-workspace: true submodule: @@ -439,3 +512,5 @@ files: - file-id: npmrc target: '$HOME/.npmrc' + - file-id: pipconf + target: '$HOME/.config/pip/pip.conf'