From 9b1afedcbb2a9cef35d5a0b59976622265c88edd Mon Sep 17 00:00:00 2001 From: rafal-bigaj Date: Tue, 6 Sep 2022 14:41:15 +0200 Subject: [PATCH] Improve DAG validation for pipelines with hundreds of tasks - v1beta1 tests Add pipeline validation tests for `v1beta1`. Related to: https://github.com/tektoncd/pipeline/issues/5420 --- .../pipeline/v1beta1/pipeline_validation_test.go | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/pkg/apis/pipeline/v1beta1/pipeline_validation_test.go b/pkg/apis/pipeline/v1beta1/pipeline_validation_test.go index 6d1bf94f96b..bde9229e7ff 100644 --- a/pkg/apis/pipeline/v1beta1/pipeline_validation_test.go +++ b/pkg/apis/pipeline/v1beta1/pipeline_validation_test.go @@ -701,9 +701,11 @@ func TestPipelineSpec_Validate_Failure_CycleDAG(t *testing.T) { name := "invalid pipeline spec with DAG having cyclic dependency" ps := &PipelineSpec{ Tasks: []PipelineTask{{ - Name: "foo", TaskRef: &TaskRef{Name: "foo-task"}, RunAfter: []string{"bar"}, + Name: "foo", TaskRef: &TaskRef{Name: "foo-task"}, RunAfter: []string{"baz"}, }, { Name: "bar", TaskRef: &TaskRef{Name: "bar-task"}, RunAfter: []string{"foo"}, + }, { + Name: "baz", TaskRef: &TaskRef{Name: "baz-task"}, RunAfter: []string{"bar"}, }}, } ctx := config.SkipValidationDueToPropagatedParametersAndWorkspaces(context.Background(), false) @@ -1089,9 +1091,15 @@ func TestValidateGraph_Failure(t *testing.T) { }, { Name: "bar", TaskRef: &TaskRef{Name: "bar-task"}, RunAfter: []string{"foo"}, }} - if err := validateGraph(tasks); err == nil { + expectedError := apis.FieldError{ + Message: `invalid value: cycle detected; task "bar" depends on "foo"`, + Paths: []string{"tasks"}, + } + err := validateGraph(tasks) + if err == nil { t.Error("Pipeline.validateGraph() did not return error for invalid DAG of pipeline tasks:", desc) - + } else if d := cmp.Diff(expectedError.Error(), err.Error(), cmpopts.IgnoreUnexported(apis.FieldError{})); d != "" { + t.Errorf("Pipeline.validateGraph() errors diff %s", diff.PrintWantGot(d)) } }