#!/usr/bin/env groovy env.APPLICATION_NAME = 'db-gateway' env.APPLICATION_LABEL = 'gateway' env.GIT_BRANCH = 'master' env.GIT_REPOSITORY_PATH = "github.com/andyjk15/${env.APPLICATION_NAME}.git" env.GIT_REPOSITORY_URL = "https://${env.GIT_REPOSITORY_PATH}" env.GITHUB_CREDENTIALS_ID = 'Registry' env.DOCKER_REPOSITORY = 'registry.cryptosky.me' env.DOCKER_REPOSITORY_URL = "https://${env.DOCKER_REPOSITORY}" env.DOCKER_REPOSITORY_TCP = "tcp://${env.DOCKER_REPOSITORY}:4243" env.NAMESPACE = 'production' env.SLAVE_LABEL = "cryptosky-aio-build" env.CPU_REQUESTS = '1' env.CPU_LIMIT = '2' env.RAM_REQUEST = '500MiB' env.RAM_LIMIT = '1Gi' def mvn( String gloals ) { sh "mvn -s configuration/settings.xml --show-version --batch-mode ${gloals}" } String get_application_version() { pom = readMavenPom file: 'pom.xml' "${pom.version}-b${env.BUILD_NUMBER}" } try { timestamps { node ("${env.SLAVE_LABEL}") { stage('Initialise') { checkout([$class: 'GitSCM', branches: [[name: 'master']], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: 'Github', url: 'https://github.com/andyjk15/db-gateway.git']]]) env.APPLICATION_VERSION = get_application_version() mvn '--version' withCredentials( [usernamePassword( credentialsId: 'doctl', passwordVariable: 'DOCTL_TOKEN', usernameVariable: 'DOCTL_USERNAME' )] ) { sh "doctl auth init --access-token '${DOCTL_TOKEN}'" sh "doctl kubernetes cluster kubeconfig save cryptosky-kubernetes-cluster-production" } } stage('Build Artifact') { mvn 'compile' } stage('Test Artifact') { try { mvn 'verify -DskipUTs -DskipTests' } finally { mvn 'test' } } stage('Build Image') { mvn 'clean package -DskipTests' sh "sed -i 's/REPOSITORY/${env.DOCKER_REPOSITORY}/g' configuration/kubernetes/deployment.yaml" sh "sed -i 's/IMAGE/${env.APPLICATION_NAME}:${env.APPLICATION_VERSION}/g' configuration/kubernetes/deployment.yaml" sh "sed -i 's/RESOURCE_NAME/${env.APPLICATION_NAME}/g' configuration/kubernetes/deployment.yaml" sh "sed -i 's/LABEL/${env.APPLICATION_LABEL}/g' configuration/kubernetes/deployment.yaml" sh "sed -it 's/RESOURCE_NAME/${env.APPLICATION_NAME}/g' configuration/kubernetes/service.yaml" sh "sed -it 's/LABEL/${env.APPLICATION_LABEL}/g' configuration/kubernetes/service.yaml" } stage('Tag Repository') { withDockerServer([uri: "${env.DOCKER_REPOSITORY_TCP}"]) { withDockerRegistry([credentialsId: 'Registry', url: "${env.DOCKER_REPOSITORY_URL}"]) { def image = docker.build("${env.DOCKER_REPOSITORY}/db-gateway:${env.APPLICATION_VERSION}") image.push() def latest = docker.build("${env.DOCKER_REPOSITORY}/db-gateway:latest") latest.push() } } // } // withCredentials( // [usernamePassword( // credentialsId: env.BITBUCKET_CREDENTIALS_ID, // passwordVariable: 'GIT_PASSWORD', // usernameVariable: 'GIT_USERNAME' // )] // ) { // sh "git tag ${env.APPLICATION_VERSION}" // sh "git push https://${GIT_USERNAME}:${GIT_PASSWORD}@${env.GIT_REPOSITORY_PATH} ${env.APPLICATION_VERSION}" // } } stage('Deploy') { sh "kubectl apply -f configuration/kubernetes/deployment.yaml" sh "kubectl apply -f configuration/kubernetes/service.yaml" sh "kubectl get pods" sh "kubectl rollout status deployment/${env.APPLICATION_NAME}" } } } } catch ( exception ) { currentBuild.result = 'FAILURE' throw exception } finally { sh "echo SUCCESS" }