X-Git-Url: https://gerrit.opnfv.org/gerrit/gitweb?a=blobdiff_plain;f=jjb%2Ffunctest%2Ffunctest.yml;h=6268f27d2bd9648b8d7dc023fae26f9a55fc0eea;hb=2b1dda7443ae1f917542781444c25f92317471a4;hp=9c1ca084a665326de528ea5f51bc64ee120c521e;hpb=3a58ada482a61762854c8f0285714f291dc698d8;p=releng.git diff --git a/jjb/functest/functest.yml b/jjb/functest/functest.yml index 9c1ca084a..6268f27d2 100644 --- a/jjb/functest/functest.yml +++ b/jjb/functest/functest.yml @@ -1,31 +1,82 @@ +################################### +# job configuration for functest +################################### - project: name: functest + installer: + - fuel: + node: 'opnfv-jump-2' + installer_type: 'fuel' + installer_ip: '10.20.0.2' + functest_repo_dir: '/home/opnfv/repos/functest' + - foreman: + node: 'opnfv-jump-2' + installer_type: 'foreman' + installer_ip: '172.30.10.73' + functest_repo_dir: '/home/opnfv/repos/functest' + pod: + - orange-build: + node: 'orange-build' + installer_type: 'foreman' + installer_ip: '172.30.10.73' + functest_repo_dir: '/home/opnfv/repos/functest' + jobs: - - 'functest-vim_bench-test' - - 'functest-vim_tempest-test' - - 'functest-odl-test' - - 'functest-vims-test' - - 'functest-vping-test' + - 'set-functest-env-{pod}' + - 'functest-{pod}' + - 'clean-functest-env-{pod}' + - 'set-functest-env-{installer}-{stream}' + - 'functest-{installer}-{stream}' + - 'clean-functest-env-{installer}-{stream}' + - 'functest-openstack-bench-test-{pod}' + - 'functest-openstack-tempest-smoke-test-{pod}' + - 'functest-odl-test-{pod}' + - 'functest-vims-{installer}-{stream}' + - 'functest-vping-test-{pod}' - 'functest-daily-{stream}' - - 'functest-merge' - - 'functest-verify' + - 'functest-merge-{stream}' + - 'functest-verify-{stream}' - # stream: branch with - in place of / (eg. stable-helium) - # branch: branch (eg. stable/helium) + # stream: branch with - in place of / (eg. stable-arno) + # branch: branch (eg. stable/arno) stream: - master: branch: 'master' + gs-pathname: '' + - stable-arno: + branch: 'stable/arno' + gs-pathname: '/arno' project: 'functest' somevar: 'foo' +################################ +# job template +################################ +- job-template: + name: set-functest-env-{pod} + + project-type: freestyle + + node: '{pod}' + + logrotate: + daysToKeep: 30 + numToKeep: 10 + artifactDaysToKeep: -1 + artifactNumToKeep: -1 + + builders: + - 'set-functest-env' + + - job-template: - name: functest-vim_bench-test + name: clean-functest-env-{pod} project-type: freestyle - node: orange-build + node: '{pod}' logrotate: daysToKeep: 30 @@ -34,15 +85,15 @@ artifactNumToKeep: -1 builders: - - shell: | - python run_rally.py keystone + - 'functest-cleanup' + - job-template: - name: functest-vim_tempest-test + name: set-functest-env-{installer}-{stream} project-type: freestyle - node: orange-build + node: '{node}' logrotate: daysToKeep: 30 @@ -51,15 +102,15 @@ artifactNumToKeep: -1 builders: - - shell: | - rally verify start + - 'set-functest-env' + - job-template: - name: functest-odl-test + name: clean-functest-env-{installer}-{stream} project-type: freestyle - node: ericsson-build + node: '{node}' logrotate: daysToKeep: 30 @@ -68,15 +119,14 @@ artifactNumToKeep: -1 builders: - - shell: | - echo "put your CI scenario here" + - 'functest-cleanup' - job-template: - name: functest-vims-test + name: functest-openstack-bench-test-{pod} project-type: freestyle - node: ericsson-build + node: '{pod}' logrotate: daysToKeep: 30 @@ -85,15 +135,32 @@ artifactNumToKeep: -1 builders: - - shell: | - echo "put your CI scenario here" + - 'functest-rally-bench' + +- job-template: + name: functest-openstack-tempest-smoke-test-{pod} + + project-type: freestyle + + node: '{pod}' + + logrotate: + daysToKeep: 30 + numToKeep: 10 + artifactDaysToKeep: -1 + artifactNumToKeep: -1 + + builders: + - 'functest-tempest-smoke' - job-template: - name: functest-vping-test + name: functest-odl-test-{pod} project-type: freestyle + node: '{pod}' + logrotate: daysToKeep: 30 numToKeep: 10 @@ -102,13 +169,158 @@ builders: - shell: | - echo "put your CI scenario here" + - 'functest-odl' + + +- job-template: + name: functest-vping-test-{pod} + + project-type: freestyle + + node: '{pod}' + + logrotate: + daysToKeep: 30 + numToKeep: 10 + artifactDaysToKeep: -1 + artifactNumToKeep: -1 + + builders: + - 'functest-vping' + + +- job-template: + name: functest-{pod} + + project-type: freestyle + + node: '{pod}' + + parameters: + - project-parameter: + project: '{project}' + - string: + name: INSTALLER_TYPE + default: '{installer_type}' + description: "Installer name that is used for deployment." + - string: + name: INSTALLER_IP + default: '{installer_ip}' + description: "Installer IP." + - string: + name: FUNCTEST_REPO_DIR + default: '{functest_repo_dir}' + description: "Directory where the root functest repo is cloned in the docker." + - '{pod}' + + scm: + - git-scm: + credentials-id: '{ssh-credentials}' + refspec: '' + branch: master + + logrotate: + daysToKeep: 30 + numToKeep: 10 + artifactDaysToKeep: -1 + artifactNumToKeep: -1 + + builders: + - 'functest-all' + - 'functest-store-results' + - 'functest-cleanup' + +- job-template: + name: functest-{installer}-{stream} + + project-type: freestyle + + node: '{node}' + + parameters: + - project-parameter: + project: '{project}' + - string: + name: INSTALLER_TYPE + default: '{installer_type}' + description: "Installer name that is used for deployment." + - string: + name: INSTALLER_IP + default: '{installer_ip}' + description: "Installer IP." + - string: + name: FUNCTEST_REPO_DIR + default: '{functest_repo_dir}' + description: "Directory where the root functest repo is cloned in the docker." + - string: + name: GIT_BASE + default: ssh://gerrit.opnfv.org:29418/$PROJECT + description: "Override GIT_BASE" + + scm: + - git-scm: + credentials-id: '{ssh-credentials}' + refspec: '' + branch: master + + logrotate: + daysToKeep: 30 + numToKeep: 10 + artifactDaysToKeep: -1 + artifactNumToKeep: -1 + + builders: + - 'functest-all' + - 'functest-store-results' + - 'functest-cleanup' + +- job-template: + name: functest-vims-{installer}-{stream} + + project-type: freestyle + + node: '{node}' + parameters: + - project-parameter: + project: '{project}' + - string: + name: INSTALLER_TYPE + default: '{installer_type}' + description: "Installer name that is used for deployment." + - string: + name: INSTALLER_IP + default: '{installer_ip}' + description: "Installer IP." + - string: + name: FUNCTEST_REPO_DIR + default: '{functest_repo_dir}' + description: "Directory where the root functest repo is cloned in the docker." + - string: + name: GIT_BASE + default: ssh://gerrit.opnfv.org:29418/$PROJECT + description: "Override GIT_BASE" + + scm: + - git-scm: + credentials-id: '{ssh-credentials}' + refspec: '' + branch: master + + logrotate: + daysToKeep: 30 + numToKeep: 10 + artifactDaysToKeep: -1 + artifactNumToKeep: -1 + builders: + - 'functest-vims' - job-template: name: 'functest-daily-{stream}' + node: master + # Job template for daily builders # # Required Variables: @@ -127,32 +339,36 @@ parameters: - project-parameter: project: '{project}' + - functest-parameter: + gs-pathname: '{gs-pathname}' scm: - git-scm: credentials-id: '{ssh-credentials}' refspec: '' - branch: '{branch}' + branch: '{stream}' wrappers: - ssh-agent-credentials: user: '{ssh-credentials}' triggers: - - timed: 'H H * * *' + - 'functest-{stream}' prebuilders: - test-macro builders: - shell: - !include-raw build-docu.sh + !include-raw ../opnfvdocs/docu-build.sh postbuilders: - test-macro - job-template: - name: 'functest-verify' + name: 'functest-verify-{stream}' + + node: master project-type: freestyle @@ -166,7 +382,7 @@ - project-parameter: project: '{project}' - gerrit-parameter: - branch: 'master' + branch: '{branch}' scm: - gerrit-trigger-scm: credentials-id: '{ssh-credentials}' @@ -194,14 +410,16 @@ project-pattern: 'functest' branches: - branch-compare-type: 'ANT' - branch-pattern: '**/master' + branch-pattern: '**/{branch}' builders: - shell: - !include-raw build-docu.sh + !include-raw ../opnfvdocs/docu-build.sh - job-template: - name: 'functest-merge' + name: 'functest-merge-{stream}' + + node: master # builder-merge job to run JJB update # @@ -219,7 +437,7 @@ - project-parameter: project: '{project}' - gerrit-parameter: - branch: 'master' + branch: '{branch}' scm: - gerrit-trigger-scm: @@ -242,9 +460,179 @@ project-pattern: 'functest' branches: - branch-compare-type: 'ANT' - branch-pattern: '**/master' + branch-pattern: '**/{branch}' + + builders: + - shell: + !include-raw ../opnfvdocs/docu-build.sh + +######################## +# parameter macros +######################## +- parameter: + name: functest-parameter + parameters: + - string: + name: GS_PATHNAME + default: '{gs-pathname}' + description: "Version directory where the opnfv documents will be stored in gs repository" + +- parameter: + name: orange-build + parameters: + - string: + name: GIT_BASE + default: https://gerrit.opnfv.org/gerrit/$PROJECT + description: "Override GIT_BASE" + +- parameter: + name: opnfv-jump-1 + parameters: + - string: + name: GIT_BASE + default: ssh://gerrit.opnfv.org:29418/$PROJECT + description: "Override GIT_BASE" + +- parameter: + name: opnfv-jump-2 + parameters: + - string: + name: GIT_BASE + default: ssh://gerrit.opnfv.org:29418/$PROJECT + description: "Override GIT_BASE" +######################## +# trigger macros +######################## +- trigger: + name: 'functest-master' + triggers: + - pollscm: "H 9 * * *" + +- trigger: + name: 'functest-stable-arno' + triggers: + - pollscm: "H 21 * * *" + +######################## +# builder macros +######################## +# macros +- builder: + name: functest-all + builders: + - shell: | + #!/bin/bash + set +e + + # Remove any docker containers leftovers + $ docker ps | grep opnfv/functest | awk '{print $1}' | xargs docker stop &>/dev/null + $ docker ps -a | grep opnfv/functest | awk '{print $1}' | xargs docker rm &>/dev/null + $ docker images | grep opnfv/functest | awk '{print $3}' | xargs docker rmi &>/dev/null + + # Pull and store fresh image from Dockerhub + $ docker pull opnfv/functest + + # Run Docker and Functest tests + cmd="${FUNCTEST_REPO_DIR}/docker/start.sh" + docker run -t -e "INSTALLER_TYPE=${INSTALLER_TYPE}" \ + -e "INSTALLER_IP=${INSTALLER_IP}" opnfv/functest $cmd + + +- builder: + name: set-functest-env + builders: + - shell: | + #!/bin/bash + set +e + + echo "Functest: spawn Docker and run Functest suite" + cmd="${FUNCTEST_REPO_DIR}/docker/start.sh" + docker run -t -e "INSTALLER_TYPE=${INSTALLER_TYPE}" \ + -e "INSTALLER_IP=${INSTALLER_IP}" opnfv/functest $cmd + + +- builder: + name: functest-vping + builders: + - shell: | + #!/bin/bash + set +e + + echo "Functest: run vPing" + cmd="python ${FUNCTEST_REPO_DIR}/testcases/vPing/CI/libraries/vPing.py \ + --debug ${FUNCTEST_REPO_DIR}/ -r" + docker run -t -e "INSTALLER_TYPE=${INSTALLER_TYPE}" \ + -e "INSTALLER_IP=${INSTALLER_IP}" opnfv/functest $cmd + +- builder: + name: functest-odl + builders: + - shell: | + #!/bin/bash + set +e + echo "Functest: run ODL suite" + cmd="${FUNCTEST_REPO_DIR}/testcases/Controllers/ODL/CI/start_tests.sh" + docker run -t -e "INSTALLER_TYPE=${INSTALLER_TYPE}" \ + -e "INSTALLER_IP=${INSTALLER_IP}" opnfv/functest $cmd + +- builder: + name: functest-tempest-smoke + builders: + - shell: | + #!/bin/bash + set +e + + # tempest + echo "Functest: run Tempest suite" + cmd="rally verify start smoke; rally verify list;" + docker run -t -e "INSTALLER_TYPE=${INSTALLER_TYPE}" \ + -e "INSTALLER_IP=${INSTALLER_IP}" opnfv/functest $cmd + + + +- builder: + name: functest-rally-bench + builders: + - shell: | + #!/bin/bash + set +e + + echo "Functest: run Functest Rally Bench suites" + cmd="python ${FUNCTEST_REPO_DIR}/testcases/VIM/OpenStack/CI/libraries/run_rally.py \ + --debug ${FUNCTEST_REPO_DIR}/ all" + docker run -t -e "INSTALLER_TYPE=${INSTALLER_TYPE}" \ + -e "INSTALLER_IP=${INSTALLER_IP}" opnfv/functest $cmd + + +- builder: + name: functest-vims + builders: + - shell: | + #!/bin/bash + set +e + cmd="python ${FUNCTEST_REPO_DIR}/testcases/vIMS/CI/vIMS.py \ + --debug ${FUNCTEST_REPO_DIR}/" + docker run -t -e "INSTALLER_TYPE=${INSTALLER_TYPE}" \ + -e "INSTALLER_IP=${INSTALLER_IP}" opnfv/functest $cmd + + + +- builder: + name: functest-store-results builders: - - shell: - !include-raw build-docu.sh + - shell: + !include-raw res-build.sh + +- builder: + name: functest-cleanup + builders: + - shell: | + #!/bin/bash + set +e + + # cleanup: remove any docker containers leftovers + $ docker ps | grep opnfv/functest | awk '{print $1}' | xargs docker stop &>/dev/null + $ docker ps -a | grep opnfv/functest | awk '{print $1}' | xargs docker rm &>/dev/null + $ docker images | grep opnfv/functest | awk '{print $3}' | xargs docker rmi &>/dev/null