X-Git-Url: https://gerrit.linuxfoundation.org/infra/gitweb?a=blobdiff_plain;f=jjb%2Flf-ci-jobs.yaml;h=5019cb982f47b141e481a4d91d0a0eb6fca3dc8c;hb=cc9776d38d1d5a25a9c27af4501dda47318e09aa;hp=2ede3e7b4b01df747b4bf88e160a58b278e00d18;hpb=98efe44ce56e58bddbdebbf36888f22a9e393246;p=releng%2Fglobal-jjb.git diff --git a/jjb/lf-ci-jobs.yaml b/jjb/lf-ci-jobs.yaml index 2ede3e7b..5019cb98 100644 --- a/jjb/lf-ci-jobs.yaml +++ b/jjb/lf-ci-jobs.yaml @@ -38,7 +38,7 @@ submodule-recursive: true submodule-timeout: 10 packer-cloud-settings: packer-cloud-env - packer-version: 1.2.5 + packer-version: 1.4.0 ##################### # Job Configuration # @@ -58,7 +58,6 @@ project: '{project}' stream: '{stream}' branch: '{branch}' - lftools-version: '{lftools-version}' - lf-packer-parameters: packer-version: '{packer-version}' @@ -77,6 +76,10 @@ name: JJB_VERSION default: '{jjb-version}' description: Jenkins Job Builder version to download and install. + - string: + name: XDG_CACHE_HOME + default: '{jjb-cache}' + description: Jenkins Job Builder cache location. - parameter: name: lf-packer-parameters @@ -86,6 +89,14 @@ default: '{packer-version}' description: Packer version to download and install. +- parameter: + name: lf-puppet-parameters + parameters: + - string: + name: PUPPET_LINT_VERSION + default: '{puppet-lint-version}' + description: Puppet-lint version to download and install. + - lf_jjb_common: &lf_jjb_common name: lf-jjb-common @@ -97,10 +108,16 @@ build-timeout: 10 disable-job: false github-url: 'https://github.com' - jjb-version: 2.2.1 + jjb-cache: '$HOME/.cache/jenkins_jobs' + jjb-version: 2.8.0 stream: master submodule-recursive: true submodule-timeout: 10 + throttle_categories: [] + throttle-enabled: false + throttle-max-per-node: 1 + throttle-max-total: 0 + throttle-option: 'project' gerrit_trigger_file_paths: - compare-type: REG_EXP @@ -128,14 +145,20 @@ - lf-infra-properties: project: '{project}' build-days-to-keep: 7 + - throttle: + categories: '{obj:throttle_categories}' + enabled: '{throttle-enabled}' + max-per-node: '{throttle-max-per-node}' + max-total: '{throttle-max-total}' + option: '{throttle-option}' parameters: - lf-infra-parameters: project: '{project}' stream: '{stream}' branch: '{branch}' - lftools-version: '{lftools-version}' - lf-infra-jjb-parameters: + jjb-cache: '{jjb-cache}' jjb-version: '{jjb-version}' wrappers: @@ -185,7 +208,6 @@ project: '{project}' stream: '{stream}' branch: '{branch}' - lftools-version: '{lftools-version}' wrappers: - lf-infra-wrappers: @@ -289,7 +311,6 @@ project: '{project}' stream: '' branch: master - lftools-version: '{lftools-version}' wrappers: - lf-infra-wrappers: @@ -430,7 +451,6 @@ project: '{project}' stream: '' branch: master - lftools-version: '{lftools-version}' wrappers: - lf-infra-wrappers: @@ -464,11 +484,11 @@ scm: - lf-infra-gerrit-scm: git-url: '{git-url}' - refspec: 'refs/heads/{branch}' - branch: '{branch}' + refspec: '$GERRIT_REFSPEC' + branch: '$GERRIT_BRANCH' submodule-recursive: true submodule-timeout: '{submodule-timeout}' - choosing-strategy: default + choosing-strategy: gerrit jenkins-ssh-credential: '{jenkins-ssh-credential}' triggers: @@ -497,7 +517,7 @@ url: '{git-clone-url}{github-org}/{project}' refspec: '+refs/pull/*:refs/remotes/origin/pr/*' branch: '$sha1' - submodule-recursive: '{submodule-recursive}' + submodule-recursive: true submodule-timeout: '{submodule-timeout}' choosing-strategy: default jenkins-ssh-credential: '{jenkins-ssh-credential}' @@ -540,6 +560,7 @@ parameters: - lf-infra-jjb-parameters: + jjb-cache: '{jjb-cache}' jjb-version: '{jjb-version}' triggers: @@ -588,7 +609,7 @@ submodule-timeout: 10 gerrit_jjb_deploy_job_triggers: - comment-added-contains-event: - comment-contains-value: 'jjb-deploy[:]* (?!\*+$).+$' + comment-contains-value: '^Patch Set[ ]+[0-9]+:([ ]+|[\n]+)(jjb-deploy[:]* (?!\*+$).+$)' ##################### # Job Configuration # @@ -609,7 +630,6 @@ project: '{project}' stream: '{stream}' branch: '{branch}' - lftools-version: '{lftools-version}' wrappers: - lf-infra-wrappers: @@ -699,6 +719,8 @@ # Default parameters # ###################### + jjb-workers: 0 + gerrit_merge_triggers: - change-merged-event - comment-added-contains-event: @@ -711,6 +733,8 @@ builders: - lf-infra-pre-build - lf-infra-jjbini + - inject: + properties-content: JJB_WORKERS={jjb-workers} - shell: !include-raw-escape: - ../shell/jjb-install.sh - ../shell/jjb-merge-job.sh @@ -804,6 +828,8 @@ # Default parameters # ###################### + build-concurrent: true + gerrit_verify_triggers: - patchset-created-event: exclude-drafts: true @@ -817,7 +843,7 @@ # Job Configuration # ##################### - concurrent: true + concurrent: '{build-concurrent}' builders: - lf-infra-pre-build @@ -1035,7 +1061,6 @@ project: '{project}' branch: '{branch}' stream: '{stream}' - lftools-version: '{lftools-version}' wrappers: - lf-infra-wrappers: @@ -1234,7 +1259,7 @@ branch: master build-days-to-keep: 7 build-timeout: 10 - cron: '@daily' + cron: '@hourly' disable-job: false git-url: '$GIT_URL/$PROJECT' github-url: 'https://github.com' @@ -1242,6 +1267,9 @@ openstack-image-cleanup: true openstack-image-cleanup-age: 30 openstack-image-protect: true + openstack-server-cleanup: true + openstack-stack-cleanup: true + openstack-volume-cleanup: true stream: master submodule-timeout: 10 @@ -1263,7 +1291,11 @@ project: '{project}' stream: '{stream}' branch: '{branch}' - lftools-version: '{lftools-version}' + - string: + name: JENKINS_URLS + default: '{jenkins-urls}' + description: | + Space separated list of Jenkins URLs to check for active builds. wrappers: - lf-infra-wrappers: @@ -1286,6 +1318,24 @@ - lf-infra-pre-build - inject: properties-content: OS_CLOUD={openstack-cloud} + # Stacks + - conditional-step: + condition-kind: boolean-expression + condition-expression: '{openstack-stack-cleanup}' + steps: + - shell: !include-raw-escape: ../shell/openstack-cleanup-orphaned-stacks.sh + # Servers + - conditional-step: + condition-kind: boolean-expression + condition-expression: '{openstack-server-cleanup}' + steps: + - shell: !include-raw-escape: ../shell/openstack-cleanup-orphaned-servers.sh + # Volumes + - conditional-step: + condition-kind: boolean-expression + condition-expression: '{openstack-volume-cleanup}' + steps: + - shell: !include-raw-escape: ../shell/openstack-cleanup-orphaned-volumes.sh # Images - conditional-step: condition-kind: boolean-expression @@ -1356,7 +1406,6 @@ project: '{project}' stream: '{stream}' branch: '{branch}' - lftools-version: '{lftools-version}' - lf-packer-parameters: packer-version: '{packer-version}' @@ -1368,6 +1417,8 @@ packer-version: '{packer-version}' platform: '{platforms}' template: '{templates}' + - description-setter: + description: '.*Creating the image:(.*)' - job-template: name: '{project-name}-packer-merge-{platforms}-{templates}' @@ -1398,7 +1449,7 @@ branch: '$GERRIT_BRANCH' submodule-recursive: '{submodule-recursive}' submodule-timeout: '{submodule-timeout}' - choosing-strategy: gerrit + choosing-strategy: default jenkins-ssh-credential: '{jenkins-ssh-credential}' triggers: @@ -1449,8 +1500,10 @@ scm: - lf-infra-github-scm: url: '{git-clone-url}{github-org}/{project}' - refspec: '' - branch: 'refs/heads/{branch}' + refspec: > + +refs/heads/*:refs/remotes/origin/* + +refs/pull/*:refs/remotes/origin/pr/* + branch: '$GERRIT_REFSPEC' submodule-recursive: '{submodule-recursive}' submodule-timeout: '{submodule-timeout}' choosing-strategy: default @@ -1606,3 +1659,148 @@ included-regions: '{obj:github_included_regions}' white-list-target-branches: - '{branch}' + +################# +# Puppet Verify # +################# + +- lf_puppet_verify: &lf_puppet_verify + name: lf-puppet-verify + + ###################### + # Default parameters # + ###################### + + branch: master + build-days-to-keep: 7 + build-timeout: 15 + disable-job: false + git-url: '$GIT_URL/$GERRIT_PROJECT' + github-url: 'https://github.com' + parallel: true + puppet-dir: '' + puppet-lint-version: 2.3.6 + stream: master + submodule-recursive: true + submodule-timeout: 10 + + gerrit_trigger_file_paths: + - compare-type: REG_EXP + pattern: '.*' + + # github_included_regions MUST match gerrit_trigger_file_paths + github_included_regions: + - '.*' + + ##################### + # Job Configuration # + ##################### + + project-type: freestyle + node: '{build-node}' + concurrent: true + disabled: '{disable-job}' + + properties: + - lf-infra-properties: + build-days-to-keep: '{build-days-to-keep}' + + parameters: + - lf-infra-parameters: + project: '{project}' + branch: '{branch}' + stream: '{stream}' + - lf-puppet-parameters: + puppet-lint-version: '{puppet-lint-version}' + + wrappers: + - lf-infra-wrappers: + build-timeout: '{build-timeout}' + jenkins-ssh-credential: '{jenkins-ssh-credential}' + + builders: + - shell: !include-raw-escape: ../shell/puppet-lint.sh + + publishers: + - lf-infra-publish + +- job-template: + name: '{project-name}-puppet-verify' + id: gerrit-puppet-verify + <<: *lf_puppet_verify + + ###################### + # Default parameters # + ###################### + + gerrit_verify_triggers: + - patchset-created-event: + exclude-drafts: true + exclude-trivial-rebase: false + exclude-no-code-change: false + - draft-published-event + - comment-added-contains-event: + comment-contains-value: '^Patch Set[ ]+[0-9]+:([ ]+|[\n]+)(recheck|reverify)$' + + ##################### + # Job Configuration # + ##################### + + scm: + - lf-infra-gerrit-scm: + jenkins-ssh-credential: '{jenkins-ssh-credential}' + git-url: '{git-url}' + refspec: '$GERRIT_REFSPEC' + branch: '$GERRIT_BRANCH' + submodule-recursive: '{submodule-recursive}' + submodule-timeout: '{submodule-timeout}' + choosing-strategy: gerrit + + triggers: + - gerrit: + server-name: '{gerrit-server-name}' + trigger-on: '{obj:gerrit_verify_triggers}' + projects: + - project-compare-type: ANT + project-pattern: '{project}' + branches: + - branch-compare-type: ANT + branch-pattern: '**/{branch}' + file-paths: '{obj:gerrit_trigger_file_paths}' + +- job-template: + name: '{project-name}-puppet-verify' + id: github-puppet-verify + <<: *lf_puppet_verify + + ##################### + # Job Configuration # + ##################### + + properties: + - lf-infra-properties: + project: '{project}' + build-days-to-keep: 7 + - github: + url: '{github-url}/{github-org}/{project}' + + scm: + - lf-infra-github-scm: + url: '{git-clone-url}{github-org}/{project}' + refspec: '+refs/pull/*:refs/remotes/origin/pr/*' + branch: '$sha1' + submodule-recursive: '{submodule-recursive}' + submodule-timeout: '{submodule-timeout}' + choosing-strategy: default + jenkins-ssh-credential: '{jenkins-ssh-credential}' + + triggers: + - github-pull-request: + trigger-phrase: '^(recheck|reverify)$' + only-trigger-phrase: false + status-context: 'Puppet Verify' + permit-all: true + github-hooks: true + included-regions: '{obj:github_included_regions}' + white-list-target-branches: + - '{branch}'