Skip to content

Commit

Permalink
Refine check if the result is from a matrix task
Browse files Browse the repository at this point in the history
Given a matrix run of a TaskRun with cardinality of 1, the result from
it will not be converted to an array but kept as a string, i.e. as if
the TaskRun was not configured to run with matrix.

This causes issues for consumers of the TaskRun's results as they will
be configured to consume array results. As a result making the passed
value equal to expression value instead.

Resolves: tektoncd#8157
  • Loading branch information
zregvart committed Jul 29, 2024
1 parent 95fbf31 commit 2813050
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ func convertToResultRefs(pipelineRunState PipelineRunState, target *ResolvedPipe
resolvedResultRefs = append(resolvedResultRefs, resolved)
default:
// Matrixed referenced Pipeline Task
if len(referencedPipelineTask.TaskRuns) > 1 {
if referencedPipelineTask.PipelineTask.IsMatrixed() {
arrayValues, err := findResultValuesForMatrix(referencedPipelineTask, resultRef)
if err != nil {
return nil, resultRef.PipelineTask, err
Expand Down
53 changes: 53 additions & 0 deletions pkg/reconciler/pipelinerun/resources/resultrefresolution_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -363,6 +363,42 @@ var pipelineRunState = PipelineRunState{{
Value: *v1.NewStructuredValues("$(tasks.lTask.results.aResult)"),
}},
},
}, {
TaskRunNames: []string{"nTaskRun"},
TaskRuns: []*v1.TaskRun{{
ObjectMeta: metav1.ObjectMeta{
Name: "nTaskRun",
},
Status: v1.TaskRunStatus{
Status: duckv1.Status{
Conditions: duckv1.Conditions{successCondition},
},
TaskRunStatusFields: v1.TaskRunStatusFields{
Results: []v1.TaskRunResult{{
Name: "nResult",
Value: *v1.NewStructuredValues("one"),
}},
},
},
}},
PipelineTask: &v1.PipelineTask{
Name: "nTask",
TaskRef: &v1.TaskRef{Name: "nTask"},
Matrix: &v1.Matrix{
Include: v1.IncludeParamsList{v1.IncludeParams{}},
},
},
}, {
TaskRunNames: []string{"oTaskRun"},
TaskRuns: []*v1.TaskRun{},
PipelineTask: &v1.PipelineTask{
Name: "oTask",
TaskRef: &v1.TaskRef{Name: "oTask"},
Params: []v1.Param{{
Name: "oParam",
Value: *v1.NewStructuredValues("$(tasks.nTask.results.nResult)"),
}},
},
}}

func TestResolveResultRefs(t *testing.T) {
Expand Down Expand Up @@ -551,6 +587,23 @@ func TestResolveResultRefs(t *testing.T) {
},
wantPt: "kTask",
wantErr: true,
}, {
name: "Test result lookup single element matrix",
pipelineRunState: pipelineRunState,
targets: PipelineRunState{
pipelineRunState[21],
},
want: ResolvedResultRefs{{
Value: v1.ParamValue{
Type: v1.ParamTypeArray,
ArrayVal: []string{"one"},
},
ResultReference: v1.ResultRef{
PipelineTask: "nTask",
Result: "nResult",
},
FromTaskRun: "nTaskRun",
}},
}} {
t.Run(tt.name, func(t *testing.T) {
got, pt, err := ResolveResultRefs(tt.pipelineRunState, tt.targets)
Expand Down

0 comments on commit 2813050

Please sign in to comment.