- description-setter:
regexp: '^Build logs: .*'
+- builder:
+ name: lf-infra-package-listing
+ builders:
+ - shell: !include-raw:
+ - ../shell/package-listing.sh
+
- builder:
name: lf-infra-packer-build
builders:
- 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:
- 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:
#!/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:
- ../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 #
##############
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:
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}'
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}'
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:
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-ship-logs
+ mark-unstable-if-failed: true
- workspace-cleanup:
exclude:
# Do not clean up *.jenkins-trigger files for jobs that use a
credentials-id: '{jenkins-ssh-credential}'
url: '{url}'
refspec: '{refspec}'
+ branches:
+ - '{branch}'
skip-tag: true
wipe-workspace: true
submodule:
- '{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'