-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbasic-angular4-spring-boot-jenkinsfile
More file actions
123 lines (104 loc) · 3 KB
/
basic-angular4-spring-boot-jenkinsfile
File metadata and controls
123 lines (104 loc) · 3 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
120
121
122
123
pipeline {
agent {
node {
label 'master'
}
}
environment {
JENKINS_NODE_COOKIE = 'dontkill'
}
stages {
stage('Preparation') { // for display purposes
steps {
// clean the workspace
cleanWs()
}
}
stage('Download') {
steps {
// Download code from a GitHub repository
git branch: 'staging', url: 'https://github.com/revalution/janus-webapp.git'
}
}
stage('NPM Install') {
steps {
// go into client-side directory
dir('client-side') {
// install node modules
sh 'npm install'
}
}
}
stage('NPM Build') {
steps {
dir('client-side') {
// build Angular app
sh 'npm run build-uat'
}
}
}
stage('MVN Build') {
steps {
dir('spring-boot-server') {
// Run the maven build
sh "mvn -Dmaven.test.failure.ignore clean package"
}
}
}
stage('Destroy Old Server') {
steps {
script {
try {
// kill any running instances
sh "fuser -k 8088/tcp"
} catch (all) {
// if it fails that should mean a server wasn't already running
}
}
}
}
stage('Deploy') {
/*
* deploying a docker container example
agent {
docker {
image 'openjdk/8-jre'
label 'janus-server'
args ''
}
}
*/
steps {
dir('spring-boot-server') {
dir ('target') {
// run the Janus server
sh "nohup java -jar janus-server.jar &"
}
}
}
}
}
post {
always {
sh "echo 'i always run'"
/* SLACK message example
slackSend channel: '#some-channel',
color: 'good',
message: "The Janus server has attempted a build"
*/
}
success {
sh "echo 'i only run on success'"
}
unstable {
sh "echo 'i run when the build is unstable (testing?)'"
}
failure {
sh "echo 'i run when things failed'"
}
changed {
sh "echo 'i run when there is a successful build after a failed one'"
sh "echo 'or a failed build after a successful one'"
}
}
}