v2.9 and after
The Workflow of Workflows pattern involves a parent workflow triggering one or more child workflows, managing them, and acting on their results.
You can use workflowTemplateRef
to trigger a workflow inline.
- Define your workflow as a
workflowtemplate
.
apiVersion: argoproj.io/v1alpha1
kind: WorkflowTemplate
metadata:
name: workflow-template-submittable
spec:
entrypoint: print-message
arguments:
parameters:
- name: message
value: hello world
templates:
- name: print-message
inputs:
parameters:
- name: message
container:
image: busybox
command: [echo]
args: ["{{inputs.parameters.message}}"]
- Create the
Workflowtemplate
in cluster usingargo template create <yaml>
- Define the workflow of workflows.
# This template demonstrates a workflow of workflows.
# Workflow triggers one or more workflows and manages them.
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
generateName: workflow-of-workflows-
spec:
entrypoint: main
templates:
- name: main
steps:
- - name: workflow1
template: resource-without-argument
arguments:
parameters:
- name: workflowtemplate
value: "workflow-template-submittable"
- - name: workflow2
template: resource-with-argument
arguments:
parameters:
- name: workflowtemplate
value: "workflow-template-submittable"
- name: message
value: "Welcome Argo"
- name: resource-without-argument
inputs:
parameters:
- name: workflowtemplate
resource:
action: create
manifest: |
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
generateName: workflow-of-workflows-1-
spec:
workflowTemplateRef:
name: {{inputs.parameters.workflowtemplate}}
successCondition: status.phase == Succeeded
failureCondition: status.phase in (Failed, Error)
- name: resource-with-argument
inputs:
parameters:
- name: workflowtemplate
- name: message
resource:
action: create
manifest: |
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
generateName: workflow-of-workflows-2-
spec:
arguments:
parameters:
- name: message
value: {{inputs.parameters.message}}
workflowTemplateRef:
name: {{inputs.parameters.workflowtemplate}}
successCondition: status.phase == Succeeded
failureCondition: status.phase in (Failed, Error)