generated from hmcts/spring-boot-template
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Jenkinsfile_CNP
109 lines (90 loc) · 3.58 KB
/
Jenkinsfile_CNP
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#!groovy
@Library("Infrastructure")
import uk.gov.hmcts.contino.GradleBuilder
def type = "java"
def product = "disposer"
def component = "idam-user"
def branchesToSync = ['demo','perftest','ithc']
GradleBuilder builder = new GradleBuilder(this, product)
def secrets = [
'disposer-${env}': [
secret('app-insights-connection-string', 'app-insights-connection-string'),
secret('idam-client-secret', 'DISPOSER_IDAM_USER_CLIENT_SECRET'),
secret('s2s-secret-disposer-idam-user', 'S2S_SECRET_DISPOSER_IDAM_USER'),
secret('idam-citizen-disposer-system-user-username', 'IDAM_CLIENT_USERNAME'),
secret('idam-citizen-disposer-system-user-password', 'IDAM_CLIENT_PASSWORD')
]
]
static LinkedHashMap<String, Object> secret(String secretName, String envVar) {
[$class : 'AzureKeyVaultSecret',
secretType : 'Secret',
name : secretName,
version : '',
envVariable: envVar
]
}
withPipeline(type, product, component) {
afterAlways('test') {
builder.gradle('integration')
}
enableAksStagingDeployment()
disableLegacyDeployment()
nonServiceApp()
syncBranchesWithMaster(branchesToSync)
enableSlackNotifications('#disposer-builds')
//enableFortifyScan()
loadVaultSecrets(secrets)
afterAlways('test') {
junit 'build/test-results/test/**/*.xml'
archiveArtifacts 'build/reports/tests/test/index.html'
publishHTML target: [
allowMissing : true,
alwaysLinkToLastBuild: true,
keepAll : true,
reportDir : "build/reports/tests/test",
reportFiles : "index.html",
reportName : "disposer-idam-user Test Report"
]
}
afterAlways('akschartsinstall') {
// Set required environment variables to run functional tests apart from one in vaults.
env.S2S_URL = 'http://rpe-service-auth-provider-aat.service.core-compute-aat.internal'
env.IDAM_API_URL = 'https://idam-api.aat.platform.hmcts.net'
env.ROLE_ASSIGNMENT_HOST = 'http://am-role-assignment-service-aat.service.core-compute-aat.internal'
env.LAU_API_URL = 'http://lau-idam-backend-aat.service.core-compute-aat.internal'
echo "Just waiting a while to ensure that the pod has run the job"
sh "sleep 120s"
// Execute functional tests
echo "Verifying that functional test data was processed correctly"
try {
builder.gradle('functional')
echo "Verifying that functional test run completed"
} finally {
junit '**/test-results/**/*.xml'
}
}
afterAlways('functionalTest:preview') {
junit 'build/test-results/functional/**/*.xml'
archiveArtifacts 'build/reports/tests/functional/index.html'
publishHTML target: [
allowMissing : true,
alwaysLinkToLastBuild: true,
keepAll : true,
reportDir : "build/reports/tests/functional",
reportFiles : "index.html",
reportName : "disposer-idam-user Functional Test Report"
]
}
afterAlways('functionalTest:aat') {
junit 'build/test-results/functional/**/*.xml'
archiveArtifacts 'build/reports/tests/functional/index.html'
publishHTML target: [
allowMissing : true,
alwaysLinkToLastBuild: true,
keepAll : true,
reportDir : "build/reports/tests/functional",
reportFiles : "index.html",
reportName : "disposer-idam-user Functional Test Report"
]
}
}