diff --git a/docs/stepactions.md b/docs/stepactions.md index 561a582e2c8..88af514d4c5 100644 --- a/docs/stepactions.md +++ b/docs/stepactions.md @@ -331,3 +331,5 @@ spec: - name: pathInRepo value: remote_step.yaml ``` + +The default resolver type can be configured by the `default-resolver-type` field in the `config-defaults` ConfigMap (`alpha` feature). See [additional-configs.md](./additional-configs.md) for details. diff --git a/pkg/apis/pipeline/v1/task_defaults.go b/pkg/apis/pipeline/v1/task_defaults.go index 77a38425f23..5d130d43d16 100644 --- a/pkg/apis/pipeline/v1/task_defaults.go +++ b/pkg/apis/pipeline/v1/task_defaults.go @@ -19,6 +19,7 @@ package v1 import ( "context" + "github.com/tektoncd/pipeline/pkg/apis/config" "knative.dev/pkg/apis" ) @@ -31,6 +32,12 @@ func (t *Task) SetDefaults(ctx context.Context) { // SetDefaults set any defaults for the task spec func (ts *TaskSpec) SetDefaults(ctx context.Context) { + cfg := config.FromContextOrDefaults(ctx) + for _, s := range ts.Steps { + if s.Ref != nil && s.Ref.Name == "" && s.Ref.Resolver == "" { + s.Ref.Resolver = ResolverName(cfg.Defaults.DefaultResolverType) + } + } for i := range ts.Params { ts.Params[i].SetDefaults(ctx) } diff --git a/pkg/apis/pipeline/v1/task_defaults_test.go b/pkg/apis/pipeline/v1/task_defaults_test.go new file mode 100644 index 00000000000..fbd2a6d0bb9 --- /dev/null +++ b/pkg/apis/pipeline/v1/task_defaults_test.go @@ -0,0 +1,100 @@ +/* +Copyright 2023 The Tekton Authors + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +*/ +package v1_test + +import ( + "context" + "testing" + + "github.com/google/go-cmp/cmp" + cfgtesting "github.com/tektoncd/pipeline/pkg/apis/config/testing" + v1 "github.com/tektoncd/pipeline/pkg/apis/pipeline/v1" + "github.com/tektoncd/pipeline/test/diff" +) + +func TestTask_SetDefaults(t *testing.T) { + tests := []struct { + name string + in *v1.Task + want *v1.Task + }{{ + name: "remote Ref uses default resolver", + in: &v1.Task{ + Spec: v1.TaskSpec{ + Steps: []v1.Step{{ + Name: "foo", + Ref: &v1.Ref{}, + }}, + }, + }, + want: &v1.Task{ + Spec: v1.TaskSpec{ + Steps: []v1.Step{{ + Name: "foo", + Ref: &v1.Ref{ResolverRef: v1.ResolverRef{Resolver: "git"}}, + }}, + }, + }, + }, { + name: "remote Ref has resolver not overwritten by default resolver", + in: &v1.Task{ + Spec: v1.TaskSpec{ + Steps: []v1.Step{{ + Name: "foo", + Ref: &v1.Ref{ResolverRef: v1.ResolverRef{Resolver: "bundle"}}, + }}, + }, + }, + want: &v1.Task{ + Spec: v1.TaskSpec{ + Steps: []v1.Step{{ + Name: "foo", + Ref: &v1.Ref{ResolverRef: v1.ResolverRef{Resolver: "bundle"}}, + }}, + }, + }, + }, { + name: "local Ref not adding default resolver", + in: &v1.Task{ + Spec: v1.TaskSpec{ + Steps: []v1.Step{{ + Name: "foo", + Ref: &v1.Ref{Name: "local"}, + }}, + }, + }, + want: &v1.Task{ + Spec: v1.TaskSpec{ + Steps: []v1.Step{{ + Name: "foo", + Ref: &v1.Ref{Name: "local"}, + }}, + }, + }, + }} + for _, tc := range tests { + t.Run(tc.name, func(t *testing.T) { + ctx := cfgtesting.SetDefaults(context.Background(), t, map[string]string{ + "default-resolver-type": "git", + }) + got := tc.in + got.SetDefaults(ctx) + if d := cmp.Diff(tc.want, got); d != "" { + t.Errorf("SetDefaults %s", diff.PrintWantGot(d)) + } + }) + } +}