Skip to content

Commit

Permalink
Add checking for duplicate declared resources
Browse files Browse the repository at this point in the history
Fixes tektoncd#2241

(cherry picked from commit 29966ea)
  • Loading branch information
GregDritschler authored and nikhil-thomas committed Apr 6, 2020
1 parent 7de159c commit a6ca9c5
Show file tree
Hide file tree
Showing 4 changed files with 45 additions and 0 deletions.
7 changes: 7 additions & 0 deletions pkg/apis/pipeline/v1alpha1/pipeline_validation.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,13 @@ func (p *Pipeline) Validate(ctx context.Context) *apis.FieldError {
}

func validateDeclaredResources(ps *PipelineSpec) error {
encountered := map[string]struct{}{}
for _, r := range ps.Resources {
if _, ok := encountered[r.Name]; ok {
return fmt.Errorf("resource with name %q appears more than once", r.Name)
}
encountered[r.Name] = struct{}{}
}
required := []string{}
for _, t := range ps.Tasks {
if t.Resources != nil {
Expand Down
9 changes: 9 additions & 0 deletions pkg/apis/pipeline/v1alpha1/pipeline_validation_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -213,6 +213,15 @@ func TestPipeline_Validate(t *testing.T) {
tb.PipelineTaskInputResource("the-resource", "great-resource", tb.From("bar"))),
)),
failureExpected: true,
}, {
name: "duplicate resource declaration",
p: tb.Pipeline("pipeline", "namespace", tb.PipelineSpec(
tb.PipelineDeclaredResource("duplicate-resource", v1alpha1.PipelineResourceTypeGit),
tb.PipelineDeclaredResource("duplicate-resource", v1alpha1.PipelineResourceTypeGit),
tb.PipelineTask("foo", "foo-task",
tb.PipelineTaskInputResource("the-resource", "duplicate-resource")),
)),
failureExpected: true,
}, {
name: "output resources missing from declaration",
p: tb.Pipeline("pipeline", "namespace", tb.PipelineSpec(
Expand Down
7 changes: 7 additions & 0 deletions pkg/apis/pipeline/v1beta1/pipeline_validation.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,13 @@ func (p *Pipeline) Validate(ctx context.Context) *apis.FieldError {
}

func validateDeclaredResources(ps *PipelineSpec) error {
encountered := map[string]struct{}{}
for _, r := range ps.Resources {
if _, ok := encountered[r.Name]; ok {
return fmt.Errorf("resource with name %q appears more than once", r.Name)
}
encountered[r.Name] = struct{}{}
}
required := []string{}
for _, t := range ps.Tasks {
if t.Resources != nil {
Expand Down
22 changes: 22 additions & 0 deletions pkg/apis/pipeline/v1beta1/pipeline_validation_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -350,6 +350,28 @@ func TestPipeline_Validate(t *testing.T) {
},
},
failureExpected: true,
}, {
name: "duplicate resource declaration",
p: &v1beta1.Pipeline{
ObjectMeta: metav1.ObjectMeta{Name: "pipeline"},
Spec: v1beta1.PipelineSpec{
Resources: []v1beta1.PipelineDeclaredResource{{
Name: "duplicate-resource", Type: v1beta1.PipelineResourceTypeGit,
}, {
Name: "duplicate-resource", Type: v1beta1.PipelineResourceTypeGit,
}},
Tasks: []v1beta1.PipelineTask{{
Name: "foo",
TaskRef: &v1beta1.TaskRef{Name: "foo-task"},
Resources: &v1beta1.PipelineTaskResources{
Inputs: []v1beta1.PipelineTaskInputResource{{
Name: "the-resource", Resource: "duplicate-resource",
}},
},
}},
},
},
failureExpected: true,
}, {
name: "output resources missing from declaration",
p: &v1beta1.Pipeline{
Expand Down

0 comments on commit a6ca9c5

Please sign in to comment.