| /** |
| * |
| * Deploy the product cluster using Jenkins master on CICD cluster |
| * |
| * Expected parameters: |
| |
| * ENV_NAME Fuel-devops environment name |
| * PASSED_STEPS Steps passed to install components using Jenkins on CICD cluster: "salt,core,cicd,openstack:3200,stacklight:2400", |
| where 3200 and 2400 might be timeouts (not used in the testing pipeline) |
| * RUN_TEST_OPTS Pytest option -k or -m, with expression to select necessary tests. Additional pytest options are allowed. |
| * PARENT_NODE_NAME Name of the jenkins slave to create the environment |
| * PARENT_WORKSPACE Path to the workspace of the parent job to use tcp-qa repo |
| * TCP_QA_REFS Reference to the tcp-qa change on Gerrit, like refs/changes/46/418546/41 |
| * SHUTDOWN_ENV_ON_TEARDOWN optional, shutdown fuel-devops environment at the end of the job |
| * TEMPEST_IMAGE_VERSION Tempest image version: pike by default, can be queens. |
| * TEMPEST_TARGET Node where tempest will be run |
| * MAKE_SNAPSHOT_STAGES optional, use "dos.py snapshot" to snapshot stages |
| */ |
| |
| @Library('tcp-qa')_ |
| |
| common = new com.mirantis.mk.Common() |
| shared = new com.mirantis.system_qa.SharedPipeline() |
| make_snapshot_stages = "${env.MAKE_SNAPSHOT_STAGES}" != "false" ? true : false |
| |
| if (! env.PARENT_NODE_NAME) { |
| error "'PARENT_NODE_NAME' must be set from the parent deployment job!" |
| } |
| |
| currentBuild.description = "${PARENT_NODE_NAME}:${ENV_NAME}" |
| |
| timeout(time: 20, unit: 'HOURS') { |
| timestamps { |
| node ("${PARENT_NODE_NAME}") { |
| if (! fileExists("${PARENT_WORKSPACE}")) { |
| error "'PARENT_WORKSPACE' contains path to non-existing directory ${PARENT_WORKSPACE} on the node '${PARENT_NODE_NAME}'." |
| } |
| dir("${PARENT_WORKSPACE}") { |
| try { |
| |
| if (env.TCP_QA_REFS) { |
| stage("Update working dir to patch ${TCP_QA_REFS}") { |
| shared.update_working_dir() |
| } |
| } |
| |
| stage("Run tests") { |
| def steps = shared.get_steps_list(PASSED_STEPS) |
| def sources = """\ |
| cd ${PARENT_WORKSPACE} |
| export ENV_NAME=${ENV_NAME} |
| . ./tcp_tests/utils/env_salt""" |
| if (steps.contains('k8s')) { |
| sources += """ |
| . ./tcp_tests/utils/env_k8s\n""" |
| } |
| if (steps.contains('openstack')) { |
| sources += """ |
| export TEMPEST_IMAGE_VERSION=${TEMPEST_IMAGE_VERSION} |
| export TEMPEST_TARGET=${TEMPEST_TARGET} |
| # TODO: . ./tcp_tests/utils/env_keystonercv3\n""" |
| } |
| def installed = steps.collect {"""\ |
| export ${it}_installed=true"""}.join("\n") |
| |
| shared.run_sh(sources + installed + """ |
| export TESTS_CONFIGS=${ENV_NAME}_salt_deployed.ini |
| export ENV_MANAGER=$ENV_MANAGER # use 'hardware' fixture to manage fuel-devops environment |
| export salt_master_host=\$SALT_MASTER_IP # skip salt_deployed fixture |
| export salt_master_port=6969 |
| export SALT_USER=\$SALTAPI_USER |
| export SALT_PASSWORD=\$SALTAPI_PASS |
| |
| export LOG_NAME=swarm_run_pytest.log |
| py.test --junit-xml=nosetests.xml ${RUN_TEST_OPTS} |
| |
| """) |
| |
| def snapshot_name = "test_completed" |
| shared.download_logs("test_completed_${ENV_NAME}") |
| |
| if (make_snapshot_stages) { |
| shared.run_cmd("""\ |
| dos.py suspend ${ENV_NAME} |
| dos.py snapshot ${ENV_NAME} ${snapshot_name} |
| """) |
| if ("${env.SHUTDOWN_ENV_ON_TEARDOWN}" == "false") { |
| shared.run_cmd("""\ |
| dos.py resume ${ENV_NAME} |
| """) |
| } |
| shared.devops_snapshot_info(snapshot_name) |
| } |
| } |
| |
| } catch (e) { |
| common.printMsg("Job is failed", "purple") |
| // Downloading logs usually not needed here |
| // because tests should use the decorator @pytest.mark.grab_versions |
| // shared.download_logs("test_failed_${ENV_NAME}") |
| throw e |
| } finally { |
| // TODO(ddmitriev): analyze the "def currentResult = currentBuild.result ?: 'SUCCESS'" |
| // and report appropriate data to TestRail |
| if (make_snapshot_stages) { |
| if ("${env.SHUTDOWN_ENV_ON_TEARDOWN}" == "true") { |
| shared.run_cmd("""\ |
| dos.py destroy ${ENV_NAME} |
| """) |
| } |
| } |
| } |
| } |
| } //node |
| } // timestamps |
| } // timeout |