X-Git-Url: https://gerrit.linuxfoundation.org/infra/gitweb?a=blobdiff_plain;f=jjb%2Flf-macros.yaml;h=11a827de989176da9e04d0522bd0e7e298a5bcfa;hb=c3150dcea8069e284ec52bf487541576a62687ab;hp=d0f596b4045946b05e580bfc424931624ac6b8f1;hpb=10821edc619b09e4623884b02900c39431f8a809;p=releng%2Fglobal-jjb.git diff --git a/jjb/lf-macros.yaml b/jjb/lf-macros.yaml index d0f596b4..11a827de 100644 --- a/jjb/lf-macros.yaml +++ b/jjb/lf-macros.yaml @@ -3,11 +3,15 @@ # BUILDERS # ############ +- builder: + name: lf-fetch-dependent-patches + builders: + - shell: !include-raw: ../shell/gerrit-fetch-dependencies.sh + - inject: + properties-file: $WORKSPACE/.dependency.properties + - builder: name: lf-infra-create-netrc - # Macro to create a ~/.netrc file from a Maven settings.xml - # Parameters: - # {server-id} The id of a server as defined in settings.xml builders: - inject: properties-content: 'SERVER_ID={server-id}' @@ -15,25 +19,6 @@ - builder: name: lf-infra-docker-login - # Login into a custom hosted docker registry and / or docker.io - # - # The Jenkins system should have the following global variables defined - # - # DOCKER_REGISTRY : Optional - # The DNS address of the registry (IP or FQDN) - # ex: nexus3.example.com - # - # REGISTRY_PORTS : Required if DOCKER_REGISTRY is set - # Space separated listing of the registry ports to login - # to - # ex: 10001 10002 10003 10004 - # - # DOCKERHUB_EMAIL : Optional - # If this variable is set then an attempt to login to - # DockerHub (docker.io) will be also made. It should be - # set to the email address for the credentials that will - # get looked up. Only _one_ credential will ever be found - # in the maven settings file for DockerHub builders: - lf-provide-maven-settings: global-settings-file: '{global-settings-file}' @@ -43,10 +28,6 @@ - builder: name: lf-infra-gpg-verify-git-signature - # Verify gpg signature of the latest commit message in $WORKSPACE - # - # This command assumes that $WORKSPACE is a git repo. - # # 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 @@ -76,10 +57,8 @@ builders: - config-file-provider: files: - - file-id: '{os-cloud-file-id}' - target: '$HOME/.config/openstack/clouds.yaml' - - file-id: 'packer-cloud-env' - variable: 'CLOUDENV' + - file-id: '{packer-cloud-settings}' + variable: CLOUDENV - inject: properties-content: | PACKER_PLATFORM={platform} @@ -96,9 +75,7 @@ builders: - config-file-provider: files: - - file-id: '{os-cloud-file-id}' - target: '$HOME/.config/openstack/clouds.yaml' - - file-id: 'packer-cloud-env' + - file-id: '{packer-cloud-settings}' variable: 'CLOUDENV' - inject: properties-content: | @@ -109,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: @@ -122,12 +112,6 @@ - builder: name: lf-infra-deploy-maven-file - # Deploy files to a repository. - # - # The builder requires passing the following parameters - # REPO_ID: Repository ID - # GROUP_ID: Group ID of the repository - # UPLOAD_FILES_PATH: Path to directory containing one or more files builders: - lf-maven-install: mvn-version: '{mvn-version}' @@ -136,18 +120,18 @@ settings-file: '{settings-file}' - inject: properties-content: | + MAVEN_REPO_URL={maven-repo-url} REPO_ID={repo-id} GROUP_ID={group-id} - UPLOAD_FILES_PATH={files-dir} + UPLOAD_FILES_PATH={upload-files-dir} - shell: !include-raw-escape: - ../shell/lftools-install.sh + - ../shell/common-variables.sh - ../shell/deploy-maven-file.sh - lf-provide-maven-settings-cleanup - builder: name: lf-maven-install - # call maven-target builder with a goal of --version to force Jenkins to - # install the needed maven version builders: # Create a $HOME/.wgetrc to make the Maven download quiet. - shell: 'echo "quiet=on" > "$HOME/.wgetrc"' @@ -158,7 +142,6 @@ - builder: name: lf-provide-maven-settings - # Push a global settings and user settings maven files builders: - config-file-provider: files: @@ -167,24 +150,75 @@ - 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: + - inject: + properties-content: PIP_PACKAGES={pip-packages} + - shell: !include-raw-escape: ../shell/pip-install.sh + - builder: name: lf-provide-maven-settings-cleanup - # Clear maven settings files after we are done using them builders: - shell: | #!/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_BUILD_URL={rtd-build-url} + RTD_TOKEN={rtd-token} + - shell: !include-raw-escape: ../shell/rtd-trigger-build.sh + +- builder: + name: lf-rtd-verify + builders: + - inject: + properties-content: DOC_DIR={doc-dir} + - shell: !include-raw-escape: + - ../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 + ############## # PARAMETERS # ############## @@ -192,6 +226,12 @@ - parameter: name: lf-infra-maven-parameters parameters: + - string: + name: M2_HOME + # Sets an env var for shell scripts to be able to call the dynamically + # installed maven without having to calculate the M2_HOME themselves. + default: '/w/tools/hudson.tasks.Maven_MavenInstallation/{mvn-version}' + description: 'Maven selector to be used by shell scripts' - string: name: MAVEN_OPTS default: '{mvn-opts}' @@ -206,6 +246,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: @@ -268,18 +309,35 @@ job is triggered by Gerrit. - string: name: GERRIT_REFSPEC - default: '' + default: 'refs/heads/{branch}' description: | Parameter to identify a refspec when pulling from Gerrit. Note that Gerrit will override this parameter automatically if a job is triggered by Gerrit. + - string: + name: LFTOOLS_VERSION + default: '{lftools-version}' + description: | + Version of lftools to install. Can be a specific version like + '0.6.0' or a PEP-440 definition. + https://www.python.org/dev/peps/pep-0440/ + For example '<1.0.0' or '>=1.0.0,<2.0.0'. +- parameter: + name: lf-infra-node-parameters + parameters: + - string: + name: NODE_DIR + default: '{node-dir}' + description: Path to a Node project directory. + - string: + name: NODE_VERSION + default: '{node-version}' + description: Version of NodeJS to install. - parameter: name: lf-infra-tox-parameters - # Useful parameters when working with TOX - # https://tox.readthedocs.io/ parameters: - string: name: TOX_DIR @@ -311,6 +369,24 @@ # PUBLISHERS # ############## +- publisher: + name: lf-jacoco-report + publishers: + - jacoco: + 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: + - branch: + healthy: 10 + unhealthy: 20 + - method: + healthy: 50 + unhealthy: 40 + - publisher: name: lf-infra-publish # lf-infra macro to finish up a build. @@ -321,11 +397,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 @@ -359,6 +441,8 @@ credentials-id: '{jenkins-ssh-credential}' url: '{url}' refspec: '{refspec}' + branches: + - '{branch}' skip-tag: true wipe-workspace: true submodule: @@ -403,3 +487,9 @@ - '{jenkins-ssh-credential}' - openstack: single-use: true + - config-file-provider: + files: + - file-id: npmrc + target: '$HOME/.npmrc' + - file-id: pipconf + target: '$HOME/.config/pip/pip.conf'