blob: bc411f771d13a3453cd4fac3f2a452c59252d1ef [file] [log] [blame]
Dennis Dmitrievfde667f2018-07-23 16:26:50 +03001/**
2 *
3 * Deploy the product cluster using Jenkins master on CICD cluster
4 *
5 * Expected parameters:
6
7 * ENV_NAME Fuel-devops environment name
8 * PASSED_STEPS Steps passed to install components using Jenkins on CICD cluster: "salt,core,cicd,openstack:3200,stacklight:2400",
9 where 3200 and 2400 might be timeouts (not used in the testing pipeline)
10 * RUN_TEST_OPTS Pytest option -k or -m, with expression to select necessary tests. Additional pytest options are allowed.
11 * PARENT_NODE_NAME Name of the jenkins slave to create the environment
12 * PARENT_WORKSPACE Path to the workspace of the parent job to use tcp-qa repo
13 * TCP_QA_REFS Reference to the tcp-qa change on review.gerrithub.io, like refs/changes/46/418546/41
14 * SHUTDOWN_ENV_ON_TEARDOWN optional, shutdown fuel-devops environment at the end of the job
15 * LAB_CONFIG_NAME Not used (backward compatibility, for manual deployment steps only)
16 * REPOSITORY_SUITE Not used (backward compatibility, for manual deployment steps only)
17 * MCP_IMAGE_PATH1604 Not used (backward compatibility, for manual deployment steps only)
18 * IMAGE_PATH_CFG01_DAY01 Not used (backward compatibility, for manual deployment steps only)
19 */
20
21@Library('tcp-qa')_
22
23common = new com.mirantis.mk.Common()
24shared = new com.mirantis.system_qa.SharedPipeline()
25
26if (! env.PARENT_NODE_NAME) {
27 error "'PARENT_NODE_NAME' must be set from the parent deployment job!"
28}
29
Dennis Dmitriev201a35e2018-08-06 01:37:05 +030030currentBuild.description = "${PARENT_NODE_NAME}:${ENV_NAME}"
31
Dennis Dmitrievfde667f2018-07-23 16:26:50 +030032node ("${PARENT_NODE_NAME}") {
33 if (! fileExists("${PARENT_WORKSPACE}")) {
34 error "'PARENT_WORKSPACE' contains path to non-existing directory ${PARENT_WORKSPACE} on the node '${PARENT_NODE_NAME}'."
35 }
36 dir("${PARENT_WORKSPACE}") {
37 try {
38
Dennis Dmitrieveb50ce12018-09-27 13:34:32 +030039 if (env.TCP_QA_REFS) {
40 stage("Update working dir to patch ${TCP_QA_REFS}") {
41 shared.update_working_dir()
42 }
43 }
44
Dennis Dmitrievfde667f2018-07-23 16:26:50 +030045 stage("Run tests") {
46 def steps = shared.get_steps_list(PASSED_STEPS)
47 def sources = """\
Dennis Dmitrieveb50ce12018-09-27 13:34:32 +030048 cd ${PARENT_WORKSPACE}
Dennis Dmitrievfde667f2018-07-23 16:26:50 +030049 export ENV_NAME=${ENV_NAME}
50 . ./tcp_tests/utils/env_salt"""
51 if (steps.contains('k8s')) {
52 sources += """
53 . ./tcp_tests/utils/env_k8s\n"""
54 }
55 if (steps.contains('openstack')) {
56 sources += """
57 # TODO: . ./tcp_tests/utils/env_keystonercv3\n"""
58 }
59 def installed = steps.collect {"""\
60 export ${it}_installed=true"""}.join("\n")
61
Dennis Dmitrieveb50ce12018-09-27 13:34:32 +030062 shared.run_sh(sources + installed + """
Dennis Dmitrievee5ef232018-08-31 13:53:18 +030063 export TESTS_CONFIGS=${ENV_NAME}_salt_deployed.ini
Dennis Dmitrievfde667f2018-07-23 16:26:50 +030064 export MANAGER=devops # use 'hardware' fixture to manage fuel-devops environment
65 export salt_master_host=\$SALT_MASTER_IP # skip salt_deployed fixture
66 export salt_master_port=6969
67 export SALT_USER=\$SALTAPI_USER
68 export SALT_PASSWORD=\$SALTAPI_PASS
69
70 py.test --junit-xml=nosetests.xml ${RUN_TEST_OPTS}
71
Dennis Dmitrievfde667f2018-07-23 16:26:50 +030072 """)
Dennis Dmitrievb08c0772018-10-17 15:10:26 +030073
74 def snapshot_name = "test_completed"
Dennis Dmitrievefe5c0b2018-10-24 20:35:26 +030075 shared.download_logs("test_completed")
Dennis Dmitrievb08c0772018-10-17 15:10:26 +030076 shared.run_cmd("""\
77 dos.py suspend ${ENV_NAME}
78 dos.py snapshot ${ENV_NAME} ${snapshot_name}
79 """)
80 if ("${env.SHUTDOWN_ENV_ON_TEARDOWN}" == "false") {
81 shared.run_cmd("""\
82 dos.py resume ${ENV_NAME}
83 """)
84 }
85 shared.devops_snapshot_info(snapshot_name)
Dennis Dmitrievfde667f2018-07-23 16:26:50 +030086 }
87
88 } catch (e) {
Dennis Dmitrievb08c0772018-10-17 15:10:26 +030089 common.printMsg("Job is failed", "purple")
Dennis Dmitrievefe5c0b2018-10-24 20:35:26 +030090 // Downloading logs usually not needed here
91 // because tests should use the decorator @pytest.mark.grab_versions
92 // shared.download_logs("test_failed")
Dennis Dmitrievfde667f2018-07-23 16:26:50 +030093 throw e
94 } finally {
95 // TODO(ddmitriev): analyze the "def currentResult = currentBuild.result ?: 'SUCCESS'"
96 // and report appropriate data to TestRail
97 if ("${env.SHUTDOWN_ENV_ON_TEARDOWN}" == "true") {
98 shared.run_cmd("""\
99 dos.py destroy ${ENV_NAME}
100 """)
101 }
102 }
103 }
104}