From 00599d0d6683eb559cffb7741612ed69fa8009c7 Mon Sep 17 00:00:00 2001 From: Eric Zhang Date: Fri, 24 May 2024 11:33:54 -0400 Subject: [PATCH] chore: add tests for pipeline validation against task artifact references --- .../alpha/consume-artifacts-from-task.yaml | 11 ++- pkg/apis/pipeline/v1/pipeline_validation.go | 8 +- .../pipeline/v1/pipeline_validation_test.go | 78 +++++++++++++++++++ .../pipeline/v1beta1/pipeline_validation.go | 8 +- .../v1beta1/pipeline_validation_test.go | 78 +++++++++++++++++++ 5 files changed, 171 insertions(+), 12 deletions(-) diff --git a/examples/v1/pipelineruns/alpha/consume-artifacts-from-task.yaml b/examples/v1/pipelineruns/alpha/consume-artifacts-from-task.yaml index 8cf0aaadb18..023130ee9e8 100644 --- a/examples/v1/pipelineruns/alpha/consume-artifacts-from-task.yaml +++ b/examples/v1/pipelineruns/alpha/consume-artifacts-from-task.yaml @@ -50,8 +50,11 @@ spec: - produce-artifacts-task taskSpec: steps: - - name: write - image: bash:latest + - name: artifacts-consumer-python + image: python:latest script: | - #!/usr/bin/env bash - echo $(tasks.produce-artifacts-task.outputs) \ No newline at end of file + #!/usr/bin/env python3 + import json + data = json.loads('$(tasks.produce-artifacts-task.outputs)') + if data[0]['uri'] != "pkg:github/package-url/purl-spec@244fd47e07d1004f0aed9c": + exit(1) \ No newline at end of file diff --git a/pkg/apis/pipeline/v1/pipeline_validation.go b/pkg/apis/pipeline/v1/pipeline_validation.go index a3de0e31f6c..d42e30ad366 100644 --- a/pkg/apis/pipeline/v1/pipeline_validation.go +++ b/pkg/apis/pipeline/v1/pipeline_validation.go @@ -889,17 +889,17 @@ func validateArtifactReference(ctx context.Context, tasks []PipelineTask, finalT if config.FromContextOrDefaults(ctx).FeatureFlags.EnableArtifacts { return errs } - for _, t := range tasks { + for i, t := range tasks { for _, v := range t.Params.extractValues() { if len(artifactref.TaskArtifactRegex.FindAllStringSubmatch(v, -1)) > 0 { - return errs.Also(apis.ErrGeneric(fmt.Sprintf("feature flag %s should be set to true to use artifacts feature.", config.EnableArtifacts), "")) + return errs.Also(apis.ErrGeneric(fmt.Sprintf("feature flag %s should be set to true to use artifacts feature.", config.EnableArtifacts), "").ViaField("params").ViaFieldIndex("tasks", i)) } } } - for _, t := range finalTasks { + for i, t := range finalTasks { for _, v := range t.Params.extractValues() { if len(artifactref.TaskArtifactRegex.FindAllStringSubmatch(v, -1)) > 0 { - return errs.Also(apis.ErrGeneric(fmt.Sprintf("feature flag %s should be set to true to use artifacts feature.", config.EnableArtifacts), "")) + return errs.Also(apis.ErrGeneric(fmt.Sprintf("feature flag %s should be set to true to use artifacts feature.", config.EnableArtifacts), "").ViaField("params").ViaFieldIndex("finally", i)) } } } diff --git a/pkg/apis/pipeline/v1/pipeline_validation_test.go b/pkg/apis/pipeline/v1/pipeline_validation_test.go index 446c8177066..1ece5b65496 100644 --- a/pkg/apis/pipeline/v1/pipeline_validation_test.go +++ b/pkg/apis/pipeline/v1/pipeline_validation_test.go @@ -114,6 +114,31 @@ func TestPipeline_Validate_Success(t *testing.T) { }, }, }, + }, { + name: "valid pipeline with pipeline task and final task referencing artifacts in task params with enable-artifacts flag true", + p: &Pipeline{ + ObjectMeta: metav1.ObjectMeta{Name: "pipeline"}, + Spec: PipelineSpec{ + Description: "this is an invalid pipeline referencing artifacts with enable-artifacts flag false", + Tasks: []PipelineTask{{ + Name: "pre-task", + TaskRef: &TaskRef{Name: "foo-task"}, + }, { + Name: "consume-artifacts-task", + Params: Params{{Name: "aaa", Value: ParamValue{ + Type: ParamTypeString, + StringVal: "$(tasks.produce-artifacts-task.outputs)", + }}}, + TaskSpec: &EmbeddedTask{TaskSpec: getTaskSpec()}, + }}, + }, + }, + wc: func(ctx context.Context) context.Context { + return cfgtesting.SetFeatureFlags(ctx, t, + map[string]string{ + "enable-artifacts": "true", + "enable-api-fields": "alpha"}) + }, }} for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { @@ -1023,6 +1048,59 @@ func TestPipelineSpec_Validate_Failure(t *testing.T) { Message: `missing field(s)`, Paths: []string{"tasks[1].when[0]", "finally[0].when[0]"}, }, + }, { + name: "invalid pipeline with one pipeline task referencing artifacts in task params with enable-artifacts flag false", + ps: &PipelineSpec{ + Description: "this is an invalid pipeline referencing artifacts with enable-artifacts flag false", + Tasks: []PipelineTask{{ + Name: "pre-task", + TaskRef: &TaskRef{Name: "foo-task"}, + }, { + Name: "consume-artifacts-task", + Params: Params{{Name: "aaa", Value: ParamValue{ + Type: ParamTypeString, + StringVal: "$(tasks.produce-artifacts-task.outputs)", + }}}, + TaskSpec: &EmbeddedTask{TaskSpec: getTaskSpec()}, + }}, + }, + expectedError: apis.FieldError{ + Message: `feature flag enable-artifacts should be set to true to use artifacts feature.`, + Paths: []string{"tasks[1].params"}, + }, + wc: func(ctx context.Context) context.Context { + return cfgtesting.SetFeatureFlags(ctx, t, + map[string]string{ + "enable-artifacts": "false", + "enable-api-fields": "alpha"}) + }, + }, { + name: "invalid pipeline with one final pipeline task referencing artifacts in params with enable-artifacts flag false", + ps: &PipelineSpec{ + Description: "this is an invalid pipeline referencing artifacts with enable-artifacts flag false", + Tasks: []PipelineTask{{ + Name: "pre-task", + TaskRef: &TaskRef{Name: "foo-task"}, + }}, + Finally: []PipelineTask{{ + Name: "consume-artifacts-task", + Params: Params{{Name: "aaa", Value: ParamValue{ + Type: ParamTypeString, + StringVal: "$(tasks.produce-artifacts-task.outputs)", + }}}, + TaskSpec: &EmbeddedTask{TaskSpec: getTaskSpec()}, + }}, + }, + wc: func(ctx context.Context) context.Context { + return cfgtesting.SetFeatureFlags(ctx, t, + map[string]string{ + "enable-artifacts": "false", + "enable-api-fields": "alpha"}) + }, + expectedError: apis.FieldError{ + Message: `feature flag enable-artifacts should be set to true to use artifacts feature.`, + Paths: []string{"finally[1].params"}, + }, }} for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { diff --git a/pkg/apis/pipeline/v1beta1/pipeline_validation.go b/pkg/apis/pipeline/v1beta1/pipeline_validation.go index ed6e11b5f33..96b8a5e0924 100644 --- a/pkg/apis/pipeline/v1beta1/pipeline_validation.go +++ b/pkg/apis/pipeline/v1beta1/pipeline_validation.go @@ -893,17 +893,17 @@ func validateArtifactReference(ctx context.Context, tasks []PipelineTask, finalT if config.FromContextOrDefaults(ctx).FeatureFlags.EnableArtifacts { return errs } - for _, t := range tasks { + for i, t := range tasks { for _, v := range t.Params.extractValues() { if len(artifactref.TaskArtifactRegex.FindAllStringSubmatch(v, -1)) > 0 { - return errs.Also(apis.ErrGeneric(fmt.Sprintf("feature flag %s should be set to true to use artifacts feature.", config.EnableArtifacts), "")) + return errs.Also(apis.ErrGeneric(fmt.Sprintf("feature flag %s should be set to true to use artifacts feature.", config.EnableArtifacts), "").ViaField("params").ViaFieldIndex("tasks", i)) } } } - for _, t := range finalTasks { + for i, t := range finalTasks { for _, v := range t.Params.extractValues() { if len(artifactref.TaskArtifactRegex.FindAllStringSubmatch(v, -1)) > 0 { - return errs.Also(apis.ErrGeneric(fmt.Sprintf("feature flag %s should be set to true to use artifacts feature.", config.EnableArtifacts), "")) + return errs.Also(apis.ErrGeneric(fmt.Sprintf("feature flag %s should be set to true to use artifacts feature.", config.EnableArtifacts), "").ViaField("params").ViaFieldIndex("finally", i)) } } } diff --git a/pkg/apis/pipeline/v1beta1/pipeline_validation_test.go b/pkg/apis/pipeline/v1beta1/pipeline_validation_test.go index adb5810009b..2dccc4864ee 100644 --- a/pkg/apis/pipeline/v1beta1/pipeline_validation_test.go +++ b/pkg/apis/pipeline/v1beta1/pipeline_validation_test.go @@ -116,6 +116,31 @@ func TestPipeline_Validate_Success(t *testing.T) { }, }, }, + }, { + name: "valid pipeline with pipeline task and final task referencing artifacts in task params with enable-artifacts flag true", + p: &Pipeline{ + ObjectMeta: metav1.ObjectMeta{Name: "pipeline"}, + Spec: PipelineSpec{ + Description: "this is an invalid pipeline referencing artifacts with enable-artifacts flag false", + Tasks: []PipelineTask{{ + Name: "pre-task", + TaskRef: &TaskRef{Name: "foo-task"}, + }, { + Name: "consume-artifacts-task", + Params: Params{{Name: "aaa", Value: ParamValue{ + Type: ParamTypeString, + StringVal: "$(tasks.produce-artifacts-task.outputs)", + }}}, + TaskSpec: &EmbeddedTask{TaskSpec: getTaskSpec()}, + }}, + }, + }, + wc: func(ctx context.Context) context.Context { + return cfgtesting.SetFeatureFlags(ctx, t, + map[string]string{ + "enable-artifacts": "true", + "enable-api-fields": "alpha"}) + }, }} for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { @@ -1066,6 +1091,59 @@ func TestPipelineSpec_Validate_Failure(t *testing.T) { Message: `must not set the field(s)`, Paths: []string{"finally[0].taskSpec.resources"}, }, + }, { + name: "invalid pipeline with one pipeline task referencing artifacts in task params with enable-artifacts flag false", + ps: &PipelineSpec{ + Description: "this is an invalid pipeline referencing artifacts with enable-artifacts flag false", + Tasks: []PipelineTask{{ + Name: "pre-task", + TaskRef: &TaskRef{Name: "foo-task"}, + }, { + Name: "consume-artifacts-task", + Params: Params{{Name: "aaa", Value: ParamValue{ + Type: ParamTypeString, + StringVal: "$(tasks.produce-artifacts-task.outputs)", + }}}, + TaskSpec: &EmbeddedTask{TaskSpec: getTaskSpec()}, + }}, + }, + expectedError: apis.FieldError{ + Message: `feature flag enable-artifacts should be set to true to use artifacts feature.`, + Paths: []string{"tasks[1].params"}, + }, + wc: func(ctx context.Context) context.Context { + return cfgtesting.SetFeatureFlags(ctx, t, + map[string]string{ + "enable-artifacts": "false", + "enable-api-fields": "alpha"}) + }, + }, { + name: "invalid pipeline with one final pipeline task referencing artifacts in params with enable-artifacts flag false", + ps: &PipelineSpec{ + Description: "this is an invalid pipeline referencing artifacts with enable-artifacts flag false", + Tasks: []PipelineTask{{ + Name: "pre-task", + TaskRef: &TaskRef{Name: "foo-task"}, + }}, + Finally: []PipelineTask{{ + Name: "consume-artifacts-task", + Params: Params{{Name: "aaa", Value: ParamValue{ + Type: ParamTypeString, + StringVal: "$(tasks.produce-artifacts-task.outputs)", + }}}, + TaskSpec: &EmbeddedTask{TaskSpec: getTaskSpec()}, + }}, + }, + wc: func(ctx context.Context) context.Context { + return cfgtesting.SetFeatureFlags(ctx, t, + map[string]string{ + "enable-artifacts": "false", + "enable-api-fields": "alpha"}) + }, + expectedError: apis.FieldError{ + Message: `feature flag enable-artifacts should be set to true to use artifacts feature.`, + Paths: []string{"finally[1].params"}, + }, }} for _, tt := range tests { t.Run(tt.name, func(t *testing.T) {