X-Git-Url: https://gerrit.opnfv.org/gerrit/gitweb?a=blobdiff_plain;f=jjb%2Ffunctest%2Ffunctest-ci-jobs.yml;h=6cfcfdca4f5fd2e11042613b55010d8c68227501;hb=ab40963821dfbcc5d6c1ee2190f25b1bd117d711;hp=9765eb076b7c84b0eb9a75a52a283c2484671371;hpb=f92332f62856737a6d94c950c8073b8cee6f8e1a;p=releng.git diff --git a/jjb/functest/functest-ci-jobs.yml b/jjb/functest/functest-ci-jobs.yml index 9765eb076..0f0cabab3 100644 --- a/jjb/functest/functest-ci-jobs.yml +++ b/jjb/functest/functest-ci-jobs.yml @@ -13,84 +13,166 @@ stream: master branch: '{stream}' gs-pathname: '' - brahmaputra: &brahmaputra - stream: brahmaputra + docker-tag: 'latest' + colorado: &colorado + stream: colorado branch: 'stable/{stream}' gs-pathname: '/{stream}' + docker-tag: 'stable' #-------------------------------- # POD, INSTALLER, AND BRANCH MAPPING #-------------------------------- -# brahmaputra +# Installers using labels +# CI PODs +# This section should only contain the installers +# that have been switched using labels for slaves #-------------------------------- pod: - - opnfv-jump-1: - installer: apex - <<: *brahmaputra - - opnfv-jump-2: +# fuel CI PODs + - baremetal: + slave-label: fuel-baremetal installer: fuel - <<: *brahmaputra - - intel-pod5: - installer: joid - <<: *brahmaputra - - huawei-us-deploy-bare-1: - installer: compass - <<: *brahmaputra - - ericsson-pod1: + <<: *master + - virtual: + slave-label: fuel-virtual installer: fuel - <<: *brahmaputra - - ericsson-pod2: + <<: *master + - baremetal: + slave-label: fuel-baremetal installer: fuel - <<: *brahmaputra + <<: *colorado - virtual: + slave-label: fuel-virtual installer: fuel - <<: *brahmaputra - - huawei-virtual: - installer: compass - <<: *brahmaputra + <<: *colorado +# joid CI PODs + - baremetal: + slave-label: joid-baremetal + installer: joid + <<: *master - virtual: + slave-label: joid-virtual installer: joid - <<: *brahmaputra -#-------------------------------- -# master -#-------------------------------- - - opnfv-jump-2: - installer: fuel <<: *master - - intel-pod6: + - baremetal: + slave-label: joid-baremetal installer: joid + <<: *colorado + - virtual: + slave-label: joid-virtual + installer: joid + <<: *colorado +# compass CI PODs + - baremetal: + slave-label: compass-baremetal + installer: compass <<: *master - - intel-pod8: + - virtual: + slave-label: compass-virtual installer: compass <<: *master - - opnfv-jump-1: + - baremetal: + slave-label: compass-baremetal + installer: compass + <<: *colorado + - virtual: + slave-label: compass-virtual + installer: compass + <<: *colorado +# apex CI PODs + - apex-verify-master: + slave-label: '{pod}' installer: apex <<: *master - - ericsson-pod1: + - apex-daily-master: + slave-label: '{pod}' + installer: apex + <<: *master + - apex-verify-colorado: + slave-label: '{pod}' + installer: apex + <<: *colorado + - apex-daily-colorado: + slave-label: '{pod}' + installer: apex + <<: *colorado +# armband CI PODs + - armband-baremetal: + slave-label: armband-baremetal installer: fuel <<: *master - - ericsson-pod2: + - armband-virtual: + slave-label: armband-virtual installer: fuel <<: *master - - orange-test1: + - armband-baremetal: + slave-label: armband-baremetal + installer: fuel + <<: *colorado + - armband-virtual: + slave-label: armband-virtual + installer: fuel + <<: *colorado +#-------------------------------- +# None-CI PODs +#-------------------------------- + - orange-pod1: + slave-label: '{pod}' + installer: joid + <<: *master + - orange-pod5: + slave-label: '{pod}' installer: fuel <<: *master - orange-pod2: + slave-label: '{pod}' installer: joid <<: *master - - virtual: + - huawei-pod2: + slave-label: '{pod}' + installer: compass + <<: *master + - nokia-pod1: + slave-label: '{pod}' + installer: apex + <<: *master + - arm-pod2: + slave-label: '{pod}' installer: fuel <<: *master - - huawei-virtual: - installer: compass + - zte-pod1: + slave-label: '{pod}' + installer: fuel <<: *master - - virtual: - installer: joid + - zte-pod1: + slave-label: '{pod}' + installer: fuel + <<: *colorado + - zte-pod2: + slave-label: '{pod}' + installer: fuel + <<: *master + - zte-pod3: + slave-label: '{pod}' + installer: fuel <<: *master + - zte-pod3: + slave-label: '{pod}' + installer: fuel + <<: *colorado + - arm-pod2: + slave-label: '{pod}' + installer: fuel + <<: *colorado #-------------------------------- testsuite: - - 'daily' - - 'suite' + - 'suite': + job-timeout: 60 + - 'daily': + job-timeout: 180 + - 'weekly': + job-timeout: 400 jobs: - 'functest-{installer}-{pod}-{testsuite}-{stream}' @@ -107,23 +189,28 @@ - throttle: enabled: true max-per-node: 1 + option: 'project' wrappers: - build-name: name: '$BUILD_NUMBER Suite: $FUNCTEST_SUITE_NAME Scenario: $DEPLOY_SCENARIO' - timeout: - timeout: 400 + timeout: '{job-timeout}' abort: true parameters: - project-parameter: project: '{project}' - - '{pod}-defaults' - '{installer}-defaults' + - '{slave-label}-defaults' - 'functest-{testsuite}-parameter' - string: name: DEPLOY_SCENARIO default: 'os-odl_l2-nofeature-ha' + - string: + name: DOCKER_TAG + default: '{docker-tag}' + description: 'Tag to pull docker image' - functest-parameter: gs-pathname: '{gs-pathname}' @@ -134,6 +221,8 @@ branch: '{branch}' builders: + - description-setter: + description: "POD: $NODE_NAME" - 'functest-{testsuite}-builder' ######################## @@ -145,22 +234,36 @@ - string: name: FUNCTEST_SUITE_NAME default: 'daily' - description: "Suite name to run" + description: "Daily suite name to run" +- parameter: + name: functest-weekly-parameter + parameters: + - string: + name: FUNCTEST_SUITE_NAME + default: 'weekly' + description: "Weekly suite name to run" - parameter: name: functest-suite-parameter parameters: - choice: name: FUNCTEST_SUITE_NAME choices: - - 'tempest' - - 'rally' + - 'healthcheck' + - 'vping_userdata' + - 'vping_ssh' + - 'tempest_smoke_serial' + - 'rally_sanity' - 'odl' - 'onos' - - 'ovno' - 'promise' - 'doctor' + - 'bgpvpn' + - 'security_scan' + - 'tempest_full_parallel' + - 'rally_full' - 'vims' - - 'vping' + - 'multisite' + - 'parser' - parameter: name: functest-parameter parameters: @@ -196,95 +299,49 @@ builders: - 'functest-cleanup' - 'set-functest-env' - - 'functest-all' + - 'functest-daily' + - 'functest-store-results' + - 'functest-exit' + +- builder: + name: functest-weekly-builder + builders: + - 'functest-cleanup' + - 'set-functest-env' + - 'functest-weekly' - 'functest-store-results' + - 'functest-exit' - builder: name: functest-suite-builder builders: - - shell: | - #!/bin/bash - set +e - flag="" - if [ "${PUSH_RESULTS_TO_DB}" == "true" ]; then - flag="-r" - fi - echo "Functest: run $FUNCTEST_SUITE_NAME" - cmd="${FUNCTEST_REPO_DIR}/docker/run_tests.sh --test $FUNCTEST_SUITE_NAME ${flag}" - container_id=$(docker ps -a | grep opnfv/functest | awk '{print $1}' | head -1) - docker exec $container_id $cmd + - 'functest-cleanup' + - 'set-functest-env' + - 'functest-suite' - builder: - name: functest-all + name: functest-daily builders: - - shell: | - #!/bin/bash - set +e - flag="" - if [ "${PUSH_RESULTS_TO_DB}" == "true" ]; then - flag="-r" - fi - cmd="${FUNCTEST_REPO_DIR}/docker/run_tests.sh ${flag}" - container_id=$(docker ps -a | grep opnfv/functest | awk '{print $1}' | head -1) - docker exec $container_id $cmd + - shell: + !include-raw: ./functest-loop.sh - builder: - name: set-functest-env + name: functest-weekly builders: - - shell: | - #!/bin/bash - set +e - [[ $CI_DEBUG == true ]] && redirect="/dev/stdout" || redirect="/dev/null" - # labconfig is used only for joid - labconfig="" - if [[ ${INSTALLER_TYPE} == 'apex' ]]; then - instack_mac=$(sudo virsh domiflist instack | grep default | \ - grep -Eo "[0-9a-f]+:[0-9a-f]+:[0-9a-f]+:[0-9a-f]+:[0-9a-f]+:[0-9a-f]+") - INSTALLER_IP=$(/usr/sbin/arp -e | grep ${instack_mac} | awk {'print $1'}) - sshkey="-v /root/.ssh/id_rsa:/root/.ssh/id_rsa" - sudo iptables -D FORWARD -o virbr0 -j REJECT --reject-with icmp-port-unreachable - sudo iptables -D FORWARD -i virbr0 -j REJECT --reject-with icmp-port-unreachable - elif [[ ${INSTALLER_TYPE} == 'joid' ]]; then - # If production lab then creds may be retrieved dynamically - # creds are on the jumphost, always in the same folder - labconfig="-v $LAB_CONFIG/admin-openrc:/home/opnfv/functest/conf/openstack.creds" - # If dev lab, credentials may not be the default ones, just provide a path to put them into docker - # replace the default one by the customized one provided by jenkins config - fi - echo "Functest: Start Docker and prepare environment" - envs="-e INSTALLER_TYPE=${INSTALLER_TYPE} -e INSTALLER_IP=${INSTALLER_IP} \ - -e NODE_NAME=${NODE_NAME} -e DEPLOY_SCENARIO=${DEPLOY_SCENARIO} \ - -e CI_DEBUG=${CI_DEBUG}" - branch=${GIT_BRANCH##*/} - dir_result="${HOME}/opnfv/functest/results/${branch}" - mkdir -p ${dir_result} - sudo rm -rf ${dir_result}/* - res_volume="-v ${dir_result}:/home/opnfv/functest/results" + - shell: + !include-raw: ./functest-loop.sh + +- builder: + name: functest-suite + builders: + - shell: + !include-raw: ./functest-suite.sh - docker pull opnfv/functest:latest >$redirect - cmd="sudo docker run --privileged=true -id ${envs} ${labconfig} ${sshkey} ${res_volume} opnfv/functest:latest /bin/bash" - echo "Functest: Running docker run command: ${cmd}" - ${cmd} - docker ps -a - sleep 5 - container_id=$(docker ps | grep 'opnfv/functest:latest' | awk '{print $1}' | head -1) - echo "Container ID=${container_id}" - if [ -z ${container_id} ]; then - echo "Cannot find opnfv/functest container ID ${container_id}. Please check if it is existing." - docker ps -a - exit 1 - fi - echo "Starting the container: docker start ${container_id}" - docker start ${container_id} - sleep 5 - docker ps - if [ $(docker ps | grep 'opnfv/functest:latest' | wc -l) == 0 ]; then - echo "The container opnfv/functest with ID=${container_id} has not been properly started. Exiting..." - exit 1 - fi - cmd="${FUNCTEST_REPO_DIR}/docker/prepare_env.sh" - echo "Executing command inside the docker: ${cmd}" - docker exec ${container_id} ${cmd} +- builder: + name: set-functest-env + builders: + - shell: + !include-raw: ./set-functest-env.sh - builder: name: functest-store-results @@ -295,24 +352,11 @@ - builder: name: functest-cleanup builders: - - shell: | - #!/bin/bash - [[ $CI_DEBUG == true ]] && redirect="/dev/stdout" || redirect="/dev/null" - - echo "Cleaning up docker containers/images..." - # Remove previous running containers if exist - if [[ ! -z $(docker ps -a | grep opnfv/functest) ]]; then - echo "Removing existing opnfv/functest containers..." - docker ps -a | grep opnfv/functest | awk '{print $1}' | xargs docker rm -f >$redirect - fi + - shell: + !include-raw: ./functest-cleanup.sh - # Remove existing images if exist - if [[ ! -z $(docker images | grep opnfv/functest) ]]; then - echo "Docker images to remove:" - docker images | head -1 && docker images | grep opnfv/functest - image_tags=($(docker images | grep opnfv/functest | awk '{print $2}')) - for tag in "${image_tags[@]}"; do - echo "Removing docker image opnfv/functest:$tag..." - docker rmi opnfv/functest:$tag >$redirect - done - fi +- builder: + name: functest-exit + builders: + - shell: + !include-raw: ./functest-exit.sh