forked from argoproj/argo-workflows
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdag-diamond-steps.yaml
69 lines (69 loc) · 1.55 KB
/
dag-diamond-steps.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# The following workflow executes a diamond workflow, with each
# node comprising of three parallel fan-in fan-out steps.
#
# *
# / | \
# A1 A2 A3
# \ | /
# *
# / \
# / \
# * *
# / | \ / | \
# B1 B2 B3 C1 C2 C3
# \ | / \ | /
# * *
# \ /
# \ /
# *
# / | \
# D1 D2 D3
# \ | /
# *
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
generateName: dag-diamond-steps-
spec:
entrypoint: diamond
templates:
- name: echo
inputs:
parameters:
- name: message
container:
image: alpine:3.7
command: [echo, "{{inputs.parameters.message}}"]
- name: echo-thrice
inputs:
parameters:
- name: message
steps:
- - name: echo
template: echo
arguments:
parameters:
- {name: message, value: "{{inputs.parameters.message}}{{item}}"}
withItems: [1,2,3]
- name: diamond
dag:
tasks:
- name: A
template: echo-thrice
arguments:
parameters: [{name: message, value: A}]
- name: B
depends: "A"
template: echo-thrice
arguments:
parameters: [{name: message, value: B}]
- name: C
depends: "A"
template: echo-thrice
arguments:
parameters: [{name: message, value: C}]
- name: D
depends: "B && C"
template: echo-thrice
arguments:
parameters: [{name: message, value: D}]