diff --git a/docs/labels.md b/docs/labels.md index f376915b17c..9d7e3e4a64c 100644 --- a/docs/labels.md +++ b/docs/labels.md @@ -80,6 +80,12 @@ Tekton automatically adds labels to Tekton entities as described in the followin No propagation. Name of the TaskRun that created the Pod. + + tekton.dev/memberOf + TaskRuns that are created automatically during the execution of a PipelineRun. + TaskRuns, Pods + tasks or finally depending on the PipelineTask's membership in the Pipeline. + app.kubernetes.io/instance, app.kubernetes.io/component Pods, StatefulSets (Affinity Assistant) diff --git a/pkg/apis/pipeline/register.go b/pkg/apis/pipeline/register.go index f34e682c67a..8a7c14ed345 100644 --- a/pkg/apis/pipeline/register.go +++ b/pkg/apis/pipeline/register.go @@ -48,6 +48,10 @@ const ( // RunKey is used as the label identifier for a Run RunKey = "/run" + + // MemberOfLabelKey is used as the label identifier for a PipelineTask + // Set to Tasks/Finally depending on the position of the PipelineTask + MemberOfLabelKey = "/memberOf" ) var ( diff --git a/pkg/reconciler/pipelinerun/pipelinerun.go b/pkg/reconciler/pipelinerun/pipelinerun.go index 94e4c6ad442..31a186b4a67 100644 --- a/pkg/reconciler/pipelinerun/pipelinerun.go +++ b/pkg/reconciler/pipelinerun/pipelinerun.go @@ -907,6 +907,25 @@ func getTaskrunLabels(pr *v1beta1.PipelineRun, pipelineTaskName string, includeP if pipelineTaskName != "" { labels[pipeline.GroupName+pipeline.PipelineTaskLabelKey] = pipelineTaskName } + if pr.Status.PipelineSpec != nil { + // check if a task is part of the "tasks" section, add a label to identify it during the runtime + for _, f := range pr.Status.PipelineSpec.Tasks { + if pipelineTaskName == f.Name { + labels[pipeline.GroupName+pipeline.MemberOfLabelKey] = "tasks" + break + } + } + // try adding a label "memberOf" if it was not added before + if _, ok := labels[pipeline.GroupName+pipeline.MemberOfLabelKey]; !ok { + // check if a task is part of the "finally" section, add a label to identify it during the runtime + for _, f := range pr.Status.PipelineSpec.Finally { + if pipelineTaskName == f.Name { + labels[pipeline.GroupName+pipeline.MemberOfLabelKey] = "finally" + break + } + } + } + } return labels } diff --git a/pkg/reconciler/pipelinerun/pipelinerun_test.go b/pkg/reconciler/pipelinerun/pipelinerun_test.go index 965c3d25148..39604a58526 100644 --- a/pkg/reconciler/pipelinerun/pipelinerun_test.go +++ b/pkg/reconciler/pipelinerun/pipelinerun_test.go @@ -403,6 +403,7 @@ func TestReconcile(t *testing.T) { tb.TaskRunLabel("tekton.dev/pipeline", "test-pipeline"), tb.TaskRunLabel("tekton.dev/pipelineRun", "test-pipeline-run-success"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineTaskLabelKey, "unit-test-1"), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunSpec( tb.TaskRunTaskRef("unit-test-task"), tb.TaskRunServiceAccountName("test-sa"), @@ -515,6 +516,7 @@ func TestReconcile_CustomTask(t *testing.T) { "tekton.dev/pipeline": pipelineRunName, "tekton.dev/pipelineRun": pipelineRunName, "tekton.dev/pipelineTask": pipelineTaskName, + "tekton.dev/memberOf": "tasks", }, Annotations: map[string]string{}, }, @@ -574,6 +576,7 @@ func TestReconcile_CustomTask(t *testing.T) { "tekton.dev/pipeline": pipelineRunName, "tekton.dev/pipelineRun": pipelineRunName, "tekton.dev/pipelineTask": pipelineTaskName, + "tekton.dev/memberOf": "tasks", }, Annotations: map[string]string{}, }, @@ -643,6 +646,7 @@ func TestReconcile_CustomTask(t *testing.T) { "tekton.dev/pipeline": pipelineRunName, "tekton.dev/pipelineRun": pipelineRunName, "tekton.dev/pipelineTask": pipelineTaskName, + "tekton.dev/memberOf": "tasks", }, Annotations: map[string]string{ "pipeline.tekton.dev/affinity-assistant": getAffinityAssistantName("pipelinews", pipelineRunName), @@ -774,6 +778,7 @@ func TestReconcile_PipelineSpecTaskSpec(t *testing.T) { tb.TaskRunLabel("tekton.dev/pipeline", "test-pipeline"), tb.TaskRunLabel("tekton.dev/pipelineRun", "test-pipeline-run-success"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineTaskLabelKey, "unit-test-task-spec"), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunSpec(tb.TaskRunTaskSpec(tb.Step("myimage", tb.StepName("mystep"))), tb.TaskRunServiceAccountName(config.DefaultServiceAccountValue)), ) @@ -2458,6 +2463,7 @@ func TestReconcilePropagateLabels(t *testing.T) { tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineTaskLabelKey, "hello-world-1"), tb.TaskRunLabel("tekton.dev/pipelineRun", "test-pipeline-run-with-labels"), tb.TaskRunLabel("PipelineRunLabel", "PipelineRunValue"), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunSpec( tb.TaskRunTaskRef("hello-world"), tb.TaskRunServiceAccountName("test-sa"), @@ -2528,6 +2534,7 @@ func TestReconcileWithDifferentServiceAccounts(t *testing.T) { tb.TaskRunLabel("tekton.dev/pipeline", "test-pipeline"), tb.TaskRunLabel("tekton.dev/pipelineRun", "test-pipeline-run-different-service-accs"), tb.TaskRunLabel("tekton.dev/pipelineTask", "hello-world-0"), + tb.TaskRunLabel("tekton.dev/memberOf", "tasks"), ), tb.TaskRun(taskRunNames[1], tb.TaskRunNamespace("foo"), @@ -2542,6 +2549,7 @@ func TestReconcileWithDifferentServiceAccounts(t *testing.T) { tb.TaskRunLabel("tekton.dev/pipeline", "test-pipeline"), tb.TaskRunLabel("tekton.dev/pipelineRun", "test-pipeline-run-different-service-accs"), tb.TaskRunLabel("tekton.dev/pipelineTask", "hello-world-1"), + tb.TaskRunLabel("tekton.dev/memberOf", "tasks"), ), } for i := range ps[0].Spec.Tasks { @@ -2739,6 +2747,7 @@ func TestReconcilePropagateAnnotations(t *testing.T) { tb.TaskRunLabel("tekton.dev/pipeline", "test-pipeline"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineTaskLabelKey, "hello-world-1"), tb.TaskRunLabel("tekton.dev/pipelineRun", "test-pipeline-run-with-annotations"), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunAnnotation("PipelineRunAnnotation", "PipelineRunValue"), tb.TaskRunSpec( tb.TaskRunTaskRef("hello-world"), @@ -3002,6 +3011,7 @@ func TestReconcileAndPropagateCustomPipelineTaskRunSpec(t *testing.T) { tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineLabelKey, "test-pipeline"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineTaskLabelKey, "hello-world-1"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineRunLabelKey, "test-pipeline-run"), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunAnnotation("PipelineRunAnnotation", "PipelineRunValue"), tb.TaskRunSpec( tb.TaskRunTaskRef("hello-world"), @@ -3212,6 +3222,7 @@ func TestReconcileWithFailingConditionChecks(t *testing.T) { tb.TaskRunOwnerReference("kind", "name"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineLabelKey, "test-pipeline-run-with-conditions"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineRunLabelKey, "test-pipeline"), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunSpec(tb.TaskRunTaskRef("hello-world")), tb.TaskRunStatus(tb.StatusCondition(apis.Condition{ Type: apis.ConditionSucceeded, @@ -3267,6 +3278,7 @@ func TestReconcileWithFailingConditionChecks(t *testing.T) { tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineLabelKey, "test-pipeline"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineTaskLabelKey, "task-3"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineRunLabelKey, "test-pipeline-run-with-conditions"), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunAnnotation("PipelineRunAnnotation", "PipelineRunValue"), tb.TaskRunSpec( tb.TaskRunTaskRef("hello-world"), @@ -3289,6 +3301,7 @@ func makeExpectedTr(condName, ccName string, labels, annotations map[string]stri tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineLabelKey, "test-pipeline"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineTaskLabelKey, "hello-world-1"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineRunLabelKey, "test-pipeline-run"), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunLabel(pipeline.GroupName+pipeline.ConditionCheckKey, ccName), tb.TaskRunLabel(pipeline.GroupName+pipeline.ConditionNameKey, condName), tb.TaskRunLabels(labels), @@ -3378,6 +3391,7 @@ func TestReconcileWithWhenExpressionsWithParameters(t *testing.T) { tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineLabelKey, "test-pipeline"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineTaskLabelKey, "hello-world-1"), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineRunLabelKey, "test-pipeline-run"), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunAnnotation("PipelineRunAnnotation", "PipelineRunValue"), tb.TaskRunSpec( tb.TaskRunTaskRef("hello-world-1"), @@ -3507,6 +3521,7 @@ func TestReconcileWithWhenExpressionsWithTaskResults(t *testing.T) { tb.TaskRunLabel("tekton.dev/pipeline", "test-pipeline"), tb.TaskRunLabel("tekton.dev/pipelineRun", "test-pipeline-run-different-service-accs"), tb.TaskRunLabel("tekton.dev/pipelineTask", "b-task"), + tb.TaskRunLabel("tekton.dev/memberOf", "tasks"), tb.TaskRunSpec( tb.TaskRunTaskRef("b-task"), tb.TaskRunServiceAccountName("test-sa-0"), @@ -3921,6 +3936,7 @@ func TestReconcileWithTaskResults(t *testing.T) { tb.TaskRunLabel("tekton.dev/pipeline", "test-pipeline"), tb.TaskRunLabel("tekton.dev/pipelineRun", "test-pipeline-run-different-service-accs"), tb.TaskRunLabel("tekton.dev/pipelineTask", "b-task"), + tb.TaskRunLabel("tekton.dev/memberOf", "tasks"), tb.TaskRunSpec( tb.TaskRunTaskRef("b-task"), tb.TaskRunServiceAccountName("test-sa-0"), @@ -3997,6 +4013,7 @@ func TestReconcileWithTaskResultsEmbeddedNoneStarted(t *testing.T) { tb.TaskRunLabel("tekton.dev/pipeline", "test-pipeline-run-different-service-accs"), tb.TaskRunLabel("tekton.dev/pipelineRun", "test-pipeline-run-different-service-accs"), tb.TaskRunLabel("tekton.dev/pipelineTask", "a-task"), + tb.TaskRunLabel("tekton.dev/memberOf", "tasks"), tb.TaskRunSpec( tb.TaskRunTaskRef("a-task", tb.TaskRefKind(v1beta1.NamespacedTaskKind)), tb.TaskRunServiceAccountName("test-sa-0"), @@ -5534,6 +5551,7 @@ func TestReconciler_ReconcileKind_PipelineTaskContext(t *testing.T) { tb.TaskRunLabel("tekton.dev/pipeline", pipelineName), tb.TaskRunLabel("tekton.dev/pipelineRun", pipelineRunName), tb.TaskRunLabel("tekton.dev/pipelineTask", "finaltask"), + tb.TaskRunLabel("tekton.dev/memberOf", "finally"), tb.TaskRunSpec( tb.TaskRunTaskRef("finaltask"), tb.TaskRunServiceAccountName("test-sa"), @@ -5767,6 +5785,7 @@ func TestReconcileWithTaskResultsInFinalTasks(t *testing.T) { "tekton.dev/pipeline": "test-pipeline", "tekton.dev/pipelineRun": "test-pipeline-run-final-task-results", "tekton.dev/pipelineTask": "final-task-1", + "tekton.dev/memberOf": "finally", }, Annotations: map[string]string{}, }, @@ -5953,6 +5972,7 @@ func TestReconcile_RemotePipelineRef(t *testing.T) { "tekton.dev/pipeline": "test-pipeline", "tekton.dev/pipelineRun": "test-pipeline-run-success", pipeline.GroupName + pipeline.PipelineTaskLabelKey: "unit-test-1", + "tekton.dev/memberOf": "tasks", }, OwnerReferences: []metav1.OwnerReference{{ APIVersion: "tekton.dev/v1beta1", @@ -6060,6 +6080,7 @@ func TestReconcile_OptionalWorkspacesOmitted(t *testing.T) { "tekton.dev/pipeline": "test-pipeline-run-success", "tekton.dev/pipelineRun": "test-pipeline-run-success", pipeline.GroupName + pipeline.PipelineTaskLabelKey: "unit-test-1", + "tekton.dev/memberOf": "tasks", }, OwnerReferences: []metav1.OwnerReference{{ APIVersion: "tekton.dev/v1beta1", @@ -6263,6 +6284,7 @@ func getTaskRunWithTaskSpec(tr, pr, p, t string, labels, annotations map[string] tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineLabelKey, p), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineRunLabelKey, pr), tb.TaskRunLabel(pipeline.GroupName+pipeline.PipelineTaskLabelKey, t), + tb.TaskRunLabel(pipeline.GroupName+pipeline.MemberOfLabelKey, "tasks"), tb.TaskRunLabels(labels), tb.TaskRunAnnotations(annotations), tb.TaskRunSpec(tb.TaskRunTaskSpec(tb.Step("myimage", tb.StepName("mystep"))),