generated from Monogramm/project-template
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathJenkinsfile
108 lines (92 loc) · 4.29 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
#!/usr/bin/env groovy
pipeline {
agent any
options {
buildDiscarder(logRotator(numToKeepStr: '5'))
}
/*
* Expected Parameters to create the Pipeline in Jenkins
* - gitlabSourceRepoURL:
* - https://scm.example.com/owner/project.git
* - The GitLab Source repository URL.
* If you use login / password credentials, this is expected to be a HTTPS URL, as in https://scm.example.com/path/to/project.git
* If you use SSH key credentials, this is expected to be a SSH URL, as in ssh://scm.example.com/path/to/project.git
* This is expected to be a HTTPS URL, as in https://scm.example.com/path/to/project.git, if you use login / password credentials.
* - sourceBranch:
* - heads/develop
* - The GitLab Source branch.
* Will be overriden by $gitlabSourceBranch in case of GitLab hook, pulling refs/heads/${gitlabSourceBranch}.
*
* The repository will be pulled from refs/${sourceBranch}. You can use the following formats:
* . heads/<branchName>
* * Tracks/checks out the specified branch. E.g. heads/master, heads/feature1/something
*
* . tags/<tagName>
* * Tracks/checks out the specified tag. E.g. tags/git-2.3.0
*/
parameters {
string(name: 'DOCKER_REPO', defaultValue: 'monogramm/vue-symfony-starter', description: 'Docker Image name.')
string(name: 'DOCKER_TAG', defaultValue: 'latest', description: 'Docker Image tag.')
choice(name: 'VARIANT', choices: ['alpine', 'debian'], description: 'Docker Image variant.')
string(name: 'DOCKER_REGISTRY', defaultValue: 'registry.hub.docker.com', description: 'Docker Registry to publish the result image.')
credentials(name: 'DOCKER_CREDENTIALS', credentialType: 'Username with password', required: true, defaultValue: 'dh-reg-ci', description: 'Docker credentials to push on the Docker registry.')
choice(name: 'APP_PUBLIC_URL', choices: ['https://app.example.com'], description: 'Application target domain name.')
choice(name: 'WEBSITE_PUBLIC_URL', choices: ['https://www.example.com'], description: 'Website target domain name.')
choice(name: 'STORIES', choices: ['true', 'false'], description: 'Build Storybook in build/storybook?')
choice(name: 'EXPORT_TESTS_RESULTS', choices: ['true', 'false'], description: 'Export tests results for future analysis?')
}
triggers {
cron('H 6 * * 1-5')
}
stages {
stage('pending') {
steps {
updateGitlabCommitStatus name: 'jenkins', state: 'pending'
}
}
stage('check docker') {
steps {
sh "docker --version"
sh "docker-compose --version"
sh "docker info"
}
}
stage('build-hooks') {
steps {
updateGitlabCommitStatus name: 'jenkins', state: 'running'
sh './hooks/run build "${VARIANT}"'
}
}
stage('test-hooks') {
steps {
updateGitlabCommitStatus name: 'jenkins', state: 'running'
sh './hooks/run test "${VARIANT}"'
}
}
stage('push-hooks') {
environment {
DOCKER_CREDS = credentials("${DOCKER_CREDENTIALS}")
}
steps {
updateGitlabCommitStatus name: 'jenkins', state: 'running'
// Write Docker image tags to push
sh '([ "${DOCKER_TAG}" = "latest" ] && echo "${VARIANT} " || echo "${DOCKER_TAG}-${VARIANT} ") > .dockertags'
// Export variables to login and push to Docker Registry
sh 'export DOCKER_LOGIN=${DOCKER_CREDS_USR}; export DOCKER_PASSWORD=${DOCKER_CREDS_PSW}; ./hooks/run push "${VARIANT}"'
sh 'rm -f .dockertags'
}
}
}
post {
always {
// Always cleanup after the build.
sh 'docker image prune -f --filter until=$(date -d "yesterday" +%Y-%m-%d)'
}
success {
updateGitlabCommitStatus name: 'jenkins', state: 'success'
}
failure {
updateGitlabCommitStatus name: 'jenkins', state: 'failed'
}
}
}