forked from Ontotext-AD/graphdb-workbench
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Jenkinsfile
113 lines (96 loc) · 3.09 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
108
109
110
111
112
pipeline {
agent {
label 'graphdb-jenkins-node'
}
tools {
nodejs 'nodejs-20.11.1'
}
environment {
CI = "true"
NEXUS_CREDENTIALS = credentials('nexus-kim-user')
// Needed for our version of webpack + newer nodejs
NODE_OPTIONS = "--openssl-legacy-provider"
// Tells NPM and co. not to use color output (looks like garbage in Jenkins)
NO_COLOR = "1"
}
stages {
stage('Install') {
steps {
sh "npm install"
}
}
stage('Validate translations') {
steps {
sh 'node scripts/validate-translations.js || exit 1'
}
}
stage('Print Branch Name') {
steps {
script {
echo "Building branch: ${env.BRANCH_NAME}"
}
}
}
stage('Build') {
steps {
sh "npm run build"
}
}
stage('Sonar') {
steps {
withSonarQubeEnv('SonarCloud') {
script {
if (env.BRANCH_NAME == 'master') {
sh "node sonar-project.js --branch='${env.BRANCH_NAME}'"
} else {
sh "node sonar-project.js --branch='${env.ghprbSourceBranch}' --target-branch='${env.ghprbTargetBranch}' --pull-request-id='${env.ghprbPullId}'"
}
}
}
}
}
stage('Acceptance') {
when {
expression {
return env.BRANCH_NAME != 'master'
}
}
steps {
configFileProvider(
[configFile(fileId: 'ceb7e555-a3d9-47c7-9afe-d008fd9efb14', targetLocation: 'graphdb.license')]) {
sh 'cp graphdb.license ./test-cypress/fixtures/'
}
sh "ls ./test-cypress/fixtures/"
// --no-ansi suppresses color output that shows as garbage in Jenkins
sh "docker-compose --no-ansi build --force-rm --no-cache --parallel"
sh "docker-compose --no-ansi up --abort-on-container-exit --exit-code-from cypress-tests"
// Fix coverage permissions
sh "sudo chown -R \$(id -u):\$(id -g) coverage/"
sh "sudo chown -R \$(id -u):\$(id -g) cypress/"
sh "sudo chown -R \$(id -u):\$(id -g) report/"
// Move up to be picked by Sonar
// sh "mv test-cypress/coverage/ cypress-coverage/"
// sh "sync"
//
// // Update relative paths to absolute path
// sh "sed -i.backup \"s@^SF:..@SF:\$(pwd)@\" cypress-coverage/lcov.info"
}
}
}
post {
always {
// upload failed tests report and artifacts
junit allowEmptyResults: true, testResults: 'cypress/results/**/*.xml'
archiveArtifacts allowEmptyArchive: true, artifacts: 'report/screenshots/**/*.png, report/videos/**/*.mp4, cypress/logs/*.log'
// --no-ansi suppresses color output that shows as garbage in Jenkins
sh "docker-compose --no-ansi down -v --remove-orphans --rmi=local || true"
// clean root owned resources from docker volumes, just in case
sh "sudo rm -rf ./coverage"
sh "sudo rm -rf ./cypress"
sh "sudo rm -rf ./report"
}
failure {
archiveArtifacts artifacts: 'translation-validation-result.json', onlyIfSuccessful: false
}
}
}