forked from controlplaneio/kubesec
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Jenkinsfile
100 lines (83 loc) · 2.01 KB
/
Jenkinsfile
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
#!/usr/bin/env groovy
def getDockerImageTag() {
if (env.GIT_COMMIT == "") {
error "GIT_COMMIT value was empty at usage. "
}
return "${env.BUILD_ID}-${env.GIT_COMMIT}"
}
pipeline {
agent none
environment {
ENVIRONMENT = 'ops'
DOCKER_IMAGE_TAG = "${getDockerImageTag()}"
}
stages {
stage('GPG Verify') {
// agent is require to check out source and get GIT_URL
agent {
docker { image 'docker.io/controlplane/gcloud-sdk:latest' }
}
options {
timeout(time: 15, unit: 'MINUTES')
retry(1)
timestamps()
}
steps {
ansiColor('xterm') {
sh "echo Verifying GPG signatures for: ${env.GIT_URL}"
}
build job: 'git-gpg-verify', parameters: [
string(
name: 'GIT_REPO',
value: "${env.GIT_URL}"
)
]
}
}
stage('Test') {
agent {
docker { image 'docker.io/controlplane/gcloud-sdk:latest' }
}
options {
timeout(time: 15, unit: 'MINUTES')
retry(1)
timestamps()
}
steps {
ansiColor('xterm') {
sh 'make test'
}
}
}
stage('Push') {
agent {
docker {
image 'docker.io/controlplane/gcloud-sdk:latest'
args '-v /var/run/docker.sock:/var/run/docker.sock ' +
'--user=root ' +
'--cap-drop=ALL ' +
'--cap-add=DAC_OVERRIDE'
}
}
environment {
DOCKER_REGISTRY_CREDENTIALS = credentials("${ENVIRONMENT}_docker_credentials")
}
options {
timeout(time: 15, unit: 'MINUTES')
retry(1)
timestamps()
}
steps {
ansiColor('xterm') {
sh """
echo '${DOCKER_REGISTRY_CREDENTIALS_PSW}' \
| docker login \
--username '${DOCKER_REGISTRY_CREDENTIALS_USR}' \
--password-stdin
make push DOCKER_IMAGE_TAG="${DOCKER_IMAGE_TAG}"
"""
}
}
}
}
}