blob: 4a2d8937b8f16898839bc800470025179571ccf6 [file] [log] [blame]
Petr Lomakine700ffd2017-08-01 10:53:15 -07001/**
2 *
3 * Launch validation of the cloud
4 *
5 * Expected parameters:
6 * SALT_MASTER_URL URL of Salt master
7 * SALT_MASTER_CREDENTIALS Credentials to the Salt API
8 *
9 * TEST_IMAGE Docker image link
10 * TARGET_NODE Salt target for tempest node
11 * TEMPEST_TEST_SET If not false, run tests matched to pattern only
Dmitrii Kabanovb2f60ee2017-11-10 00:31:50 -080012 * TEMPEST_CONFIG_REPO Git repository with configuration files for Tempest
13 * TEMPEST_CONFIG_BRANCH Git branch which will be used during the checkout
14 * TEMPEST_REPO Git repository with Tempest
15 * TEMPEST_VERSION Version of Tempest (tag, branch or commit)
Petr Lomakine700ffd2017-08-01 10:53:15 -070016 * RUN_TEMPEST_TESTS If not false, run Tempest tests
17 * RUN_RALLY_TESTS If not false, run Rally tests
Dmitrii Kabanova67e5a52017-08-14 16:31:11 -070018 * RUN_K8S_TESTS If not false, run Kubernetes tests
Dmitrii Kabanov6b9343e2017-08-30 15:30:21 -070019 * RUN_SPT_TESTS If not false, run SPT tests
20 * SPT_SSH_USER The name of the user which should be used for ssh to nodes
Dmitrii Kabanov6b9343e2017-08-30 15:30:21 -070021 * SPT_IMAGE The name of the image for SPT tests
Dmitrii Kabanov9f3b7ed2017-09-29 10:47:36 -070022 * SPT_IMAGE_USER The name of the user for SPT image
Dmitrii Kabanov6b9343e2017-08-30 15:30:21 -070023 * SPT_FLAVOR The name of the flavor for SPT image
Dmitrii Kabanov9f3b7ed2017-09-29 10:47:36 -070024 * AVAILABILITY_ZONE The name of availability zone
25 * FLOATING_NETWORK The name of the external(floating) network
26 * RALLY_IMAGE The name of the image for Rally tests
27 * RALLY_FLAVOR The name of the flavor for Rally image
Dmitrii Kabanovb2f60ee2017-11-10 00:31:50 -080028 * RALLY_CONFIG_REPO Git repository with files for Rally
29 * RALLY_CONFIG_BRANCH Git branch which will be used during the checkout
Sergey Galkin8991e822017-11-29 19:10:46 +040030 * RALLY_SCENARIOS Path to file or directory with rally scenarios
31 * RALLY_TASK_ARGS_FILE Path to file with rally tests arguments
Sergey Galkin59511372018-02-13 13:59:41 +040032 * REPORT_DIR Path for reports outside docker image
Dmitrii Kabanova67e5a52017-08-14 16:31:11 -070033 * TEST_K8S_API_SERVER Kubernetes API address
34 * TEST_K8S_CONFORMANCE_IMAGE Path to docker image with conformance e2e tests
Tetiana Korchakefa4f782017-08-25 10:22:29 -070035 * TEST_K8S_NODE Kubernetes node to run tests from
36 * GENERATE_REPORT If not false, run report generation command
37 * ACCUMULATE_RESULTS If true, results from the previous build will be used
Sergey Galkin3199a2e2018-05-28 18:55:58 +040038 * JOB_TIMEOUT Job timeout in hours
Petr Lomakine700ffd2017-08-01 10:53:15 -070039 */
40
41common = new com.mirantis.mk.Common()
Dmitrii Kabanova67e5a52017-08-14 16:31:11 -070042test = new com.mirantis.mk.Test()
Petr Lomakine700ffd2017-08-01 10:53:15 -070043validate = new com.mirantis.mcp.Validate()
chnyda625f4b42017-10-11 14:10:31 +020044def python = new com.mirantis.mk.Python()
Petr Lomakine700ffd2017-08-01 10:53:15 -070045
chnyda625f4b42017-10-11 14:10:31 +020046def pepperEnv = "pepperEnv"
Petr Lomakine700ffd2017-08-01 10:53:15 -070047def artifacts_dir = 'validation_artifacts/'
Sergey Galkin3199a2e2018-05-28 18:55:58 +040048if (env.JOB_TIMEOUT == ''){
49 job_timeout = 12
50} else {
51 job_timeout = env.JOB_TIMEOUT.toInteger()
52}
53timeout(time: job_timeout, unit: 'HOURS') {
Jakub Josefa63f9862018-01-11 17:58:38 +010054 node() {
55 try{
56 stage('Setup virtualenv for Pepper') {
57 python.setupPepperVirtualenv(pepperEnv, SALT_MASTER_URL, SALT_MASTER_CREDENTIALS)
Tetiana Korchakefa4f782017-08-25 10:22:29 -070058 }
Petr Lomakine700ffd2017-08-01 10:53:15 -070059
Jakub Josefa63f9862018-01-11 17:58:38 +010060 stage('Configure') {
61 validate.installDocker(pepperEnv, TARGET_NODE)
62 if (ACCUMULATE_RESULTS.toBoolean() == false) {
63 sh "rm -r ${artifacts_dir}"
64 }
65 sh "mkdir -p ${artifacts_dir}"
Petr Lomakine700ffd2017-08-01 10:53:15 -070066 }
Petr Lomakine700ffd2017-08-01 10:53:15 -070067
Jakub Josefa63f9862018-01-11 17:58:38 +010068 stage('Run Tempest tests') {
69 if (RUN_TEMPEST_TESTS.toBoolean() == true) {
70 validate.runTempestTests(pepperEnv, TARGET_NODE, TEST_IMAGE, artifacts_dir, TEMPEST_CONFIG_REPO, TEMPEST_CONFIG_BRANCH, TEMPEST_REPO, TEMPEST_VERSION, TEMPEST_TEST_SET)
71 } else {
72 common.infoMsg("Skipping Tempest tests")
73 }
Petr Lomakine700ffd2017-08-01 10:53:15 -070074 }
Dmitrii Kabanova67e5a52017-08-14 16:31:11 -070075
Jakub Josefa63f9862018-01-11 17:58:38 +010076 stage('Run Rally tests') {
77 if (RUN_RALLY_TESTS.toBoolean() == true) {
Alexander Evseevb6c66992018-05-21 17:52:21 +030078 def report_dir = env.REPORT_DIR ?: '/root/qa_results'
Jakub Josefa63f9862018-01-11 17:58:38 +010079 def rally_variables = ["floating_network=${FLOATING_NETWORK}",
80 "rally_image=${RALLY_IMAGE}",
81 "rally_flavor=${RALLY_FLAVOR}",
82 "availability_zone=${AVAILABILITY_ZONE}"]
Sergey Galkin59511372018-02-13 13:59:41 +040083 validate.runRallyTests(pepperEnv, TARGET_NODE, TEST_IMAGE, artifacts_dir, RALLY_CONFIG_REPO, RALLY_CONFIG_BRANCH, RALLY_SCENARIOS, RALLY_TASK_ARGS_FILE, rally_variables, report_dir)
Jakub Josefa63f9862018-01-11 17:58:38 +010084 } else {
85 common.infoMsg("Skipping Rally tests")
86 }
Dmitrii Kabanov6b9343e2017-08-30 15:30:21 -070087 }
Dmitrii Kabanov6b9343e2017-08-30 15:30:21 -070088
Jakub Josefa63f9862018-01-11 17:58:38 +010089 stage('Run SPT tests') {
90 if (RUN_SPT_TESTS.toBoolean() == true) {
91 def spt_variables = ["spt_ssh_user=${SPT_SSH_USER}",
92 "spt_floating_network=${FLOATING_NETWORK}",
93 "spt_image=${SPT_IMAGE}",
94 "spt_user=${SPT_IMAGE_USER}",
95 "spt_flavor=${SPT_FLAVOR}",
96 "spt_availability_zone=${AVAILABILITY_ZONE}"]
97 validate.runSptTests(pepperEnv, TARGET_NODE, TEST_IMAGE, artifacts_dir, spt_variables)
98 } else {
99 common.infoMsg("Skipping SPT tests")
100 }
Dmitrii Kabanova67e5a52017-08-14 16:31:11 -0700101 }
Dmitrii Kabanova67e5a52017-08-14 16:31:11 -0700102
Jakub Josefa63f9862018-01-11 17:58:38 +0100103 stage('Run k8s bootstrap tests') {
104 if (RUN_K8S_TESTS.toBoolean() == true) {
105 def image = 'tomkukral/k8s-scripts'
106 def output_file = 'k8s-bootstrap-tests.txt'
107 def outfile = "/tmp/" + image.replaceAll('/', '-') + '.output'
108 test.runConformanceTests(pepperEnv, TEST_K8S_NODE, TEST_K8S_API_SERVER, image)
Dmitrii Kabanova67e5a52017-08-14 16:31:11 -0700109
Jakub Josefa63f9862018-01-11 17:58:38 +0100110 def file_content = validate.getFileContent(pepperEnv, TEST_K8S_NODE, outfile)
111 writeFile file: "${artifacts_dir}${output_file}", text: file_content
112 } else {
113 common.infoMsg("Skipping k8s bootstrap tests")
114 }
Dmitrii Kabanova67e5a52017-08-14 16:31:11 -0700115 }
Jakub Josefa63f9862018-01-11 17:58:38 +0100116
117 stage('Run k8s conformance e2e tests') {
118 if (RUN_K8S_TESTS.toBoolean() == true) {
119 def image = TEST_K8S_CONFORMANCE_IMAGE
120 def output_file = 'report-k8s-e2e-tests.txt'
121 def outfile = "/tmp/" + image.replaceAll('/', '-') + '.output'
122 test.runConformanceTests(pepperEnv, TEST_K8S_NODE, TEST_K8S_API_SERVER, image)
123
124 def file_content = validate.getFileContent(pepperEnv, TEST_K8S_NODE, outfile)
125 writeFile file: "${artifacts_dir}${output_file}", text: file_content
126 } else {
127 common.infoMsg("Skipping k8s conformance e2e tests")
128 }
Tetiana Korchakefa4f782017-08-25 10:22:29 -0700129 }
Jakub Josefa63f9862018-01-11 17:58:38 +0100130 stage('Generate report') {
131 if (GENERATE_REPORT.toBoolean() == true) {
132 common.infoMsg("Generating html test report ...")
133 validate.generateTestReport(pepperEnv, TARGET_NODE, TEST_IMAGE, artifacts_dir)
134 } else {
135 common.infoMsg("Skipping report generation")
136 }
137 }
138 stage('Collect results') {
139 archiveArtifacts artifacts: "${artifacts_dir}/*"
140 }
141 } catch (Throwable e) {
142 // If there was an error or exception thrown, the build failed
143 currentBuild.result = "FAILURE"
144 currentBuild.description = currentBuild.description ? e.message + " " + currentBuild.description : e.message
145 throw e
Tetiana Korchakefa4f782017-08-25 10:22:29 -0700146 }
Petr Lomakine700ffd2017-08-01 10:53:15 -0700147 }
148}