forked from watri/demo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathJenkinsfile
107 lines (103 loc) · 4.38 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
101
102
103
104
105
106
107
pipeline {
agent any
environment {
PATH = "$PATH:/usr/local/bin/"
IMAGETAG = ""
}
triggers {
GenericTrigger (
causeString: 'Triggered on push', genericVariables: [[defaultValue: '', key: 'branch', regexpFilter: '', value: '$.push.changes[0].old.name']], printContributedVariables: true, printPostContent: true, regexpFilterExpression: '^(master)*?$', regexpFilterText: '$branch', token: 'demo', tokenCredentialId: ''
)
}
stages {
stage('Git Clone') {
steps {
cleanWs()
git branch: 'master', credentialsId: 'github-login', url: 'https://github.com/watri/demo.git'
// checkout scmGit(branches: [[name: '*/master']], extensions: [], userRemoteConfigs: [[url: 'https://github.com/watri/demo.git']])
}
}
stage('Change jar version') {
steps {
sh '''
#!/bin/bash
sed -i "s|dcid|${BUILD_NUMBER}|g" pom.xml
sed -i "s|dcid|${BUILD_NUMBER}|g" Dockerfile
whoami
'''
}
}
stage('Dockerfie Scan Hadolint') {
steps {
sh 'hadolint --config hadolint.yaml Dockerfile'
}
}
stage('Build') {
steps {
script{
IMAGETAG = sh(script: 'git rev-parse --short HEAD', returnStdout: true).trim() + BUILD_NUMBER
echo "Image Tag: ${IMAGETAG}"
}
sh "docker build -t watri/demo:${IMAGETAG} -f Dockerfile ."
}
}
stage('Image Scan Trivy') {
steps {
sh "echo trivy scan"
// sh "trivy image --config trivy.yaml watri/demo:${IMAGETAG}"
}
}
stage('Push Image to Registry') {
steps {
withDockerRegistry([ credentialsId: 'docker-hub-cred', url: '' ]) {
sh "docker push watri/demo:${IMAGETAG}"
}
}
}
stage('Update Values File for ArgoCD') {
environment {
GIT_REPO_NAME = "demo-chart"
GIT_USER_NAME = "watri"
}
steps {
dir('demo-chart') {
git branch: 'master', credentialsId: 'github-login', url: 'https://github.com/watri/demo-chart.git'
withCredentials([string(credentialsId: 'github-key', variable: 'GITHUB_TOKEN')]) {
script {
sh """
git config user.email "[email protected]"
git config user.name "watri"
currenttag=\$(yq .image.tag charts/demo/values-prod.yaml)
yq -i '.image.tag = "${IMAGETAG}"' charts/demo/values-prod.yaml
git add charts/demo/values-prod.yaml
git commit -m "Update image to version ${IMAGETAG}"
git push https://${GITHUB_TOKEN}@github.com/${GIT_USER_NAME}/${GIT_REPO_NAME} HEAD:master
"""
}
}
}
}
}
// stage('Deploy to Cluster') {
// steps {
// sh '''
// #!/bin/bash
// echo "Deploying to Docker destop Cluster"
// helm upgrade --install --wait --timeout=300s demo-service demo/demo --set=image.tag=$(git rev-parse --short HEAD)${BUILD_NUMBER} --namespace=prod --kube-context=docker-desktop -f deployment/values-prod.yaml
// '''
// // sed -i "s|latest|$(git rev-parse --short HEAD)${BUILD_NUMBER}|g" deployment/deployment.yaml
// // kubectl config use-context docker-desktop && kubectl apply -f deployment/deployment.yaml
// sh '''
// #!/bin/bash
// echo "Deployment Check Development"
// kubectl config use-context docker-desktop && kubectl rollout status deployment/demo-service -n prod --timeout=300s
// '''
// }
// }
}
// post {
// always {
// archiveArtifacts artifacts: 'result.html', followSymlinks: false
// }
// }
}