+ regexp: "^Build logs: .*"
+
+- builder:
+ name: lf-infra-package-listing
+ builders:
+ - shell: !include-raw:
+ - ../shell/package-listing.sh
+
+- builder:
+ name: lf-infra-packer-build
+ 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
+ - inject:
+ properties-content: |
+ PACKER_PLATFORM={platform}
+ PACKER_TEMPLATE={template}
+ PACKER_VERSION={packer-version}
+ - shell: !include-raw-escape:
+ - ../shell/packer-install.sh
+ - ../shell/packer-build.sh
+ - shell: !include-raw:
+ - ../shell/packer-clear-credentials.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
+ - inject:
+ properties-content: |
+ 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-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/sysstat.sh
+
+- builder:
+ name: lf-jacoco-nojava-workaround
+ builders:
+ - shell: "mkdir -p $WORKSPACE/target/classes $WORKSPACE/jacoco/classes"
+
+- builder:
+ name: lf-infra-deploy-maven-file
+ builders:
+ - lf-maven-install:
+ mvn-version: "{mvn-version}"
+ - lf-provide-maven-settings:
+ 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}
+ - shell: !include-raw-escape:
+ - ../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-maven-install
+ 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"
+ - shell: 'rm "$HOME/.wgetrc"'
+
+- builder:
+ name: lf-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: 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
+ builders:
+ - shell: |
+ #!/bin/bash
+ set +e # DO NOT cause build failure if any of the rm calls fail.
+
+ 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 -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}
+ - shell: !include-raw-escape: ../shell/tox-install.sh
+ - shell: !include-raw-escape: ../shell/rtd-verify.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: ../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
+
+##############
+# PARAMETERS #
+##############
+
+- 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}"
+ description: |
+ Maven Java opts. Example: -Xmx1024m -XX:MaxPermSize=256m
+ - string:
+ name: MAVEN_PARAMS
+ default: "{mvn-params}"
+ description: |
+ 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.
+ # 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}"
+ 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/