/
runSmokeTestScripts.groovy
93 lines (81 loc) · 4.85 KB
/
runSmokeTestScripts.groovy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
def main() {
def USE_SECURITY = '-'
def runbranchstage = [:]
if ("${SECURITY_SERVICE_NEEDED}" == 'true') {
USE_SECURITY = '-security-'
}
runbranchstage["SmokeTest ${ARCH}${USE_SECURITY}${TAF_BRANCH}"]= {
node("${NODE}") {
stage ('Checkout edgex-taf repository') {
checkout([$class: 'GitSCM',
branches: [[name: "*/${TAF_BRANCH}"]],
doGenerateSubmoduleConfigurations: false,
extensions: [[$class: 'RelativeTargetDirectory', relativeTargetDir: '']],
submoduleCfg: [],
userRemoteConfigs: [[url: 'https://github.com/edgexfoundry/edgex-taf.git']]
])
}
stage ("Deploy EdgeX - ${ARCH}${USE_SECURITY}${TAF_BRANCH}") {
dir ('TAF/utils/scripts/docker') {
sh "sh get-compose-file.sh ${ARCH} ${USE_SECURITY} ${params.SHA1}"
}
sh "docker run --rm --network host -v ${env.WORKSPACE}:${env.WORKSPACE}:z -w ${env.WORKSPACE} \
-e COMPOSE_IMAGE=${COMPOSE_IMAGE} -e SECURITY_SERVICE_NEEDED=${SECURITY_SERVICE_NEEDED} \
--security-opt label:disable -v /var/run/docker.sock:/var/run/docker.sock ${TAF_COMMON_IMAGE} \
--exclude Skipped --include deploy-base-service -u deploy.robot -p default"
}
stage ("Run Functional Tests Script - ${ARCH}${USE_SECURITY}${TAF_BRANCH}") {
sh "docker run --rm --network host -v ${env.WORKSPACE}:${env.WORKSPACE}:z -w ${env.WORKSPACE} \
--security-opt label:disable -e COMPOSE_IMAGE=${COMPOSE_IMAGE} -e ARCH=${ARCH} \
-e SECURITY_SERVICE_NEEDED=${SECURITY_SERVICE_NEEDED} \
-v /var/run/docker.sock:/var/run/docker.sock ${TAF_COMMON_IMAGE} \
--exclude Skipped --include SmokeTest -u functionalTest/V2-API -p default"
dir ('TAF/testArtifacts/reports/rename-report') {
sh "cp ../edgex/log.html functional-log.html"
sh "cp ../edgex/report.xml functional-report.xml"
}
}
stage ("Run device-virtual Test Script") {
// Run Tests
sh "docker run --rm --network host -v ${env.WORKSPACE}:${env.WORKSPACE}:z -w ${env.WORKSPACE} \
--security-opt label:disable -e COMPOSE_IMAGE=${COMPOSE_IMAGE} -e ARCH=${ARCH} \
-e SECURITY_SERVICE_NEEDED=${SECURITY_SERVICE_NEEDED} \
-v /var/run/docker.sock:/var/run/docker.sock ${TAF_COMMON_IMAGE} \
--exclude Skipped --include SmokeTest -u functionalTest/device-service -p device-virtual"
dir ('TAF/testArtifacts/reports/rename-report') {
sh "cp ../edgex/log.html device-service-log.html"
sh "cp ../edgex/report.xml device-service-report.xml"
}
}
stage ("Stash Report - ${ARCH}${USE_SECURITY}${TAF_BRANCH}") {
echo '===== Merge Reports ====='
sh "docker run --rm --network host -v ${env.WORKSPACE}:${env.WORKSPACE}:z -w ${env.WORKSPACE} \
-e COMPOSE_IMAGE=${COMPOSE_IMAGE} ${TAF_COMMON_IMAGE} \
rebot --inputdir TAF/testArtifacts/reports/rename-report \
--outputdir TAF/testArtifacts/reports/smoke-${TAF_BRANCH}-report"
dir ("TAF/testArtifacts/reports/smoke-${TAF_BRANCH}-report") {
// Check if the merged-report folder exists
def mergeExist = sh (
script: 'ls ../ | grep merged-report',
returnStatus: true
)
if (mergeExist != 0) {
sh 'mkdir ../merged-report'
}
//Copy log file to merged-report folder
sh "cp log.html ../merged-report/smoke-${ARCH}${USE_SECURITY}${TAF_BRANCH}-log.html"
sh "cp result.xml ../merged-report/smoke-${ARCH}${USE_SECURITY}${TAF_BRANCH}-report.xml"
}
stash name: "smoke-${ARCH}${USE_SECURITY}${TAF_BRANCH}-report", includes: "TAF/testArtifacts/reports/merged-report/*", allowEmpty: true
}
stage ("Shutdown EdgeX - ${ARCH}${USE_SECURITY}${TAF_BRANCH}") {
sh "docker run --rm --network host -v ${env.WORKSPACE}:${env.WORKSPACE}:z -w ${env.WORKSPACE} \
-e COMPOSE_IMAGE=${COMPOSE_IMAGE} --security-opt label:disable \
-v /var/run/docker.sock:/var/run/docker.sock ${TAF_COMMON_IMAGE} \
--exclude Skipped --include shutdown-edgex -u shutdown.robot -p default"
}
}
}
parallel runbranchstage
}
return this