Skip to content

Commit

Permalink
fix: resolve output artifact of steps from expression when it refers … (
Browse files Browse the repository at this point in the history
#12320)

Signed-off-by: shuangkun <[email protected]>
Co-authored-by: zjgemi <[email protected]>
  • Loading branch information
shuangkun and zjgemi authored Dec 18, 2023
1 parent d900f07 commit 5b4b8f6
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 1 deletion.
48 changes: 48 additions & 0 deletions workflow/controller/controller_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,35 @@ spec:
args: ["hello world"]
`

var fromExrpessingWf = `
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
name: from-expression
spec:
entrypoint: main
arguments:
artifacts:
- name: foo
raw:
data: |
Hello
templates:
- name: main
inputs:
artifacts:
- name: foo
steps:
- - name: hello
inline:
container:
image: docker/whalesay:latest
outputs:
artifacts:
- name: result
fromExpression: "1 == 1 ? inputs.artifacts.foo : inputs.artifacts.foo"
`

var helloDaemonWf = `
apiVersion: argoproj.io/v1alpha1
kind: Workflow
Expand Down Expand Up @@ -1103,3 +1132,22 @@ spec:
assert.NoError(t, err)
assert.Len(t, pods.Items, 0)
}

func TestWorkflowReferItselfFromExpression(t *testing.T) {
wf := wfv1.MustUnmarshalWorkflow(fromExrpessingWf)
cancel, controller := newController(wf)
defer cancel()

ctx := context.Background()
assert.True(t, controller.processNextItem(ctx))

woc := newWorkflowOperationCtx(wf, controller)
woc.operate(ctx)
assert.Equal(t, wfv1.WorkflowRunning, woc.wf.Status.Phase)
makePodsPhase(ctx, woc, apiv1.PodSucceeded)

woc.operate(ctx)
assert.True(t, controller.processNextPodCleanupItem(ctx))
assert.True(t, controller.processNextPodCleanupItem(ctx))
assert.Equal(t, wfv1.WorkflowSucceeded, woc.wf.Status.Phase)
}
8 changes: 7 additions & 1 deletion workflow/controller/scope.go
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,13 @@ func (s *wfScope) resolveArtifact(art *wfv1.Artifact) (*wfv1.Artifact, error) {
}
valArt, ok := val.(wfv1.Artifact)
if !ok {
return nil, errors.Errorf(errors.CodeBadRequest, "Variable {{%v}} is not an artifact", art)
//If the workflow refers itself input artifacts in fromExpression, the val type is "*wfv1.Artifact"
ptArt, ok := val.(*wfv1.Artifact)
if ok {
valArt = *ptArt
} else {
return nil, errors.Errorf(errors.CodeBadRequest, "Variable {{%v}} is not an artifact", art)
}
}

if art.SubPath != "" {
Expand Down

0 comments on commit 5b4b8f6

Please sign in to comment.