forked from microservices-demo/front-end
-
Notifications
You must be signed in to change notification settings - Fork 35
Expand file tree
/
Copy pathJenkinsfile
More file actions
119 lines (118 loc) · 4.07 KB
/
Jenkinsfile
File metadata and controls
119 lines (118 loc) · 4.07 KB
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
110
111
112
113
114
115
116
117
118
119
def _VERSION = 'UNKNOWN'
def _TAG = 'UNKNOWN'
def _TAG_DEV = 'UNKNOWN'
def _TAG_STAGING = 'UNKNOWN'
pipeline {
agent {
label 'nodejs'
}
environment {
APP_NAME = "front-end"
ARTEFACT_ID = "sockshop-" + "${env.APP_NAME}"
}
stages {
stage('Node build') {
steps {
// checkout scm
checkout([$class: 'GitSCM',
branches: [[name: "${env.BRANCH_NAME}"]],
doGenerateSubmoduleConfigurations: false,
extensions: [],
userRemoteConfigs: [[url: "https://github.com/${env.GITHUB_ORGANIZATION}/${env.APP_NAME}"]]
])
script {
_VERSION = readFile('version').trim()
_TAG = "${env.DOCKER_REGISTRY_URL}:5000/sockshop-registry/${env.ARTEFACT_ID}"
_TAG_DEV = "${_TAG}:${_VERSION}-${env.BUILD_NUMBER}"
_TAG_STAGING = "${_TAG}:${_VERSION}"
}
container('nodejs') {
sh 'npm install'
}
}
}
stage('Docker build') {
when {
expression {
return env.BRANCH_NAME ==~ 'release/.*' || env.BRANCH_NAME ==~'master'
}
}
steps {
container('docker') {
sh "docker build --no-cache -t ${_TAG_DEV} ."
}
}
}
stage('Docker push to registry') {
when {
expression {
return env.BRANCH_NAME ==~ 'release/.*' || env.BRANCH_NAME ==~'master'
}
}
steps {
container('docker') {
withCredentials([usernamePassword(credentialsId: 'registry-creds', passwordVariable: 'TOKEN', usernameVariable: 'USER')]) {
sh "docker login --username=anything --password=${TOKEN} ${env.DOCKER_REGISTRY_URL}:5000"
sh "docker tag ${_TAG_DEV} ${_TAG_DEV}"
sh "docker push ${_TAG_DEV}"
}
}
}
}
stage('Deploy to dev namespace') {
when {
expression {
return env.BRANCH_NAME ==~ 'release/.*' || env.BRANCH_NAME ==~'master'
}
}
steps {
container('kubectl') {
sh "sed -i 's#image: .*#image: ${_TAG_DEV}#' manifest/front-end.yml"
sh "kubectl -n dev apply -f manifest/front-end.yml"
}
}
}
stage('DT Deploy Event') {
when {
expression {
return env.BRANCH_NAME ==~ 'release/.*' || env.BRANCH_NAME ==~'master'
}
}
steps {
container("curl") {
// send custom deployment event to Dynatrace
sh "curl -X POST \"$DT_TENANT_URL/api/v1/events?Api-Token=$DT_API_TOKEN\" -H \"accept: application/json\" -H \"Content-Type: application/json\" -d \"{ \\\"eventType\\\": \\\"CUSTOM_DEPLOYMENT\\\", \\\"attachRules\\\": { \\\"tagRule\\\" : [{ \\\"meTypes\\\" : [\\\"SERVICE\\\"], \\\"tags\\\" : [ { \\\"context\\\" : \\\"CONTEXTLESS\\\", \\\"key\\\" : \\\"app\\\", \\\"value\\\" : \\\"${env.APP_NAME}\\\" }, { \\\"context\\\" : \\\"CONTEXTLESS\\\", \\\"key\\\" : \\\"environment\\\", \\\"value\\\" : \\\"dev\\\" } ] }] }, \\\"deploymentName\\\":\\\"${env.JOB_NAME}\\\", \\\"deploymentVersion\\\":\\\"${_VERSION}\\\", \\\"deploymentProject\\\":\\\"\\\", \\\"ciBackLink\\\":\\\"${env.BUILD_URL}\\\", \\\"source\\\":\\\"Jenkins\\\", \\\"customProperties\\\": { \\\"Jenkins Build Number\\\": \\\"${env.BUILD_ID}\\\", \\\"Git commit\\\": \\\"${env.GIT_COMMIT}\\\" } }\" "
}
}
}
stage('Mark artifact for staging namespace') {
when {
expression {
return env.BRANCH_NAME ==~ 'release/.*'
}
}
steps {
container('docker'){
sh "docker tag ${_TAG_DEV} ${_TAG_STAGING}"
sh "docker push ${_TAG_STAGING}"
}
}
}
stage('Deploy to staging') {
when {
beforeAgent true
expression {
return env.BRANCH_NAME ==~ 'release/.*'
}
}
steps {
build job: "k8s-deploy-staging",
parameters: [
string(name: 'APP_NAME', value: "${env.APP_NAME}"),
string(name: 'TAG_STAGING', value: "${_TAG_STAGING}"),
string(name: 'VERSION', value: "${_VERSION}")
]
}
}
}
}