added steps to Jenkins pipeline

This commit is contained in:
Bulat Yusupov 2020-07-23 19:19:36 +03:00
parent 3be3949916
commit 31a8da939c

67
Jenkinsfile vendored
View file

@ -1,4 +1,4 @@
def TAG def VERSION
pipeline { pipeline {
options { options {
@ -53,22 +53,20 @@ spec:
} }
} }
stages { stages {
stage('Create release branch') { stage('Checkout release branch') {
steps { steps {
git 'https://github.com/provectus/kafka-ui.git'
sh 'git checkout -b release' sh 'git checkout -b release'
sh 'git merge master'
} }
} }
stage('Build artifact') { stage('Merge to release branch') {
steps {
sh 'git merge origin/ci-cd'
}
}
stage('Remove SNAPSHOT from version') {
steps { steps {
container('docker-client') { container('docker-client') {
sh "docker run -v ${WORKSPACE}:/usr/src/mymaven -v /tmp/repository:/root/.m2/repository -w /usr/src/mymaven maven:3.6.3-jdk-13 /bin/sh -c 'mvn versions:set -DremoveSnapshot && mvn clean install'" sh "docker run -v $WORKSPACE:/usr/src/mymaven -v /tmp/repository:/root/.m2/repository -w /usr/src/mymaven maven:3.6.3-jdk-13 bash -c 'mvn versions:set -DremoveSnapshot'"
}
}
post {
success {
archiveArtifacts(artifacts: '**/target/*.jar', allowEmptyArchive: true)
} }
} }
} }
@ -76,9 +74,15 @@ spec:
steps { steps {
script { script {
pom = readMavenPom file: 'pom.xml' pom = readMavenPom file: 'pom.xml'
TAG = pom.version VERSION = pom.version
// sh 'git log $(git describe --tags --abbrev=0)..HEAD --oneline' sh "git tag -f v$VERSION"
sh "git tag -f ${TAG}" }
}
}
stage('Build artifact') {
steps {
container('docker-client') {
sh "docker run -v $WORKSPACE:/usr/src/mymaven -v /tmp/repository:/root/.m2/repository -w /usr/src/mymaven maven:3.6.3-jdk-13 bash -c 'mvn clean install'"
} }
} }
} }
@ -87,7 +91,7 @@ spec:
container('docker-client') { container('docker-client') {
dir(path: './kafka-ui-api') { dir(path: './kafka-ui-api') {
script { script {
dockerImage = docker.build( registry + ":$TAG", "--build-arg JAR_FILE=*.jar -f Dockerfile ." ) dockerImage = docker.build( registry + ":VERSION", "--build-arg JAR_FILE=*.jar -f Dockerfile ." )
} }
} }
} }
@ -108,14 +112,41 @@ spec:
stage('Remove unused docker image') { stage('Remove unused docker image') {
steps{ steps{
container('docker-client') { container('docker-client') {
sh "docker rmi $registry:$TAG" sh "docker rmi $registry:VERSION"
} }
} }
} }
stage('Tag release') { stage('Create github release with text from commits') {
steps { steps {
script { script {
sh "git push -f --tags" withCredentials([usernamePassword(credentialsId: 'github-jenkins-internal-provectus', passwordVariable: 'GIT_PASSWORD', usernameVariable: 'GIT_USER')]) {
sh "git push -f --tags https://$GIT_USER:$GIT_PASSWORD@github.com/provectus/kafka-ui.git"
sh "bash release_json.sh v$VERSION"
sh "curl -XPOST -u $GIT_USER:$GIT_PASSWORD --data @/tmp/release.json https://api.github.com/repos/provectus/kafka-ui/releases"
}
}
}
}
stage('Checkout master') {
steps {
sh 'git checkout origin/ci-cd'
}
}
stage('Increase version in master') {
steps {
container('docker-client') {
sh "docker run -v $WORKSPACE:/usr/src/mymaven -v /tmp/repository:/root/.m2/repository -w /usr/src/mymaven maven:3.6.3-jdk-13 bash -c 'mvn build-helper:parse-version versions:set -DnewVersion=\\\${parsedVersion.majorVersion}.\\\${parsedVersion.minorVersion}.\\\${parsedVersion.nextIncrementalVersion}-SNAPSHOT versions:commit'"
}
}
}
stage('Push to master') {
steps {
script {
withCredentials([usernamePassword(credentialsId: 'github-jenkins-internal-provectus', passwordVariable: 'GIT_PASSWORD', usernameVariable: 'GIT_USER')]) {
sh "git add ."
sh "git -c user.name=\"$GIT_USER\" -c user.email=\"\" commit -m \"Increased version\""
sh "git push https://$GIT_USER:$GIT_PASSWORD@github.com/provectus/kafka-ui.git HEAD:ci-cd"
}
} }
} }
} }