X-Git-Url: https://gerrit.linuxfoundation.org/infra/gitweb?a=blobdiff_plain;f=jjb%2Flf-python-jobs.yaml;h=5d62828a821d31b0305bfc55e19849daca014621;hb=refs%2Ftags%2Fv0.77.3;hp=9f91a6f78e8ae7bae709f2ffed790a2876273c5b;hpb=bf2c57751c5ddf5004b74bb2b575d4751435a6f5;p=releng%2Fglobal-jjb.git diff --git a/jjb/lf-python-jobs.yaml b/jjb/lf-python-jobs.yaml index 9f91a6f7..5d62828a 100644 --- a/jjb/lf-python-jobs.yaml +++ b/jjb/lf-python-jobs.yaml @@ -4,11 +4,13 @@ ########## - builder: - name: lf-infra-clm-python + name: lf-infra-nexus-iq-python-cli builders: - inject: - properties-content: "CLM_PROJECT_NAME={clm-project-name}" - - shell: !include-raw-escape: ../shell/nexus-iq-cli.sh + properties-content: | + NEXUS_IQ_PROJECT_NAME={nexus-iq-project-name} + REQUIREMENTS_FILE={requirements-file} + - shell: !include-raw-escape: ../shell/nexus-iq-python-cli.sh - builder: name: lf-infra-tox-install @@ -63,39 +65,36 @@ publishers: - lf-infra-publish -################# -# Python XC CLM # -################# +#################### +# Tox Nexus IQ CLM # +#################### -- lf_python_clm_xc: &lf_python_xc_clm - name: lf-python-xc-clm +- lf_tox_nexus_iq_clm: &lf_tox_nexus_iq_clm + name: lf-tox-nexus-iq-clm ###################### # Default parameters # ###################### branch: master - build-days-to-keep: 30 # 30 days for troubleshooting purposes - build-timeout: 60 + build-days-to-keep: 7 + build-timeout: 15 + cron: "@weekly" disable-job: false git-url: "$GIT_URL/$PROJECT" github-url: "https://github.com" - java-version: openjdk8 - nexus-iq-cli-version: 1.44.0-01 + java-version: openjdk11 # Scanner is a jar + nexus-iq-cli-version: 1.89.0-02 nexus-iq-namespace: "" # Recommend a trailing dash when set. Example: odl- - pre-build-script: " # pre-build script goes here" + pre-build-script: "# pre-build script goes here" + python-version: python3 + requirements-file: requirements.txt stream: master submodule-recursive: true submodule-timeout: 10 submodule-disable: false - - gerrit_trigger_file_paths: - - compare-type: REG_EXP - pattern: ".*" - - # github_included_regions MUST match gerrit_trigger_file_paths - github_included_regions: - - ".*" + tox-dir: "." + tox-envs: "clm" ##################### # Job Configuration # @@ -108,35 +107,52 @@ project: "{project}" branch: "{branch}" stream: "{stream}" + - lf-infra-tox-parameters: + tox-dir: "{tox-dir}" + tox-envs: "{tox-envs}" + - string: + name: ARCHIVE_ARTIFACTS + default: "{archive-artifacts}" + description: Artifacts to archive to the logs server. - string: name: NEXUS_IQ_CLI_VERSION default: "{nexus-iq-cli-version}" - description: Nexus IQ CLI package to download and use. + description: Nexus IQ CLI jar to download and run. wrappers: + - lf-infra-wrappers: + build-timeout: "{build-timeout}" + jenkins-ssh-credential: "{jenkins-ssh-credential}" - credentials-binding: - username-password-separated: credential-id: nexus-iq-xc-clm - username: CLM_USER - password: CLM_PASSWORD + username: NEXUS_IQ_USER + password: NEXUS_IQ_PASSWORD + builders: + - lf-infra-pre-build - lf-update-java-alternatives: java-version: "{java-version}" + - lf-infra-tox-install: + python-version: "{python-version}" - shell: "{pre-build-script}" - - lf-infra-clm-python: - clm-project-name: "{nexus-iq-namespace}{project-name}" + - lf-infra-tox-run: + parallel: false + - lf-infra-nexus-iq-python-cli: + nexus-iq-project-name: "{nexus-iq-namespace}{project-name}" + requirements-file: "{requirements-file}" - job-template: - name: "{project-name}-python-clm-{stream}" - id: gerrit-python-xc-clm + name: "{project-name}-tox-nexus-iq-clm" + id: gerrit-tox-nexus-iq-clm <<: *lf_python_common - <<: *lf_python_xc_clm + <<: *lf_tox_nexus_iq_clm ###################### # Default parameters # ###################### - gerrit_clm_triggers: + gerrit_nexus_iq_triggers: - comment-added-contains-event: comment-contains-value: '^Patch Set\s+\d+:\s+run-clm\s*$' @@ -156,18 +172,16 @@ choosing-strategy: default triggers: - # Build weekly on Saturdays - - timed: "H H * * 6" + - timed: "{obj:cron}" - gerrit: server-name: "{gerrit-server-name}" - trigger-on: "{obj:gerrit_clm_triggers}" + trigger-on: "{obj:gerrit_nexus_iq_triggers}" projects: - project-compare-type: ANT project-pattern: "{project}" branches: - branch-compare-type: ANT branch-pattern: "**/{branch}" - file-paths: "{obj:gerrit_trigger_file_paths}" skip-vote: successful: true failed: true @@ -175,10 +189,10 @@ notbuilt: true - job-template: - name: "{project-name}-python-clm-{stream}" - id: github-python-xc-clm + name: "{project-name}-tox-nexus-iq" + id: github-tox-nexus-iq-clm <<: *lf_python_common - <<: *lf_python_xc_clm + <<: *lf_tox_nexus_iq_clm properties: - lf-infra-properties: @@ -198,8 +212,7 @@ jenkins-ssh-credential: "{jenkins-ssh-credential}" triggers: - # Build weekly on Saturdays - - timed: "H H * * 6" + - timed: "{obj:cron}" - github-pull-request: trigger-phrase: "^run-clm$" only-trigger-phrase: false @@ -208,7 +221,6 @@ github-hooks: true white-list-target-branches: - "{branch}" - included-regions: "{obj:github_included_regions}" ######################### # Python Sonar with Tox # @@ -228,7 +240,7 @@ disable-job: false git-url: "$GIT_URL/$PROJECT" github-url: "https://github.com" - java-version: openjdk8 + java-version: openjdk11 mvn-global-settings: global-settings mvn-goals: validate mvn-opts: "" @@ -243,12 +255,17 @@ sonarcloud-project-key: "" sonarcloud-project-organization: "" sonarcloud-api-token: "" + sonarcloud-qualitygate-wait: false + # SonarCloud scan using jdk8 will become deprecated by Oct, 2020 + # Projects not compatible with jdk11 can set java-version to something else + sonarcloud-java-version: openjdk11 stream: master submodule-recursive: true submodule-timeout: 10 submodule-disable: false tox-dir: "." tox-envs: "" + scan-dev-branch: false gerrit_trigger_file_paths: - compare-type: REG_EXP @@ -320,6 +337,9 @@ # yamllint disable-line rule:line-length sonarcloud-project-organization: "{sonarcloud-project-organization}" sonarcloud-api-token: "{sonarcloud-api-token}" + sonarcloud-java-version: "{sonarcloud-java-version}" + sonarcloud-qualitygate-wait: "{sonarcloud-qualitygate-wait}" + scan-dev-branch: "{scan-dev-branch}" # With SonarQube - conditional-step: condition-kind: not @@ -799,7 +819,7 @@ github-hooks: true org-list: - "{github-org}" - white-list: "{obj:github_pr_whitelist}" + white-list: "{obj:github_pr_allowlist}" admin-list: "{obj:github_pr_admin_list}" white-list-target-branches: - "{branch}" @@ -892,8 +912,8 @@ parallel: "{parallel}" - shell: !include-raw-escape: ../shell/pypi-dist-build.sh -- lf_pypi_merge_builders: &lf_pypi_merge_builders - name: lf-pypi-merge-builders +- lf_pypi_publish_builders: &lf_pypi_publish_builders + name: lf-pypi-publish-builders builders: - lf-infra-pre-build @@ -984,9 +1004,9 @@ name: "{project-name}-pypi-merge-{stream}" id: gerrit-pypi-merge <<: *lf_pypi_common - <<: *lf_pypi_merge_builders + <<: *lf_pypi_publish_builders - cron: "" + cron: "" # avoid for pypi which rejects duplicates pypi-repo: pypi-test scm: @@ -1021,7 +1041,7 @@ name: "{project-name}-pypi-merge-{stream}" id: github-pypi-merge <<: *lf_pypi_common - <<: *lf_pypi_merge_builders + <<: *lf_pypi_publish_builders cron: "" pypi-repo: pypi-test @@ -1051,8 +1071,82 @@ github-hooks: true org-list: - "{github-org}" - white-list: "{obj:github_pr_whitelist}" + white-list: "{obj:github_pr_allowlist}" admin-list: "{obj:github_pr_admin_list}" white-list-target-branches: - "{branch}" included-regions: "{obj:github_included_regions}" + +- job-template: + name: "{project-name}-pypi-stage-{stream}" + id: gerrit-pypi-stage + <<: *lf_pypi_common + <<: *lf_pypi_publish_builders + + cron: "" + pypi-repo: pypi-test + + gerrit_stage_triggers: + - comment-added-contains-event: + comment-contains-value: '^Patch Set\s+\d+:\s+stage-release\s*$' + + 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}" + submodule-disable: "{submodule-disable}" + # stage jobs always build from tip + choosing-strategy: default + + triggers: + - timed: "{obj:cron}" + - gerrit: + server-name: "{gerrit-server-name}" + trigger-on: "{obj:gerrit_stage_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}-pypi-stage-{stream}" + id: github-pypi-stage + <<: *lf_pypi_common + <<: *lf_pypi_publish_builders + + cron: "" + pypi-repo: pypi-test + + properties: + - github: + url: "{github-url}/{github-org}/{project}" + + scm: + - lf-infra-github-scm: + url: "{git-clone-url}{github-org}/{project}" + refspec: "" + branch: "refs/heads/{branch}" + submodule-recursive: "{submodule-recursive}" + submodule-timeout: "{submodule-timeout}" + submodule-disable: "{submodule-disable}" + choosing-strategy: default + jenkins-ssh-credential: "{jenkins-ssh-credential}" + + triggers: + - timed: "{obj:cron}" + - github-pull-request: + trigger-phrase: "^stage-release$" + only-trigger-phrase: true + status-context: "Release" + permit-all: true + github-hooks: true + white-list-target-branches: + - "{branch}" + included-regions: "{obj:github_included_regions}"