Skip to content

Commit

Permalink
fix: use execWf when setting PodMetadata (#6512)
Browse files Browse the repository at this point in the history
Signed-off-by: Ed Marks <edwardmarks@bulb.co.uk>
  • Loading branch information
ed-marks authored and sarabala1979 committed Sep 3, 2021
1 parent 0df0f3a commit 36d2389
Showing 1 changed file with 56 additions and 0 deletions.
56 changes: 56 additions & 0 deletions workflow/controller/workflowpod_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1584,3 +1584,59 @@ func TestPodMetadataWithWorkflowDefaults(t *testing.T) {
assert.Equal(t, "label-value", pod.ObjectMeta.Labels["controller-level-pod-label"])
cancel()
}

func TestPodMetadataWithWorkflowDefaults(t *testing.T) {
cancel, controller := newController()
defer cancel()

wfDefaultAnnotations := make(map[string]string)
wfDefaultAnnotations["controller-level-pod-annotation"] = "annotation-value"
wfDefaultAnnotations["workflow-level-pod-annotation"] = "set-by-controller"
wfDefaultLabels := make(map[string]string)
wfDefaultLabels["controller-level-pod-label"] = "label-value"
wfDefaultLabels["workflow-level-pod-label"] = "set-by-controller"
controller.Config.WorkflowDefaults = &wfv1.Workflow{
Spec: wfv1.WorkflowSpec{
PodMetadata: &wfv1.Metadata{
Annotations: wfDefaultAnnotations,
Labels: wfDefaultLabels,
},
},
}

wf := wfv1.MustUnmarshalWorkflow(helloWorldWf)
ctx := context.Background()
woc := newWorkflowOperationCtx(wf, controller)
err := woc.setExecWorkflow(ctx)
assert.NoError(t, err)
mainCtr := woc.execWf.Spec.Templates[0].Container
pod, _ := woc.createWorkflowPod(ctx, wf.Name, []apiv1.Container{*mainCtr}, &wf.Spec.Templates[0], &createWorkflowPodOpts{})
assert.Equal(t, "annotation-value", pod.ObjectMeta.Annotations["controller-level-pod-annotation"])
assert.Equal(t, "set-by-controller", pod.ObjectMeta.Annotations["workflow-level-pod-annotation"])
assert.Equal(t, "label-value", pod.ObjectMeta.Labels["controller-level-pod-label"])
assert.Equal(t, "set-by-controller", pod.ObjectMeta.Labels["workflow-level-pod-label"])
cancel() // need to cancel to spin up pods with the same name

cancel, controller = newController()
defer cancel()
controller.Config.WorkflowDefaults = &wfv1.Workflow{
Spec: wfv1.WorkflowSpec{
PodMetadata: &wfv1.Metadata{
Annotations: wfDefaultAnnotations,
Labels: wfDefaultLabels,
},
},
}
wf = wfv1.MustUnmarshalWorkflow(wfWithPodMetadata)
ctx = context.Background()
woc = newWorkflowOperationCtx(wf, controller)
err = woc.setExecWorkflow(ctx)
assert.NoError(t, err)
mainCtr = woc.execWf.Spec.Templates[0].Container
pod, _ = woc.createWorkflowPod(ctx, wf.Name, []apiv1.Container{*mainCtr}, &wf.Spec.Templates[0], &createWorkflowPodOpts{})
assert.Equal(t, "foo", pod.ObjectMeta.Annotations["workflow-level-pod-annotation"])
assert.Equal(t, "bar", pod.ObjectMeta.Labels["workflow-level-pod-label"])
assert.Equal(t, "annotation-value", pod.ObjectMeta.Annotations["controller-level-pod-annotation"])
assert.Equal(t, "label-value", pod.ObjectMeta.Labels["controller-level-pod-label"])
cancel()
}

0 comments on commit 36d2389

Please # to comment.