refactor(executeFreeleapsPipeline): update generateComponentStages to accept configurations and improve build agent image handling

Signed-off-by: 孙振宇 <>
This commit is contained in:
孙振宇 2025-02-04 14:59:41 +08:00
parent a3e3788ee1
commit 43dbb2b7cd

View File

@ -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)
} }