# BUILDERS #
############
+# To take advantage of this macro, have your build write
+# out the file 'gerrit_comment.txt' with information to post
+# back to gerrit and include this macro in the list of builders.
+- builder:
+ name: comment-to-gerrit
+ builders:
+ - shell: !include-raw: ../shell/comment-to-gerrit.sh
+
+- builder:
+ name: lf-ansible-config-file-provider
+ builders:
+ - config-file-provider:
+ files:
+ - file-id: "ansible-cfg"
+ target: "$HOME/.ansible/ansible.cfg"
+
+- builder:
+ name: lf-fetch-dependent-patches
+ builders:
+ - shell: !include-raw-escape: ../shell/gerrit-fetch-dependencies.sh
+ - inject:
+ properties-file: $WORKSPACE/.dependency.properties
+
+- builder:
+ name: lf-license-check
+ builders:
+ - inject:
+ properties-content: |
+ FILE_PATTERNS={file-patterns}
+ SPDX_DISABLE={spdx-disable}
+ LHC_VERSION={lhc-version}
+ LICENSE_EXCLUDE_PATHS={license-exclude-paths}
+ LICENSES_ALLOWED={licenses-allowed}
+ - shell: !include-raw-escape:
+ - ../shell/license-check.sh
+
+- builder:
+ name: lf-infra-capture-instance-metadata
+ builders:
+ - shell: !include-raw-escape:
+ - ../shell/capture-instance-metadata.sh
+
- 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}'
+ properties-content: "SERVER_ID={server-id}"
- shell: !include-raw-escape: ../shell/create-netrc.sh
- 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}'
- settings-file: '{settings-file}'
+ global-settings-file: "{global-settings-file}"
+ settings-file: "{settings-file}"
- shell: !include-raw-escape: ../shell/docker-login.sh
- lf-provide-maven-settings-cleanup
- 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
builders:
- shell: !include-raw: ../shell/gpg-verify-git-signature.sh
+- builder:
+ name: lf-infra-pre-build
+ builders:
+ - shell: !include-raw-escape: ../shell/python-tools-install.sh
+
- builder:
name: lf-infra-ship-logs
builders:
+ # Ensure no pre-existing .netrc files are overriding logs config
+ - lf-provide-maven-settings-cleanup
- config-file-provider:
files:
- - file-id: 'jenkins-log-archives-settings'
- variable: 'SETTINGS_FILE'
+ - file-id: "jenkins-log-archives-settings"
+ variable: "SETTINGS_FILE"
+ - conditional-step:
+ condition-kind: regex-match
+ regex: "^.*logs-s3.*"
+ label: $S3_BUCKET
+ on-evaluation-failure: dont-run
+ steps:
+ - config-file-provider:
+ files:
+ - file-id: "jenkins-s3-log-ship"
+ target: $HOME/.aws/credentials
- lf-infra-create-netrc:
server-id: logs
- shell: !include-raw:
- - ../shell/lftools-install.sh
+ # Ensure python-tools are installed in case job template does not
+ # call the lf-infra-pre-build macro.
+ - ../shell/python-tools-install.sh
+ - shell: !include-raw-escape:
+ - ../shell/sudo-logs.sh
+ - shell: !include-raw-escape:
+ - ../shell/job-cost.sh
+ - shell: !include-raw-escape:
- ../shell/logs-deploy.sh
- shell: !include-raw:
- ../shell/logs-clear-credentials.sh
- description-setter:
- regexp: '^Build logs: .*'
+ regexp: "(^(Nexus|S3) build logs: .*)"
+
+- builder:
+ name: lf-infra-package-listing
+ builders:
+ - shell: !include-raw-escape:
+ - ../shell/package-listing.sh
- builder:
name: lf-infra-packer-build
builders:
+ - lf-ansible-config-file-provider
+ - conditional-step:
+ condition-kind: boolean-expression
+ condition-expression: "{openstack}"
+ steps:
+ - config-file-provider:
+ files:
+ - file-id: clouds-yaml
+ target: "$HOME/.config/openstack/clouds.yaml"
+ - inject:
+ properties-content: OS_CLOUD={openstack-cloud}
- config-file-provider:
files:
- - file-id: '{packer-cloud-settings}'
+ - file-id: "{packer-cloud-settings}"
+ target: "$HOME/.config/jenkins_jobs/cloud-env.pkrvars.hcl"
variable: CLOUDENV
- inject:
properties-content: |
- PACKER_PLATFORM={platform}
- PACKER_TEMPLATE={template}
- PACKER_VERSION={packer-version}
+ PACKER_BUILDER={packer-builder}
+ PACKER_PLATFORM={platform}
+ PACKER_TEMPLATE={template}
+ PACKER_VERSION={packer-version}
+ UPDATE_CLOUD_IMAGE={update-cloud-image}
- shell: !include-raw-escape:
- ../shell/packer-install.sh
- ../shell/packer-build.sh
- builder:
name: lf-infra-packer-validate
builders:
+ - conditional-step:
+ condition-kind: boolean-expression
+ condition-expression: "{openstack}"
+ steps:
+ - config-file-provider:
+ files:
+ - file-id: clouds-yaml
+ target: "$HOME/.config/openstack/clouds.yaml"
+ - inject:
+ properties-content: OS_CLOUD={openstack-cloud}
- config-file-provider:
files:
- - file-id: '{packer-cloud-settings}'
- variable: 'CLOUDENV'
+ - file-id: "{packer-cloud-settings}"
+ target: "$HOME/.config/jenkins_jobs/cloud-env.pkrvars.hcl"
+ variable: CLOUDENV
- inject:
properties-content: |
- PACKER_VERSION={packer-version}
+ PACKER_VERSION={packer-version}
- shell: !include-raw-escape:
- ../shell/packer-install.sh
- ../shell/packer-validate.sh
- shell: !include-raw:
- ../shell/packer-clear-credentials.sh
+- builder:
+ name: lf-infra-update-packer-images
+ builders:
+ - shell: !include-raw-escape: ../shell/update-cloud-images.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:
- - shell: !include-raw:
+ - shell: !include-raw-escape:
- ../shell/sysstat.sh
- builder:
name: lf-jacoco-nojava-workaround
builders:
- - shell: 'mkdir -p $WORKSPACE/target/classes $WORKSPACE/jacoco/classes'
+ - shell: "mkdir -p $WORKSPACE/target/classes $WORKSPACE/jacoco/classes"
- 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}'
+ mvn-version: "{mvn-version}"
- lf-provide-maven-settings:
- global-settings-file: '{global-settings-file}'
- settings-file: '{settings-file}'
+ global-settings-file: "{global-settings-file}"
+ settings-file: "{settings-file}"
- inject:
properties-content: |
- MAVEN_REPO_URL={maven-repo-url}
- REPO_ID={repo-id}
- GROUP_ID={group-id}
- UPLOAD_FILES_PATH={upload-files-dir}
+ MAVEN_REPO_URL={maven-repo-url}
+ REPO_ID={repo-id}
+ GROUP_ID={group-id}
+ 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-central
+ builders:
+ - conditional-step:
+ condition-kind: boolean-expression
+ condition-expression: "{mvn-central}"
+ steps:
+ - lf-provide-maven-settings:
+ global-settings-file: "{mvn-global-settings}"
+ settings-file: "{mvn-settings}"
+ - lf-infra-create-netrc:
+ server-id: "ossrh"
+ - inject:
+ properties-content: "OSSRH_PROFILE_ID={ossrh-profile-id}"
+ - shell: !include-raw-escape: ../shell/maven-central.sh
+ - lf-provide-maven-settings-cleanup
+
+- builder:
+ name: lf-packagecloud-file-provider
+ builders:
+ - config-file-provider:
+ files:
+ - file-id: ".packagecloud"
+ target: "$HOME/.packagecloud"
+ - config-file-provider:
+ files:
+ - file-id: "packagecloud_api"
+ target: "$HOME/packagecloud_api"
+
+- builder:
+ name: lf-packagecloud-push
+ builders:
+ - inject:
+ properties-content: |
+ BUILD_DIR={build-dir}
+ PACKAGECLOUD_ACCOUNT={packagecloud-account}
+ PACKAGECLOUD_REPO={packagecloud-repo}
+ DEBIAN_DISTRIBUTION_VERSIONS={debian-distribution-versions}
+ RPM_DISTRIBUTION_VERSIONS={rpm-distribution-versions}
+ - shell: !include-raw-escape: ../shell/packagecloud-push.sh
+
- 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"'
- maven-target:
- maven-version: '{mvn-version}'
- goals: '--version'
+ maven-version: "{mvn-version}"
+ goals: "--version"
- shell: 'rm "$HOME/.wgetrc"'
- builder:
name: lf-provide-maven-settings
- # Push a global settings and user settings maven files
builders:
- config-file-provider:
files:
- - file-id: '{global-settings-file}'
- variable: 'GLOBAL_SETTINGS_FILE'
- - file-id: '{settings-file}'
- variable: 'SETTINGS_FILE'
+ - file-id: "{global-settings-file}"
+ variable: "GLOBAL_SETTINGS_FILE"
+ - file-id: "{settings-file}"
+ variable: "SETTINGS_FILE"
- 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-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}
+ PYTHON={python-version}
+ - shell: !include-raw-escape: ../shell/tox-install.sh
+ - shell: !include-raw-escape: ../shell/rtd-verify.sh
+
+- builder:
+ name: lf-rtdv3-build
+ builders:
+ - inject:
+ properties-content: |
+ DEFAULT_VERSION={default-version}
+ - shell: !include-raw-escape: ../shell/rtdv3.sh
+
+- builder:
+ name: check-info-votes
+ builders:
+ - inject:
+ properties-content: JENKINS_SSH_CREDENTIAL={jenkins-ssh-credential}
+ - shell: !include-raw-escape: ../shell/check-info-votes.sh
+
+- builder:
+ name: lf-release
+ builders:
+ - config-file-provider:
+ files:
+ - file-id: lftoolsini
+ target: "$HOME/.config/lftools/lftools.ini"
+ - shell: !include-raw-escape: ../shell/release-job.sh
+
+- builder:
+ name: lf-sigul-sign-dir
+ # Requires that Jenkins be configured with SIGUL_BRIDGE_IP as a global
+ # Environment variable
+ builders:
+ - conditional-step:
+ condition-kind: boolean-expression
+ condition-expression: "{sign-artifacts}"
+ steps:
+ - 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
+ - shell: !include-raw-escape: ../shell/sigul-install.sh
+ - inject:
+ properties-content: |
+ SIGN_DIR={sign-dir}
+ SIGN_MODE={sign-mode}
+ - shell: !include-raw-escape:
+ - ../shell/sigul-sign-dir.sh
+ - shell: !include-raw-escape: ../shell/sigul-configuration-cleanup.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
+
+- builder:
+ name: lf-infra-sonar
+ # Run a Sonar Jenkins Plugin
+ builders:
+ - sonar:
+ sonar-name: Sonar
+ scanner-name: SonarQubeScanner
+ task: "{sonar-task}"
+ project: "{sonar-project-file}"
+ properties: "{sonar-properties}"
+ java-opts: "{sonar-java-opts}"
+ additional-arguments: "{sonar-additional-args}"
+ jdk: "{sonar-jdk}"
+
+- builder:
+ name: lf-infra-sonar-with-prescan
+ # Run a Sonar Jenkins Plugin
+ builders:
+ - lf-sonar-prescan # Must be defined by caller
+ - sonar:
+ sonar-name: Sonar
+ scanner-name: SonarQubeScanner
+ task: "{sonar-task}"
+ project: "{sonar-project-file}"
+ properties: "{sonar-properties}"
+ java-opts: "{sonar-java-opts}"
+ additional-arguments: "{sonar-additional-args}"
+
+- builder:
+ name: lf-infra-pipeline-verify
+ builders:
+ - shell: !include-raw-escape: ../shell/pipeline-linter.sh
+
##############
# PARAMETERS #
##############
+- parameter:
+ name: lf-autotools-parameters
+ # Parameters for configure-make builds.
+ parameters:
+ - string:
+ name: CONFIGURE_OPTS
+ default: "{configure-opts}"
+ description: |
+ Options to pass to configure.
+ Example: --build=i686-pc-linux-gnu
+ - string:
+ name: INSTALL_PREFIX
+ default: "{install-prefix}"
+ description: |
+ Install prefix for configure.
+ Usually a workspace subdirectory.
+ - string:
+ name: MAKE_OPTS
+ default: "{make-opts}"
+ description: |
+ Options to pass to make.
+ Example: -j8 all
+
+- parameter:
+ name: lf-clm-parameters
+ parameters:
+ - string:
+ name: NEXUS_IQ_STAGE
+ default: "{nexus-iq-stage}"
+ description: |
+ Stage the policy evaluation will be run against on the Nexus IQ Server.
+
+- parameter:
+ name: lf-cmake-parameters
+ # Parameters useful in CMake builds.
+ parameters:
+ - string:
+ name: BUILD_DIR
+ default: "{build-dir}"
+ description: "Directory to build the project in."
+ - string:
+ name: CMAKE_OPTS
+ default: "{cmake-opts}"
+ description: |
+ Options to pass to CMAKE.
+ Example: -DCMAKE_INSTALL_PREFIX=$WORKSPACE/target/output
+ - string:
+ name: INSTALL_PREFIX
+ default: "{install-prefix}"
+ description: "Install prefix for C/C++ builds. Example: /usr/local"
+ - string:
+ name: MAKE_OPTS
+ default: "{make-opts}"
+ description: "Options to pass to make. Example: -j8"
+
- 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}'
+ default: "{mvn-opts}"
description: |
- Maven Java opts. Example: -Xmx1024m -XX:MaxPermSize=256m
+ Maven Java opts. Example: -Xmx1024m -XX:MaxPermSize=256m
- string:
name: MAVEN_PARAMS
- default: '{mvn-params}'
+ default: "{mvn-params}"
description: |
- Maven parameters to pass to the mvn command.
+ Maven parameters to pass to the mvn command.
- string:
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.
- default: '/w/tools/hudson.tasks.Maven_MavenInstallation/{mvn-version}/bin/mvn'
- description: 'Maven selector to be used by shell scripts'
- - string:
- name: STAGING_PROFILE_ID
- default: '{staging-profile-id}'
- description: |
- Nexus staging profile ID.
-
+ # 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"
- parameter:
name: lf-infra-openstack-parameters
parameters:
- string:
name: OS_CLOUD
- default: '{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/
-
+ 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: lf-infra-parameters
parameters:
- string:
name: PROJECT
- default: '{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}'
+ default: "{stream}"
description: |
- Stream is often set to the same name as 'branch' but can
- sometimes be used as a name representing a project's release code
- name.
+ Stream is often set to the same name as 'branch' but can
+ sometimes be used as a name representing a project's release code
+ name.
- string:
name: GERRIT_PROJECT
- default: '{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}'
+ 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}'
+ 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.
- Note that Gerrit will override this parameter automatically if a
- job is triggered by 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: LFTOOLS_VERSION
- default: '{lftools-version}'
+ name: sha1
+ default: "origin/{branch}"
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'.
+ GitHub PR Trigger provided parameter for specifying the commit
+ to checkout.
+
+ If using GitHub, in a manual build override with a branch path or
+ sha1 hash to a specific commit. For example: 'origin/master'
+
+- 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-sonar-cli-parameters
+ parameters:
+ - string:
+ name: TOX_DIR
+ default: "{tox-dir}"
+ description: |
+ Path to directory containing tox.ini file.
+ - string:
+ name: TOX_ENVS
+ default: "{tox-envs}"
+ description: |
+ Tox environments to run build against.
+ - string:
+ name: SONAR_SCANNER_VERSION
+ default: "{sonar-scanner-version}"
+ description: |
+ Version of sonar scanner to use.
+ Example: 4.7.0.2747
+ - string:
+ name: SONAR_SCANNER_HOME
+ default: "{sonar-scanner-home}"
+ description: |
+ Sonar scanner home directory.
+ Example: $WORKSPACE/.sonar/sonar-scanner-$SONAR_SCANNER_VERSION-linux
+ - string:
+ name: SONAR_SCANNER_OPTS
+ default: "{sonar-scanner-opts}"
+ description: |
+ Sonar scanner Java options.
+ Example: -server
- parameter:
name: lf-infra-tox-parameters
- # Useful parameters when working with TOX
- # https://tox.readthedocs.io/
parameters:
- string:
name: TOX_DIR
- default: '{tox-dir}'
+ default: "{tox-dir}"
description: |
- Path to directory containing tox.ini file.
+ Path to directory containing tox.ini file.
- string:
name: TOX_ENVS
- default: '{tox-envs}'
+ default: "{tox-envs}"
description: |
- Tox environments to run build against.
- Example: docs,py2,py3
+ Tox environments to run build against.
+ Example: docs,py3
+
+- parameter:
+ name: lf-build-with-parameters-maven-release
+ parameters:
+ - string:
+ name: VERSION
+ default: ""
+ description: "Version to release, for example: 1.0.0"
+ - string:
+ name: GIT_TAG
+ default: ""
+ description: "Tag to push to git repo; optional, defaults to VERSION"
+ - string:
+ name: LOG_DIR
+ default: ""
+ description: "Log dir, for example: project-maven-stage-master/17/"
+ - string:
+ name: OVERRIDE_SEMVER_REGEX
+ default: ""
+ description: "Override Semantic Version (SemVer) Regular Expression. Ex: '.*'"
+ - choice:
+ name: DISTRIBUTION_TYPE
+ choices:
+ - None
+ - container
+ - maven
+ description: "Set to maven for build with parameters"
+ - bool:
+ name: USE_RELEASE_FILE
+ default: "{use-release-file}"
+ description: "Set to False for job built with parameters"
##############
# PROPERTIES #
- build-discarder:
# Allow build data to be stored at a length configured by the
# downstream project.
- days-to-keep: '{build-days-to-keep}'
+ days-to-keep: "{build-days-to-keep}"
# Do not allow artifacts to be stored in Jenkins.
artifact-num-to-keep: 0
exec-pattern: "**/**.exec"
class-pattern: "**/classes"
source-pattern: "**/src/main/java"
- exclusion-pattern: "**/gen/**,**/generated-sources/**,**/yang-gen**,**/pax/**"
+ # yamllint disable-line rule:line-length
+ exclusion-pattern: "{exclude-pattern}"
status-update: true
targets:
- branch:
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-package-listing
+ - lf-infra-capture-instance-metadata
+ - lf-infra-ship-logs
+ mark-unstable-if-failed: true
- workspace-cleanup:
exclude:
# Do not clean up *.jenkins-trigger files for jobs that use a
# properties file as input for triggering another build.
- - '**/*.jenkins-trigger'
+ - "**/*.jenkins-trigger"
fail-build: false
+- publisher:
+ name: lf-infra-publish-windows
+ # lf-infra macro to finish up a build.
+ #
+ # Handles the following:
+ # - Shipping logs to Nexus logs site repository
+ # - Cleanup workspace
+ publishers:
+ # TODO: RELENG-1228 Develop log shipping script for Windows systems
+ # - postbuildscript:
+ # builders:
+ # - role: BOTH
+ # build-on:
+ # - ABORTED
+ # - FAILURE
+ # - NOT_BUILT
+ # - SUCCESS
+ # - UNSTABLE
+ # build-steps:
+ # - lf-infra-ship-logs-windows
+ # mark-unstable-if-failed: true
+ - workspace-cleanup:
+ exclude:
+ # Do not clean up *.jenkins-trigger files for jobs that use a
+ # properties file as input for triggering another build.
+ - "**/*.jenkins-trigger"
+ fail-build: false
+
+- publisher:
+ name: global-jjb-email-notification
+ publishers:
+ - email-ext:
+ recipients: "{email-recipients}"
+ reply-to: ""
+ content-type: default
+ subject: "{email-prefix} $PROJECT_NAME - Build # $BUILD_NUMBER - $BUILD_STATUS!"
+ body: |
+ $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.
+
+ Jenkins Build URL:
+ $BUILD_URL
+ unstable: true
+ fixed: true
+ send-to:
+ - recipients
+
#######
# SCM #
#######
name: lf-infra-gerrit-scm
scm:
- git:
- credentials-id: '{jenkins-ssh-credential}'
- url: '{git-url}'
- refspec: '{refspec}'
+ credentials-id: "{jenkins-ssh-credential}"
+ url: "{git-url}"
+ refspec: "{refspec}"
branches:
- - 'refs/heads/{branch}'
+ - "refs/heads/{branch}"
skip-tag: true
wipe-workspace: true
submodule:
- recursive: '{submodule-recursive}'
- choosing-strategy: '{choosing-strategy}'
+ disable: "{submodule-disable}"
+ recursive: "{submodule-recursive}"
+ timeout: "{submodule-timeout}"
+ choosing-strategy: "{choosing-strategy}"
- scm:
name: lf-infra-github-scm
scm:
- git:
- credentials-id: '{jenkins-ssh-credential}'
- url: '{url}'
- refspec: '{refspec}'
+ credentials-id: "{jenkins-ssh-credential}"
+ url: "{url}"
+ refspec: "{refspec}"
+ branches:
+ - "{branch}"
skip-tag: true
wipe-workspace: true
submodule:
- recursive: '{submodule-recursive}'
- choosing-strategy: '{choosing-strategy}'
-
-############
-# TRIGGERS #
-############
-
-- trigger:
- name: lf-infra-github-pr-trigger
- triggers:
- - github-pull-request:
- trigger-phrase: '{trigger-phrase}'
- only-trigger-phrase: '{only-trigger-phrase}'
- status-context: '{status-context}'
- permit-all: '{permit-all}'
- github-hooks: '{github-hooks}'
- auto-close-on-fail: false
- org-list:
- - '{github-org}'
- white-list: '{obj:github_pr_whitelist}'
- admin-list: '{obj:github_pr_admin_list}'
+ disable: "{submodule-disable}"
+ recursive: "{submodule-recursive}"
+ timeout: "{submodule-timeout}"
+ choosing-strategy: "{choosing-strategy}"
############
# WRAPPERS #
############
- wrapper:
- name: lf-infra-wrappers
+ name: lf-infra-wrappers-common
wrappers:
- mask-passwords
- timeout:
type: absolute
- timeout: '{build-timeout}'
- timeout-var: 'BUILD_TIMEOUT'
+ timeout: "{build-timeout}"
+ timeout-var: "BUILD_TIMEOUT"
fail: true
- timestamps
- - ssh-agent-credentials:
- users:
- - '{jenkins-ssh-credential}'
- openstack:
single-use: true
+
+- wrapper:
+ name: lf-infra-wrappers
+ wrappers:
+ - lf-infra-wrappers-common:
+ build-timeout: "{build-timeout}"
+ - config-file-provider:
+ files:
+ - file-id: npmrc
+ target: "$HOME/.npmrc"
+ - file-id: pipconf
+ target: "$HOME/.config/pip/pip.conf"
+ - ssh-agent-credentials:
+ users:
+ - "{jenkins-ssh-credential}"
+
+- wrapper:
+ name: lf-infra-wrappers-windows
+ wrappers:
+ - lf-infra-wrappers-common:
+ build-timeout: "{build-timeout}"