From 2686e017ceca21671d47a6f8d5703ad94b7f0615 Mon Sep 17 00:00:00 2001 From: Helber Belmiro Date: Wed, 8 Jan 2025 11:06:21 -0300 Subject: [PATCH] chore(backend): Fixed ServiceAccount in job creation (#11481) Signed-off-by: Helber Belmiro --- .../apiserver/resource/resource_manager.go | 19 ++++++++++--------- .../src/apiserver/template/template_test.go | 7 ++++--- backend/src/apiserver/template/v2_template.go | 6 ++++-- 3 files changed, 18 insertions(+), 14 deletions(-) diff --git a/backend/src/apiserver/resource/resource_manager.go b/backend/src/apiserver/resource/resource_manager.go index cc9c865eb2d..0e804de1dc7 100644 --- a/backend/src/apiserver/resource/resource_manager.go +++ b/backend/src/apiserver/resource/resource_manager.go @@ -1007,18 +1007,19 @@ func (r *ResourceManager) CreateJob(ctx context.Context, job *model.Job) (*model for _, modelRef := range job.ResourceReferences { modelRef.ResourceUUID = string(swf.UID) } - // Get the service account - serviceAccount := "" - if swf.Spec.Workflow != nil { - execSpec, err := util.ScheduleSpecToExecutionSpec(util.ArgoWorkflow, swf.Spec.Workflow) - if err == nil { - serviceAccount = execSpec.ServiceAccount() - } - } - job.ServiceAccount = serviceAccount if tmpl.GetTemplateType() == template.V1 { + // Get the service account + serviceAccount := "" + if swf.Spec.Workflow != nil { + execSpec, err := util.ScheduleSpecToExecutionSpec(util.ArgoWorkflow, swf.Spec.Workflow) + if err == nil { + serviceAccount = execSpec.ServiceAccount() + } + } + job.ServiceAccount = serviceAccount job.PipelineSpec.WorkflowSpecManifest = manifest } else { + job.ServiceAccount = newScheduledWorkflow.Spec.ServiceAccount job.PipelineSpec.PipelineSpecManifest = manifest } return r.jobStore.CreateJob(job) diff --git a/backend/src/apiserver/template/template_test.go b/backend/src/apiserver/template/template_test.go index 98e7482bf46..27c9817cb60 100644 --- a/backend/src/apiserver/template/template_test.go +++ b/backend/src/apiserver/template/template_test.go @@ -217,9 +217,10 @@ func TestScheduledWorkflow(t *testing.T) { Parameters: []scheduledworkflow.Parameter{{Name: "y", Value: "\"world\""}}, Spec: "", }, - PipelineId: "1", - PipelineName: "pipeline name", - NoCatchup: util.BoolPointer(true), + PipelineId: "1", + PipelineName: "pipeline name", + NoCatchup: util.BoolPointer(true), + ServiceAccount: "pipeline-runner", }, } diff --git a/backend/src/apiserver/template/v2_template.go b/backend/src/apiserver/template/v2_template.go index d14ddffdaeb..1055bcdf8a9 100644 --- a/backend/src/apiserver/template/v2_template.go +++ b/backend/src/apiserver/template/v2_template.go @@ -97,7 +97,9 @@ func (t *V2Spec) ScheduledWorkflow(modelJob *model.Job) (*scheduledworkflow.Sche if modelJob.Namespace != "" { executionSpec.SetExecutionNamespace(modelJob.Namespace) } - setDefaultServiceAccount(executionSpec, modelJob.ServiceAccount) + if executionSpec.ServiceAccount() == "" { + setDefaultServiceAccount(executionSpec, modelJob.ServiceAccount) + } // Disable istio sidecar injection if not specified executionSpec.SetAnnotationsToAllTemplatesIfKeyNotExist(util.AnnotationKeyIstioSidecarInject, util.AnnotationValueIstioSidecarInjectDisabled) swfGeneratedName, err := toSWFCRDResourceGeneratedName(modelJob.K8SName) @@ -132,7 +134,7 @@ func (t *V2Spec) ScheduledWorkflow(modelJob *model.Job) (*scheduledworkflow.Sche PipelineId: modelJob.PipelineId, PipelineName: modelJob.PipelineName, PipelineVersionId: modelJob.PipelineVersionId, - ServiceAccount: modelJob.ServiceAccount, + ServiceAccount: executionSpec.ServiceAccount(), }, } return scheduledWorkflow, nil