[DO-1361] add avroid service lib and DSL job for it (!51)
Co-authored-by: Rustam Tagaev <rustam.tagaev@avroid.tech> Reviewed-on: https://git.avroid.tech/DevOps/jenkins-pipelines/pulls/51 Reviewed-by: Denis Patrakeev <denis.patrakeev@avroid.team> Co-authored-by: Rustam Tagaev <rustam.tagaev@avroid.team> Co-committed-by: Rustam Tagaev <rustam.tagaev@avroid.team>
This commit is contained in:
committed by
Denis Patrakeev
parent
8b82e59ee2
commit
1454578765
101
jobs-dsl/jobs/Cloud/Apps-Backend/avroid_service_lib.groovy
Normal file
101
jobs-dsl/jobs/Cloud/Apps-Backend/avroid_service_lib.groovy
Normal file
@@ -0,0 +1,101 @@
|
||||
multibranchPipelineJob('Cloud/Apps-Backend/avroid-service-lib') {
|
||||
description('avroid-service-lib')
|
||||
displayName('avroid-service-lib')
|
||||
factory {
|
||||
remoteJenkinsFileWorkflowBranchProjectFactory {
|
||||
localMarker('')
|
||||
matchBranches(true)
|
||||
fallbackBranch('master')
|
||||
lookupInParameters(false)
|
||||
remoteJenkinsFile('pipelines/Cloud/Apps-Backend/avroid-service-lib.groovy')
|
||||
remoteJenkinsFileSCM {
|
||||
gitSCM {
|
||||
userRemoteConfigs {
|
||||
userRemoteConfig {
|
||||
url('https://git.avroid.tech/DevOps/jenkins-pipelines.git')
|
||||
credentialsId('user-jenkins-in-gitea')
|
||||
name('')
|
||||
refspec('')
|
||||
}
|
||||
}
|
||||
gitTool('')
|
||||
browser {}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
branchSources {
|
||||
branchSource {
|
||||
source {
|
||||
giteaSCMSource {
|
||||
serverUrl('https://git.avroid.tech')
|
||||
repoOwner('Apps-Backend')
|
||||
repository('avroid-service-lib')
|
||||
credentialsId('user-jenkins-in-gitea')
|
||||
id('Apps-Backend/avroid-service-lib')
|
||||
traits {
|
||||
giteaBranchDiscovery {
|
||||
// 1 Exclude branches that are also filed as PRs
|
||||
// 2 Only branches that are also filed as PRs
|
||||
// 3 Only branches that are also filed as PRs or main
|
||||
// 4 All branches
|
||||
strategyId(1)
|
||||
}
|
||||
|
||||
giteaPullRequestDiscovery {
|
||||
// 1 Merging the pull request with the current target branch revision
|
||||
// 2 The current pull request revision
|
||||
// 3 Both the current pull request revision and the pull request merged with
|
||||
// the current target branch revision
|
||||
strategyId(2)
|
||||
}
|
||||
|
||||
giteaForkDiscovery {
|
||||
// 1 Merging the pull request with the current target branch revision
|
||||
// 2 The current pull request revision
|
||||
// 3 Both the current pull request revision and the pull request merged with
|
||||
// the current target branch revision
|
||||
strategyId(2)
|
||||
trust {
|
||||
giteaTrustContributors()
|
||||
}
|
||||
}
|
||||
|
||||
giteaTagDiscovery()
|
||||
pruneStaleBranch()
|
||||
pruneStaleTag()
|
||||
|
||||
refSpecs {
|
||||
templates {
|
||||
refSpecTemplate {
|
||||
value('+refs/heads/*:refs/remotes/@{remote}/*')
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
// uncomment after reload jenkins
|
||||
// buildStrategies {
|
||||
// buildRegularBranches()
|
||||
// buildTags {
|
||||
// atLeastDays("")
|
||||
// atMostDays("7")
|
||||
// }
|
||||
// }
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
orphanedItemStrategy {
|
||||
discardOldItems {
|
||||
numToKeep(20)
|
||||
}
|
||||
|
||||
defaultOrphanedItemStrategy {
|
||||
pruneDeadBranches(true)
|
||||
numToKeepStr('10')
|
||||
daysToKeepStr('10')
|
||||
}
|
||||
}
|
||||
}
|
||||
93
pipelines/Cloud/Apps-Backend/avroid-service-lib.groovy
Normal file
93
pipelines/Cloud/Apps-Backend/avroid-service-lib.groovy
Normal file
@@ -0,0 +1,93 @@
|
||||
@Library('shared-lib') _
|
||||
|
||||
import tech.avroid.kube.PodTemplates
|
||||
import tech.avroid.scm.Git
|
||||
import tech.avroid.api.Nexus
|
||||
import tech.avroid.jenkins.Notifications
|
||||
|
||||
properties([
|
||||
buildDiscarder(logRotator(artifactDaysToKeepStr: '',
|
||||
artifactNumToKeepStr: '30',
|
||||
daysToKeepStr: '',
|
||||
numToKeepStr: '30')),
|
||||
disableConcurrentBuilds()
|
||||
])
|
||||
|
||||
Git git = new Git(this, env.JENKINS_GIT_CREDENTIALS_SSH)
|
||||
Nexus nexus = new Nexus(this, env.JENKINS_NEXUS_URL, env.JENKINS_NEXUS_CREDENTIALS)
|
||||
|
||||
String repoPath = 'Apps-Backend/avroid-service-lib.git'
|
||||
String nexusRepoName = 'tavro-cloud-pypi-release'
|
||||
String artifactUrl = "${env.JENKINS_NEXUS_URL}/repository/${nexusRepoName}"
|
||||
String localArtifactDir = './dist'
|
||||
|
||||
Map gitVars = [:]
|
||||
Map author = [:]
|
||||
|
||||
slaveTemplates = new PodTemplates(this, env.JENKINS_DOCKER_REGISTRY, ["${env.JENKINS_K8S_HARBOR_SECRET}"])
|
||||
|
||||
slaveTemplates.jnlp {
|
||||
slaveTemplates.poetry {
|
||||
slaveTemplates.docker {
|
||||
slaveTemplates.git {
|
||||
node(POD_LABEL){
|
||||
try {
|
||||
container('poetry'){
|
||||
stage('Download sources') {
|
||||
gitVars = git.clone([urlRepo: "${env.JENKINS_GIT_REPOSITORY_SSH_URL}/${repoPath}",
|
||||
branch: git.getBranch()])
|
||||
}
|
||||
|
||||
stage('prepare app'){
|
||||
sh 'make setup'
|
||||
}
|
||||
|
||||
stage('build lib'){
|
||||
sh 'make build'
|
||||
}
|
||||
}
|
||||
|
||||
container('git'){
|
||||
stage('push lib to nexus'){
|
||||
author = git.getAuthor(commit: gitVars.GIT_COMMIT)
|
||||
|
||||
if (env.TAG_NAME) {
|
||||
print "Upload from tag ${env.TAG_NAME}"
|
||||
|
||||
dir(localArtifactDir){
|
||||
String artifact = sh(
|
||||
script: """#!/bin/sh
|
||||
ls *.whl
|
||||
""",
|
||||
returnStdout: true).trim()
|
||||
print artifact
|
||||
nexus.uploadPypiArtifact(
|
||||
artifact: "${artifact}",
|
||||
repository: nexusRepoName
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
errorMessage = err.getMessage()
|
||||
|
||||
println 'ERROR: ' + errorMessage
|
||||
|
||||
currentBuild.result = 'FAILURE'
|
||||
|
||||
String emailSubject = "${currentBuild.currentResult}. " +
|
||||
"Pipeline task: ${currentBuild.fullDisplayName}"
|
||||
Notifications.email(
|
||||
script: this,
|
||||
subject: emailSubject,
|
||||
errorString: errorMessage,
|
||||
recipientProviders: [],
|
||||
to: author.email
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user