Skip to content

Commit

Permalink
fix(ray): Use default svc account if not set in task metadata (flyteo…
Browse files Browse the repository at this point in the history
…rg#5499)

Signed-off-by: Kevin Su <[email protected]>
  • Loading branch information
pingsutw authored and robert-ulbrich-mercedes-benz committed Jul 2, 2024
1 parent 1f32053 commit 9b98b80
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 6 deletions.
3 changes: 3 additions & 0 deletions flyteplugins/go/tasks/plugins/k8s/ray/ray.go
Original file line number Diff line number Diff line change
Expand Up @@ -190,6 +190,9 @@ func constructRayJob(taskCtx pluginsCore.TaskExecutionContext, rayJob plugins.Ra
}

serviceAccountName := flytek8s.GetServiceAccountNameFromTaskExecutionMetadata(taskCtx.TaskExecutionMetadata())
if len(serviceAccountName) == 0 {
serviceAccountName = cfg.ServiceAccount
}

rayClusterSpec.HeadGroupSpec.Template.Spec.ServiceAccountName = serviceAccountName
for index := range rayClusterSpec.WorkerGroupSpecs {
Expand Down
22 changes: 16 additions & 6 deletions flyteplugins/go/tasks/plugins/k8s/ray/ray_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ func dummyRayTaskTemplate(id string, rayJob *plugins.RayJob) *core.TaskTemplate
}
}

func dummyRayTaskContext(taskTemplate *core.TaskTemplate, resources *corev1.ResourceRequirements, extendedResources *core.ExtendedResources, containerImage string) pluginsCore.TaskExecutionContext {
func dummyRayTaskContext(taskTemplate *core.TaskTemplate, resources *corev1.ResourceRequirements, extendedResources *core.ExtendedResources, containerImage, serviceAccount string) pluginsCore.TaskExecutionContext {
taskCtx := &mocks.TaskExecutionContext{}
inputReader := &pluginIOMocks.InputReader{}
inputReader.OnGetInputPrefixPath().Return("/input/prefix")
Expand Down Expand Up @@ -177,7 +177,8 @@ func TestBuildResourceRay(t *testing.T) {
err := config.SetK8sPluginConfig(&config.K8sPluginConfig{DefaultTolerations: toleration})
assert.Nil(t, err)

RayResource, err := rayJobResourceHandler.BuildResource(context.TODO(), dummyRayTaskContext(taskTemplate, resourceRequirements, nil, ""))
rayCtx := dummyRayTaskContext(taskTemplate, resourceRequirements, nil, "", serviceAccount)
RayResource, err := rayJobResourceHandler.BuildResource(context.TODO(), rayCtx)
assert.Nil(t, err)

assert.NotNil(t, RayResource)
Expand Down Expand Up @@ -208,6 +209,15 @@ func TestBuildResourceRay(t *testing.T) {
assert.Equal(t, ray.Spec.RayClusterSpec.WorkerGroupSpecs[0].Template.Annotations, map[string]string{"annotation-1": "val1"})
assert.Equal(t, ray.Spec.RayClusterSpec.WorkerGroupSpecs[0].Template.Labels, map[string]string{"label-1": "val1"})
assert.Equal(t, ray.Spec.RayClusterSpec.WorkerGroupSpecs[0].Template.Spec.Tolerations, toleration)

// Make sure the default service account is being used if SA is not provided in the task context
rayCtx = dummyRayTaskContext(taskTemplate, resourceRequirements, nil, "", "")
RayResource, err = rayJobResourceHandler.BuildResource(context.TODO(), rayCtx)
assert.Nil(t, err)
assert.NotNil(t, RayResource)
ray, ok = RayResource.(*rayv1.RayJob)
assert.True(t, ok)
assert.Equal(t, ray.Spec.RayClusterSpec.HeadGroupSpec.Template.Spec.ServiceAccountName, GetConfig().ServiceAccount)
}

func TestBuildResourceRayContainerImage(t *testing.T) {
Expand Down Expand Up @@ -241,7 +251,7 @@ func TestBuildResourceRayContainerImage(t *testing.T) {
for _, f := range fixtures {
t.Run(f.name, func(t *testing.T) {
taskTemplate := dummyRayTaskTemplate("id", dummyRayCustomObj())
taskContext := dummyRayTaskContext(taskTemplate, f.resources, nil, f.containerImageOverride)
taskContext := dummyRayTaskContext(taskTemplate, f.resources, nil, f.containerImageOverride, serviceAccount)
rayJobResourceHandler := rayJobResourceHandler{}
r, err := rayJobResourceHandler.BuildResource(context.TODO(), taskContext)
assert.Nil(t, err)
Expand Down Expand Up @@ -372,7 +382,7 @@ func TestBuildResourceRayExtendedResources(t *testing.T) {
t.Run(p.name, func(t *testing.T) {
taskTemplate := dummyRayTaskTemplate("ray-id", dummyRayCustomObj())
taskTemplate.ExtendedResources = p.extendedResourcesBase
taskContext := dummyRayTaskContext(taskTemplate, p.resources, p.extendedResourcesOverride, "")
taskContext := dummyRayTaskContext(taskTemplate, p.resources, p.extendedResourcesOverride, "", serviceAccount)
rayJobResourceHandler := rayJobResourceHandler{}
r, err := rayJobResourceHandler.BuildResource(context.TODO(), taskContext)
assert.Nil(t, err)
Expand Down Expand Up @@ -431,7 +441,7 @@ func TestDefaultStartParameters(t *testing.T) {
err := config.SetK8sPluginConfig(&config.K8sPluginConfig{DefaultTolerations: toleration})
assert.Nil(t, err)

RayResource, err := rayJobResourceHandler.BuildResource(context.TODO(), dummyRayTaskContext(taskTemplate, resourceRequirements, nil, ""))
RayResource, err := rayJobResourceHandler.BuildResource(context.TODO(), dummyRayTaskContext(taskTemplate, resourceRequirements, nil, "", serviceAccount))
assert.Nil(t, err)

assert.NotNil(t, RayResource)
Expand Down Expand Up @@ -637,7 +647,7 @@ func TestInjectLogsSidecar(t *testing.T) {
assert.NoError(t, SetConfig(&Config{
LogsSidecar: p.logsSidecarCfg,
}))
taskContext := dummyRayTaskContext(&p.taskTemplate, resourceRequirements, nil, "")
taskContext := dummyRayTaskContext(&p.taskTemplate, resourceRequirements, nil, "", serviceAccount)
rayJobResourceHandler := rayJobResourceHandler{}
r, err := rayJobResourceHandler.BuildResource(context.TODO(), taskContext)
assert.Nil(t, err)
Expand Down

0 comments on commit 9b98b80

Please sign in to comment.