[DO-1452] add build and deploy jobs from msg-auth (!98)

Co-authored-by: Ilya Zaharenkov <ilya.zaharenkov@avroid.tech>
Co-authored-by: Denis Patrakeev <denis.patrakeev@avroid.team>
Co-authored-by: Rustam Tagaev <rustam.tagaev@avroid.team>
Reviewed-on: https://git.avroid.tech/DevOps/jenkins-pipelines/pulls/98
Reviewed-by: Denis Patrakeev <denis.patrakeev@avroid.team>
Reviewed-by: Aleksandr Vodyanov <aleksandr.vodyanov@avroid.team>
Reviewed-by: Rustam Tagaev <rustam.tagaev@avroid.team>
This commit is contained in:
Ilya Zaharenkov
2025-03-07 12:51:23 +03:00
parent 63fdf8e539
commit bde6e3fc4b
4 changed files with 412 additions and 0 deletions

View File

@@ -0,0 +1,104 @@
@Library('shared-lib') _
import tech.avroid.kube.PodTemplates
import tech.avroid.scm.Git
properties([
buildDiscarder(logRotator(daysToKeepStr: '10',
numToKeepStr: '10')),
disableConcurrentBuilds()
])
Git git = new Git(this, env.JENKINS_GIT_CREDENTIALS_SSH)
String repoPath = 'Apps-Backend/msg-auth.git'
Map envBranch = [
'DEV': 'develop',
// 'TEST': 'test'
]
String dockerGroup = 'cloud'
String dockerProject = 'msg-auth'
String projectSettingFile = 'pyproject.toml'
Map gitVars = [:]
String tag = ''
String branch = git.getBranch()
String publishBranch = envBranch.find { it.value == branch }?.value
Map configuration = [
vaultUrl: env.JENKINS_VAULT_URL,
vaultCredentialId: env.JENKINS_VAULT_TOKEN,
engineVersion: 2
]
List dockerCreds = [
[path: 'team-devops/services/registry/Harbor/harbor.avroid.tech', engineVersion: 2,
secretValues:
[
[vaultKey: 'service.user.jenkins.ci.login'],
[vaultKey: 'service.user.ci.token'],
]
]
]
slaveTemplates = new PodTemplates(this, env.JENKINS_DOCKER_REGISTRY, ["${env.JENKINS_K8S_HARBOR_SECRET}"])
slaveTemplates.jnlp {
slaveTemplates.poetry {
slaveTemplates.docker {
node(POD_LABEL){
stage('Download sources') {
gitVars = git.clone([urlRepo: "${env.JENKINS_GIT_REPOSITORY_SSH_URL}/${repoPath}",
branch: branch])
}
stage('prepare app'){
container('poetry'){
sh 'make setup'
}
}
withVault([configuration: configuration, vaultSecrets: dockerCreds]) {
String ciUser = getProperty('service.user.jenkins.ci.login')
String dockerToken = getProperty('service.user.ci.token')
container('docker'){
Map props = readTOML file: projectSettingFile
String version = props.tool.poetry.version
tag = "${version}-${gitVars.GIT_COMMIT.take(5)}"
currentBuild.description = tag
String imageName = "${env.JENKINS_DOCKER_REGISTRY}/" +
"${dockerGroup}/${dockerProject}:${tag}"
docker.withRegistry("https://${env.JENKINS_DOCKER_REGISTRY}", env.JENKINS_HARBOR_CREDENTIALS) {
stage('build image and push'){
Object buildImage = docker.build(imageName,
"--build-arg PIP_INDEX_URL=${env.JENKINS_PIP_INDEX_URL} -f Dockerfile ."
)
if (publishBranch != null && publishBranch.contains(branch)) {
buildImage.push()
}
}
}
stage('deploy application'){
if (publishBranch != null && publishBranch.contains(branch)){
build job: 'Cloud/Deploy/Backend/msg-auth-deploy',
parameters: [
string(name: 'ENV', value: envBranch.find { it.value == branch }?.key ),
string(name: 'APP_VERSION', value: tag)
],
wait: false
}
}
}
}
}
}
}
}