-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathJenkinsfile
More file actions
116 lines (105 loc) · 3.5 KB
/
Jenkinsfile
File metadata and controls
116 lines (105 loc) · 3.5 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
@Library("JenkinsTesLib@main") _
pipeline {
agent any
environment {
dockerNamespace = "orcsin"
imageReference = ''
dockerImage = ''
}
stages {
stage('Checkout') {
steps {
echo 'Checkout'
checkout scm
}
}
stage('Build') {
steps {
echo 'Building'
sh 'chmod +x ./scripts/build.sh'
sh 'scripts/build.sh'
}
}
stage('Test') {
steps {
echo 'Testing'
sh 'chmod +x ./scripts/test.sh'
sh 'scripts/test.sh'
}
}
stage('Build docker image') {
steps {
echo 'Build docker image'
script {
def imageName = ''
if (env.BRANCH_NAME == 'main') {
imageName = "main"
} else if (env.BRANCH_NAME == 'dev') {
imageName = "dev"
}
imageReference = "${dockerNamespace}/node${imageName}:v1.0"
dockerImage = docker.build imageReference
}
}
}
/*
stage('Scan Docker Image for Vulnerabilities') {
steps {
script {
def vulnerabilities = sh(script: "trivy image --exit-code 0 --severity HIGH,MEDIUM,LOW --no-progress ${imageReference}", returnStdout: true).trim()
echo "Vulnerability report:\n${vulnerabilities}"
}
}
}
*/
stage('Deploy') {
steps {
echo 'Deploying Example'
deployToMaster ('version')
script {
def run_containers = sh(returnStdout: true, script: 'docker container ps -q').replaceAll("\n", " ")
def all_containers = sh(returnStdout: true, script: 'docker container ps -aq').replaceAll("\n", " ")
def all_containers_pattern = sh(returnStdout: true, script: "docker ps -aq --filter ancestor=${imageReference}").replaceAll("\n", " ")
if (run_containers){
sh "docker container kill ${run_containers}"
}
if (all_containers){
sh "docker container rm ${all_containers_pattern} | true"
}
def port = ""
if (env.BRANCH_NAME == 'main') {
port = '3000'
} else if (env.BRANCH_NAME == 'dev') {
port = '3001'
}
def container = dockerImage.run("--expose ${port} -p ${port}:3000")
sleep 10
container.stop()
}
}
}
stage('Push') {
steps {
script {
sh "echo ${dockerImage}"
docker.withRegistry('', 'docker_id') {
docker.image(imageReference).push('latest')
}
}
}
}
}
post ('Clean docker image') {
success {
script {
def branchName = env.BRANCH_NAME
if (branchName == 'dev') {
postJobName = 'Deploy_to_dev'
} else if (branchName == 'main') {
postJobName = 'Deploy_to_main'
}
build job: "${postJobName}"
}
}
}
}