X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=jjb%2Fintegration%2Fintegration-test-jobs.yaml;h=15aa436b89e18cb219867d2aa591b1caadf391c9;hb=12835ee13cc548d31c830f6f1c8a1b4ec13bc297;hp=f2e6ff6cd0854aee1d0184b38d01c23066dec682;hpb=1a3ab78314a8c124eab54c3e70bf0fa45f1d4d67;p=releng%2Fbuilder.git diff --git a/jjb/integration/integration-test-jobs.yaml b/jjb/integration/integration-test-jobs.yaml index f2e6ff6cd..15aa436b8 100644 --- a/jjb/integration/integration-test-jobs.yaml +++ b/jjb/integration/integration-test-jobs.yaml @@ -3,185 +3,109 @@ name: integration-test project: integration/test project-name: integration-test - test-branch: master jobs: - - '{project-name}-verify-tox-master' - - 'integration-csit-verify-1node-library' - - 'integration-distribution-test-{stream}' - - 'integration-sanity-test-{stream}' - 'integration-patch-test-{stream}' - 'integration-multipatch-test-{stream}' + - '{project-name}-rtd-jobs': + build-node: centos7-builder-2c-2g + project-pattern: integration/test + rtd-build-url: https://readthedocs.org/api/v2/webhook/odl-integrationtest/32934/ + rtd-token: 70766f97941a74ef80b84749ac4799e5ddeee99a + - gerrit-tox-verify: + branch: master + stream: master + + # CSIT Lists in releng-defaults.yaml + stream: + - fluorine: + branch: 'master' + mvn-version: 'mvn35' + csit-list: !include: csit-jobs-fluorine.lst + build-order: > + infrautils mdsal controller aaa netconf daexim bgpcep ovsdb neutron + lispflowmapping openflowplugin coe genius sfc netvirt + + - oxygen: + branch: 'stable/oxygen' + mvn-version: 'mvn35' + csit-list: !include: csit-jobs-oxygen.lst + build-order: > + infrautils mdsal controller aaa netconf daexim bgpcep ovsdb neutron + lispflowmapping openflowplugin coe genius sfc netvirt + + - nitrogen: + branch: 'stable/nitrogen' + mvn-version: 'mvn35' + csit-list: !include: csit-jobs-nitrogen.lst + build-order: > + infrautils mdsal controller aaa netconf daexim bgpcep ovsdb neutron + lispflowmapping openflowplugin coe genius sfc netvirt + +- project: + name: integration-distribution + project: integration/test + project-name: integration-test + jobs: + - 'integration-distribution-test-{stream}' - 'integration-distribution-weekly-test-trigger-{stream}' - 'integration-distribution-high-frequency-test-trigger-{stream}' - 'integration-update-csit-tests-{stream}' # CSIT Lists in releng-defaults.yaml stream: - - oxygen: + - fluorine: branch: 'master' - jdk: 'openjdk8' - csit-blacklist: longevity gate sanity capwap centinel coe didm iotdm jsonrpc lacp netide tsdr + csit-blacklist: > + alto bier capwap centinel coe didm dluxapps groupbasedpolicy iotdm jsonrpc lacp + l2switch messaging4transport nemo netide nic ocpplugin of-config p4plugin packetcable + sdninterfaceapp sxp tsdr unimgr usc usecplugin vtn gate longevity sanity tdd wip + csit-list: !include: csit-jobs-fluorine.lst + csit-weekly-list: '{csit-weekly-list-fluorine}' + csit-high-frequency-list: '{csit-high-frequency-list-fluorine}' + - oxygen: + branch: 'stable/oxygen' + csit-blacklist: > + capwap centinel coe didm iotdm jsonrpc lacp messaging4transport netide nic + ocpplugin sdninterfaceapp unimgr usecplugin gate longevity sanity tdd wip csit-list: !include: csit-jobs-oxygen.lst - csit-sanity-list: '{csit-sanity-list-oxygen}' csit-weekly-list: '{csit-weekly-list-oxygen}' - schedule-weekly: 'H 23 * * 6' csit-high-frequency-list: '{csit-high-frequency-list-oxygen}' - schedule-high-frequency: '' - nitrogen: branch: 'stable/nitrogen' - jre: 'openjdk8' - csit-blacklist: longevity gate sanity capwap centinel coe didm iotdm jsonrpc lacp netide tsdr + csit-blacklist: capwap centinel coe didm iotdm jsonrpc lacp netide tsdr gate longevity sanity tdd wip csit-list: !include: csit-jobs-nitrogen.lst - csit-sanity-list: '{csit-sanity-list-nitrogen}' csit-weekly-list: '{csit-weekly-list-nitrogen}' - schedule-weekly: 'H 23 * * 6' csit-high-frequency-list: '{csit-high-frequency-list-nitrogen}' - schedule-high-frequency: '' - - - carbon: - branch: 'stable/carbon' - karaf-version: karaf3 - jdk: 'openjdk8' - jre: 'openjdk8' - csit-blacklist: longevity gate sanity capwap centinel coe jsonrpc - csit-list: !include: csit-jobs-carbon.lst - csit-sanity-list: '{csit-sanity-list-carbon}' - csit-weekly-list: '{csit-weekly-list-carbon}' - schedule-weekly: 'H 23 * * 6' - csit-high-frequency-list: '{csit-high-frequency-list-carbon}' - schedule-high-frequency: 'H H/4 * * *' - - - boron: - branch: 'stable/boron' - karaf-version: karaf3 - jdk: 'openjdk8' - jre: 'openjdk8' - csit-blacklist: longevity gate sanity jsonrpc - csit-list: !include: csit-jobs-boron.lst - csit-sanity-list: '{csit-sanity-list-boron}' - csit-weekly-list: '{csit-weekly-list-boron}' - schedule-weekly: 'H 23 * * 6' - csit-high-frequency-list: '' - schedule-high-frequency: '' - - # tools system image - tools_system_image: Ubuntu 16.04 - mininet-ovs-25 - 20170808-0158 - -# Template: integration-csit-verify-1node-library -# Goal: Verify changes in csit folder not covered by projects suite verify jobs (e.g. libraries or variables) -# Operation: This job template performs a base openflow test when there is a change in the libraries folder - -- job-template: - name: 'integration-csit-verify-1node-library' - - project-type: freestyle - node: centos7-robot-2c-2g - - # {stream} is already defined as a composite object, it cannot be overriden. - dist-stream: boron - # This is not a template, so define branch, scope and jre for distribution to test with. - branch: stable/boron - scope: only - jre: openjdk8 - - properties: - - opendaylight-infra-properties: - build-days-to-keep: '{build-days-to-keep}' - - parameters: - - opendaylight-infra-parameters: - os-cloud: '{os-cloud}' - project: '{project}' - branch: '{test-branch}' - refspec: 'refs/heads/{test-branch}' - artifacts: '{archive-artifacts}' - - integration-distribution-branch: - branch: '{verify-branch}' - - integration-distribution-stream: - stream: '{verify-stream}' - - integration-bundle-url: - bundle-url: '{bundle-url}' - - integration-controller-scope: - controller-scope: '{scope}' - - integration-controller-features: - controller-features: > - odl-clustering-test-app, - odl-openflowplugin-flow-services-ui, - odl-openflowplugin-app-table-miss-enforcer, - odl-bgpcep-pcep, - odl-bgpcep-bgp, - odl-netconf-connector-all - # when upgrading to carbon you should replace odl-netconf-connector-all with odl-netconf-topology - # and change USE_NETCONF_CONNECTOR to False in test-options - - integration-test-options: - test-options: '-v TIMEOUT_BUG_4220:10s -v USE_NETCONF_CONNECTOR:True' - - integration-stream-test-plan: - stream-test-plan: 'test-libraries-{verify-stream}.txt' - - integration-test-plan: - test-plan: 'test-libraries.txt' - - integration-patch-refspec: - branch: '$GERRIT_REFSPEC' - - integration-jdk-version: - jdkversion: '{jre}' - - distribution-karaf-version: - karaf-version: '{verify-karaf-version}' - - scm: - - integration-gerrit-scm: - basedir: 'test' - refspec: '$PATCHREFSPEC' - branch: '{test-branch}' - - wrappers: - - opendaylight-infra-wrappers: - build-timeout: '{build-timeout}' - - triggers: - - integration-trigger-patch-submitted: - server: '{server-name}' - project: '{project}' - branch: '{test-branch}' - files: 'csit/libraries/*' - builders: - - integration-infra-stack: - stack-template: '{stack-template}' - vm_0_count: '1' - vm_0_flavor: '{odl_system_flavor}' - vm_0_image: '{odl_system_image}' - vm_1_count: '{tools_system_count}' - vm_1_flavor: '{tools_system_flavor}' - vm_1_image: '{tools_system_image}' - - integration-install-robotframework - - inject: - properties-file: 'env.properties' - - integration-get-slave-addresses - - inject: - properties-file: 'slave_addresses.txt' - - integration-detect-variables - - integration-deploy-controller-run-test - - integration-cleanup-tmp - - publishers: - - integration-robot: - unstable-if: 0.0 - pass-if: 100.0 - - email-notification: - email-recipients: '{email-recipients}' - email-prefix: '[integration]' - - integration-csit-archive-build - - lf-infra-publish +- project: + name: integration-sanity + project: integration/test + project-name: integration-test + jobs: + - 'integration-sanity-test-{stream}' -# Template: integration-distribution-test-{stream} -# Goal: Verify a distribution through all system test available -# Operation: This template takes a distribution and passes all available system test + stream: + - fluorine: + branch: 'master' + karaf-version: odl + csit-sanity-list: '{csit-sanity-list-fluorine}' + - oxygen: + branch: 'stable/oxygen' + karaf-version: karaf4 + csit-sanity-list: '{csit-sanity-list-oxygen}' + - nitrogen: + branch: 'stable/nitrogen' + karaf-version: karaf4 + csit-sanity-list: '{csit-sanity-list-nitrogen}' - job-template: name: 'integration-distribution-test-{stream}' + # Goal: Verify a distribution through all system test available + # Operation: This template takes a distribution and passes all available system test project-type: freestyle - node: centos7-robot-2c-2g + node: queue-disttest-2c-1g properties: - opendaylight-infra-properties: @@ -202,19 +126,20 @@ KARAF_VERSION=$KARAF_VERSION publishers: + - opendaylight-infra-generate-csit-status-report - email-notification: email-recipients: '{email-recipients}' email-prefix: '[integration]' - -# Template: integration-sanity-test-{stream} -# Goal: Verify a distribution through sanity test -# Operation: This template takes a distribution and passes sanity test + - lf-infra-publish - job-template: name: 'integration-sanity-test-{stream}' + # Goal: Verify a distribution through sanity test + # Operation: This template takes a distribution and passes sanity test + # This jobs works for both managed & unmanaged distro. project-type: freestyle - node: centos7-robot-2c-2g + node: queue-intque-2c-1g properties: - opendaylight-infra-properties: @@ -226,6 +151,9 @@ - distribution-karaf-version: karaf-version: '{karaf-version}' + triggers: + - timed: '{schedule-daily}' + builders: - trigger-builds: - project: '{csit-sanity-list}' @@ -239,16 +167,15 @@ email-recipients: '{email-recipients}' email-prefix: '[integration]' -# Template: integration-patch-test-{stream} -# Goal: Build a patch and run all available system test on a distribution containing the change -# Operation: This job template builds a patch, creates a distribution containing the patch, and -# triggers the distribution test when test-integration is used in gerrit comments - - job-template: name: 'integration-patch-test-{stream}' + # Template: integration-patch-test-{stream} + # Goal: Build a patch and run all available system test on a distribution containing the change + # Operation: This job template builds a patch, creates a distribution containing the patch, and + # triggers the distribution test when test-integration is used in gerrit comments project-type: freestyle - node: centos7-java-builder-2c-8g + node: centos7-builder-2c-8g properties: - opendaylight-infra-properties: @@ -268,7 +195,7 @@ - integration-distribution-git-url: git-url: '{git-url}' - maven-exec: - maven-version: mvn33 + maven-version: mvn35 scm: - integration-gerrit-scm: @@ -284,7 +211,7 @@ triggers: - gerrit: - server-name: '{server-name}' + server-name: '{gerrit-server-name}' trigger-on: - comment-added-contains-event: comment-contains-value: 'test-integration' @@ -307,13 +234,14 @@ global-settings-file: 'global-settings' settings-file: 'integration-settings' - maven-target: - maven-version: 'mvn33' + maven-version: 'mvn35' pom: '$GERRIT_PROJECT/pom.xml' goals: | clean install dependency:tree -DoutputFile=dependency_tree.txt -Pq -Dstream={stream} {opendaylight-infra-mvn-opts} + # {opendaylight-infra-parallel-mvn-opts} is bad when there are multiple big features in SFT. java-opts: - '-Xmx4096m -XX:MaxPermSize=1024m -Dmaven.compile.fork=true' settings: integration-settings @@ -321,11 +249,12 @@ global-settings: global-settings global-settings-type: cfp - maven-target: - maven-version: mvn33 + maven-version: mvn35 pom: distribution/pom.xml goals: | clean install dependency:tree -DoutputFile=dependency_tree.txt {opendaylight-infra-mvn-opts} + # {opendaylight-infra-parallel-mvn-opts} is bad when there are multiple big features in SFT. java-opts: - '-Xmx1024m -XX:MaxPermSize=256m -Dmaven.compile.fork=true' settings: integration-settings @@ -351,31 +280,14 @@ - job-template: name: 'integration-multipatch-test-{stream}' # Goal: Build one or more patches and run all available system test on a distribution containing the change. - # Operation: This job template checks out and builds each patch provided in job parameters, creates a distribution - # containing these patches, and triggers the distribution test job which includes most (if not all) available - # CSIT jobs - # TODO: Move the following to appropriate readthedocs document. - # Recommended Sandbox usage: - # 0. Create this job and a CSIT job you want to run on the new .zip in Sandbox (disable timed triggers). - # 1. Copy the csit job name to clipboard. - # 2. Navigate to Sandbox page of this job. - # 3. Click "Configure". - # 4. Locate "Trigger/call builds on other projects" (under "Post Steps" tab). - # 5. Delete the long value of "Projects to build" field and paste the job name from clipboard (ctrl+a, ctrl+v). - # 6. Click "Save" button. - # 7. Click "Build with Parameters". - # yamllint disable-line rule:line-length - # 8. Start the job with your parameters, see https://wiki.opendaylight.org/view/Integration/Test/Running_System_Tests#Running_System_Tests_Using_Custom_Distribution_Built_From_Multiple_Patches - # 9. The multipatch job waits for the csit job to finish, so abort csit if you see something went wrong. - # 10. Navigate to Sandbox page of the csit job, click the run triggered from multipatch. - # 11. Click Parameters and copy the long value of BUNDLE_URL field to clipboard. - # 12. Run the same csit job woth different patchset or test options, or other csit jobs, with this BUNDLE_URL value - # so you do not have to wait for multipatch build. Repeat step 12. - # 13. Currently, the .zip lasts 24 hours (?) so you may need to jump to step 2 (or 0) after some time. + # Operation: This job template checks out and builds in order each patch provided in job parameters, finally + # it creates a distribution containing all patches and triggers the distribution test job which includes most + # (if not all) available CSIT jobs. project-type: freestyle - node: centos7-java-builder-8c-8g - jdk: '{jdk}' + node: centos7-builder-8c-8g + concurrent: true + jdk: '{java-version}' properties: - opendaylight-infra-properties: @@ -384,10 +296,16 @@ parameters: - patches-to-build-parameter: patches_to_build: '$PATCHES_TO_BUILD' + - build-order-parameter: + build-order: '{build-order}' + - build-fast-parameter: + build-fast: 'false' - run-test-parameter: run-test: 'false' - integration-distribution-branch: branch: '{branch}' + - integration-distribution-stream: + stream: '{stream}' - distribution-karaf-version: karaf-version: '{karaf-version}' - opendaylight-infra-parameters: @@ -396,40 +314,42 @@ branch: '{branch}' refspec: 'refs/heads/{branch}' artifacts: '{archive-artifacts}' - - maven-exec: - maven-version: mvn33 + - lf-infra-maven-parameters: + mvn-opts: '' + mvn-params: '' + mvn-version: mvn35 + staging-profile-id: '' # Staging repos do not make sense for this job wrappers: - opendaylight-infra-wrappers: build-timeout: '1200' + triggers: + - gerrit: + server-name: '{gerrit-server-name}' + trigger-on: + - comment-added-contains-event: + comment-contains-value: 'multipatch-build' + projects: + - project-compare-type: ANT + project-pattern: '**' + branches: + - branch-compare-type: ANT + branch-pattern: '**/{branch}' + builders: - wipe-org-opendaylight-repo - - integration-multipatch-builder + - lf-maven-install: + mvn-version: '{mvn-version}' - provide-maven-settings: global-settings-file: 'global-settings' - settings-file: 'yangtools-settings' - - maven-target: - maven-version: mvn33 - pom: patch_tester/pom.xml - # TODO: Make Maven options configurable. Currently tests are not skipped, everything else is. - goals: | - clean install dependency:tree -DoutputFile=dependency_tree.txt - -Pq - -Dstream={stream} - -Dsft.heap.max=4g - {opendaylight-infra-mvn-opts} - java-opts: - - '-Xmx3072m -Dmaven.compile.fork=true' - settings: integration-settings - settings-type: cfp - global-settings: global-settings - global-settings-type: cfp + settings-file: 'integration-distribution-settings' + - integration-multipatch-builder - integration-upload-distribution: dist-pom: patch_tester/distribution/pom.xml - conditional-step: condition-kind: boolean-expression - condition-expression: $RUNTEST + condition-expression: $RUN_TEST steps: - trigger-builds: - project: '{csit-list}' @@ -448,7 +368,7 @@ name: 'integration-distribution-weekly-test-trigger-{stream}' project-type: freestyle - node: centos7-robot-2c-2g + node: queue-intque-2c-1g properties: - opendaylight-infra-properties: @@ -480,7 +400,7 @@ name: 'integration-distribution-high-frequency-test-trigger-{stream}' project-type: freestyle - node: centos7-robot-2c-2g + node: queue-intque-2c-1g properties: - opendaylight-infra-properties: @@ -513,8 +433,7 @@ # This job's purpose is to update csit # tests to run in integration-distribution-test-{stream} - # by updating integration files: csit-list-carbon.inc, - # csit-list-boron.inc, csit-list-beryllium.inc + # by updating integration files: csit-list-{stream}.inc # These files can be used as !include in int-dist-test-{stream} ###################### @@ -529,7 +448,7 @@ ##################### project-type: freestyle - node: centos7-java-builder-2c-4g + node: centos7-builder-2c-8g properties: - lf-infra-properties: @@ -569,10 +488,13 @@ - shell: | git status git add jjb/integration/*.lst - - opendaylight-infra-push-gerrit-patch: - project: "releng/builder" - gerrit-topic: "auto-update-csit-jobs-{stream}" - gerrit-commit-message: "Auto Update CSIT Jobs to run for {stream}" + - lf-infra-push-gerrit-patch: + project: 'releng/builder' + gerrit-user: 'jenkins-$SILO' + gerrit-host: 'git.opendaylight.org' + gerrit-topic: 'auto-update-csit-jobs-{stream}' + gerrit-commit-message: 'Auto Update CSIT Jobs to run for {stream}' + reviewers-email: 'integration-dev@lists.opendaylight.org' publishers: - lf-infra-publish