refactor(executeFreeleapsPipeline): update generateComponentStages to accept configurations and improve build agent image handling
Signed-off-by: 孙振宇 <>
This commit is contained in:
parent
a3e3788ee1
commit
43dbb2b7cd
@ -7,32 +7,31 @@ import com.freeleaps.devops.enums.ServiceLanguage
|
|||||||
import com.freeleaps.devops.CommitMessageLinter
|
import com.freeleaps.devops.CommitMessageLinter
|
||||||
import com.freeleaps.devops.ChangedComponentsDetector
|
import com.freeleaps.devops.ChangedComponentsDetector
|
||||||
|
|
||||||
def generateComponentStages(component) {
|
def generateComponentStages(component, configurations) {
|
||||||
return [
|
return [
|
||||||
stage("${component.name} :: Build Agent Setup") {
|
stage("${component.name} :: Build Agent Setup") {
|
||||||
podTemplate(
|
|
||||||
label: "build-agent-${component.name}",
|
|
||||||
containers: [
|
|
||||||
containerTemplate(
|
|
||||||
name: 'build-agent',
|
|
||||||
image: component.buildAgentImage ?: 'python:3.10-slim-buster',
|
|
||||||
ttyEnabled: true,
|
|
||||||
command: 'cat'
|
|
||||||
)
|
|
||||||
]
|
|
||||||
) {
|
|
||||||
node("build-agent-${component.name}") {
|
|
||||||
steps {
|
|
||||||
script {
|
script {
|
||||||
if (env.executeMode == "fully" || env.changedComponents.contains(component.name)) {
|
if (env.executeMode == "fully" || env.changedComponents.contains(component.name)) {
|
||||||
def buildAgentImage = component.buildAgentImage ?: "python:3.10-slim-buster"
|
def buildAgentImage = component.buildAgentImage
|
||||||
|
if (buildAgentImage == null || buildAgentImage.isEmpty()) {
|
||||||
|
log.warn("Pipeline", "Not set buildAgentImage for ${component.name}, using default build agent image")
|
||||||
|
|
||||||
|
def language = ServiceLanguage.parse(configurations.serviceLang)
|
||||||
|
switch(language) {
|
||||||
|
case ServiceLanguage.PYTHON:
|
||||||
|
buildAgentImage = "python:3.10-slim-buster"
|
||||||
|
break
|
||||||
|
case ServiceLanguage.JS:
|
||||||
|
buildAgentImage = "node:lts-alpine"
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
error("Unknown service language")
|
||||||
|
}
|
||||||
|
}
|
||||||
log.info("Pipeline", "Using ${buildAgentImage} as build agent image for ${component.name}")
|
log.info("Pipeline", "Using ${buildAgentImage} as build agent image for ${component.name}")
|
||||||
env.buildAgentImage = buildAgentImage
|
env.buildAgentImage = buildAgentImage
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
|
||||||
stage("${component.name} :: Dependencies Resolving") {
|
stage("${component.name} :: Dependencies Resolving") {
|
||||||
@ -49,7 +48,6 @@ def generateComponentStages(component) {
|
|||||||
]
|
]
|
||||||
) {
|
) {
|
||||||
node("dep-resolver-${component.name}") {
|
node("dep-resolver-${component.name}") {
|
||||||
steps {
|
|
||||||
script {
|
script {
|
||||||
if (env.executeMode == "fully" || env.changedComponents.contains(component.name)) {
|
if (env.executeMode == "fully" || env.changedComponents.contains(component.name)) {
|
||||||
log.info("Pipeline", "Using ${env.buildAgentImage} as build agent image for dependencies resolving")
|
log.info("Pipeline", "Using ${env.buildAgentImage} as build agent image for dependencies resolving")
|
||||||
@ -74,85 +72,9 @@ def generateComponentStages(component) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
// def generateComponentStages(component) {
|
|
||||||
// return [
|
|
||||||
// stage("${component.name} :: Build Agent Setup") {
|
|
||||||
// script {
|
|
||||||
// if (env.executeMode == "fully" || env.changedComponents.contains(component.name)) {
|
|
||||||
// def buildAgentImage = component.buildAgentImage
|
|
||||||
// if (buildAgentImage == null || buildAgentImage.isEmpty()) {
|
|
||||||
// log.warn("Pipeline", "Not set buildAgentImage for ${component.name}, using default build agent image")
|
|
||||||
|
|
||||||
// def language = ServiceLanguage.parse(configurations.serviceLang)
|
|
||||||
// switch(language) {
|
|
||||||
// case ServiceLanguage.PYTHON:
|
|
||||||
// buildAgentImage = "python:3.10-slim-buster"
|
|
||||||
// break
|
|
||||||
// case ServiceLanguage.JS:
|
|
||||||
// buildAgentImage = "node:lts-alpine"
|
|
||||||
// break
|
|
||||||
// default:
|
|
||||||
// error("Unknown service language")
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// log.info("Pipeline", "Using ${buildAgentImage} as build agent image for ${component.name}")
|
|
||||||
// env.buildAgentImage = buildAgentImage
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// },
|
|
||||||
|
|
||||||
// stage("${component.name} :: Dependencies Resolving") {
|
|
||||||
// agent {
|
|
||||||
// kubernetes {
|
|
||||||
// defaultContainer 'dep-resolver'
|
|
||||||
// yaml """
|
|
||||||
// apiVersion: v1
|
|
||||||
// kind: Pod
|
|
||||||
// metadata:
|
|
||||||
// labels:
|
|
||||||
// freeleaps-devops-system/milestone: dependencies-resolving
|
|
||||||
// spec:
|
|
||||||
// containers:
|
|
||||||
// - name: dep-resolver
|
|
||||||
// image: ${env.buildAgentImage}
|
|
||||||
// command:
|
|
||||||
// - sleep
|
|
||||||
// args:
|
|
||||||
// - infinity
|
|
||||||
// """
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// steps {
|
|
||||||
// script {
|
|
||||||
// if (env.executeMode == "fully" || env.changedComponents.contains(component.name)) {
|
|
||||||
// log.info("Pipeline", "Build Agent sets to: ${env.buildAgentImage}")
|
|
||||||
// def sourceFetcher = new SourceFetcher(this)
|
|
||||||
// sourceFetcher.fetch(configurations)
|
|
||||||
|
|
||||||
// def language = ServiceLanguage.parse(component.language)
|
|
||||||
// def depManager = DependenciesManager.parse(component.dependenciesManager)
|
|
||||||
|
|
||||||
// def dependenciesResolver = new DependenciesResolver(this, language, env.workspace + "/" + component.root + "/")
|
|
||||||
// dependenciesResolver.useManager(depManager)
|
|
||||||
|
|
||||||
// if (component.buildCacheEnabled) {
|
|
||||||
// dependenciesResolver.enableCachingSupport()
|
|
||||||
// } else {
|
|
||||||
// dependenciesResolver.disableCachingSupport()
|
|
||||||
// }
|
|
||||||
|
|
||||||
// dependenciesResolver.resolve(component)
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// ]
|
|
||||||
// }
|
|
||||||
|
|
||||||
def call(Closure closure) {
|
def call(Closure closure) {
|
||||||
def configurations = [:]
|
def configurations = [:]
|
||||||
closure.resolveStrategy = Closure.DELEGATE_FIRST
|
closure.resolveStrategy = Closure.DELEGATE_FIRST
|
||||||
@ -258,7 +180,7 @@ spec:
|
|||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
configurations.components.each { component ->
|
configurations.components.each { component ->
|
||||||
def generatedStages = generateComponentStages(component)
|
def generatedStages = generateComponentStages(component, configurations)
|
||||||
generatedStages.each { stage ->
|
generatedStages.each { stage ->
|
||||||
stage(stage)
|
stage(stage)
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user