forked from sidd-harth/kubernetes-devops-security
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathJenkinsfile
91 lines (86 loc) · 2.66 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
pipeline {
agent any
stages {
stage('Build Artifact') {
steps {
sh "mvn clean package -DskipTests=true"
archive 'target/*.jar' //so
}
}
stage('Unit Tests - JUnit and Jacoco') {
steps {
sh "mvn test"
}
post {
always {
junit 'target/surefire-reports/*.xml'
jacoco execPattern: 'target/jacoco.exec'
}
}
}
stage('Mutation Tests - PIT') {
steps {
sh "mvn org.pitest:pitest-maven:mutationCoverage"
}
post {
always {
pitmutation mutationStatsFile: '**/target/pit-reports/**/mutations.xml'
}
}
}
// stage('SonarQube - SAST') {
// steps {
// withSonarQubeEnv('sonarcube'){
// sh "mvn sonar:sonar -Dsonar.projectKey=numeric-application -Dsonar.host.url=http://devsecops-aakash.eastus.cloudapp.azure.com:9000 -Dsonar.login=ef24409f636e6a68a31fdc65f8d1ea103b0d75bf"
// }
// timeout(time: 2, unit: 'MINUTES'){
// script{
// waitForQualityGate abortPipeline: true
// }
// }
// }
// }
stage('SonarQube - SAST') { //WebHook Sahi kia
steps {
withSonarQubeEnv('SonarCube') {
sh "mvn sonar:sonar -Dsonar.projectKey=numeric-application -Dsonar.host.url=http://devsecops-aakash.eastus.cloudapp.azure.com:9000 -Dsonar.login=ef24409f636e6a68a31fdc65f8d1ea103b0d75bf"
}
timeout(time: 8, unit: 'MINUTES') {
script {
waitForQualityGate abortPipeline: true
}
}
}
}
// Added Vulnerable version checking Dependency scan + trivy Scan
stage('Vulnerability Scan - Docker') {
steps {
parallel(
"Dependency Scan": {
sh "mvn dependency-check:check"
},
"Trivy Scan": {
sh "bash trivy-docker-image-scan.sh"
}
)
}
}
stage('Docker Build and Push'){
steps {
withDockerRegistry([credentialsId: "docker-hub", url: ""]){
sh 'printenv'
sh 'sudo docker build -t aakashrathee/numeric-app:""$GIT_COMMIT"" .'
sh 'docker push aakashrathee/numeric-app:""$GIT_COMMIT""' //git added a new stage
}
}
}
stage('Kubernetes Deployment - DEV') {
steps {
withKubeConfig([credentialsId: 'kubeconfig']) {
sh "sed -i 's#replace#aakashrathee/numeric-app:${GIT_COMMIT}#g' k8s_deployment_service.yaml"
sh "kubectl apply -f k8s_deployment_service.yaml"
}
}
}
}
}