ClaptrapBot/Jenkinsfile

57 lines
2.0 KiB
Plaintext
Raw Normal View History

2018-03-07 15:52:18 +01:00
pipeline {
agent any
stages {
def app
stage('Clone') { // for display purposes
// Get some code from a GitHub repository
echo env.BRANCH_NAME
script {
if (env.BRANCH_NAME == 'master') {
git url: 'https://github.com/BrokenFire/BrokenDiscordBot.git', branch: 'master'
} else {
git url: 'https://github.com/BrokenFire/BrokenDiscordBot.git', branch: 'devel'
}
}
2018-03-01 13:08:55 +01:00
2018-03-07 15:52:18 +01:00
}
stage('Gradle Build'){
script {
if (env.BRANCH_NAME == 'master') {
2018-03-01 13:17:32 +01:00
build job: 'Bot Discord Gradle', wait: true
2018-03-07 15:52:18 +01:00
} else {
build job: 'Bot Discord Gradle devel', wait: true
}
2018-03-01 13:17:32 +01:00
}
}
2018-03-07 15:52:18 +01:00
stage('Build Docker image') {
/* This builds the actual image; synonymous to
* docker build on the command line */
2018-02-18 12:13:50 +01:00
2018-03-07 15:52:18 +01:00
app = docker.build("brokenfire/brokendiscordbot",'--build-arg BUILD_NBR=${BUILD_NUMBER} --build-arg BRANCH_NAME=${BRANCH_NAME} --rm=true .')
}
stage('Push Docker image') {
/* Finally, we'll push the image with two tags:
* First, the incremental build number from Jenkins
* Second, the 'latest' tag.
* Pushing multiple tags is cheap, as all the layers are reused. */
withCredentials([[$class: 'UsernamePasswordMultiBinding', credentialsId: 'docker-hub-credentials', usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD']]) {
sh 'docker login -u $USERNAME -p $PASSWORD'
script {
if (env.BRANCH_NAME == 'master') {
app.push()
} else {
app.push("devel")
}
}
}
}
stage('Cleaning'){
sh "docker image prune -f"
}
2018-02-18 12:13:50 +01:00
}
2018-03-07 15:52:18 +01:00
}