Skip to content

Commit

Permalink
SDK - Preserving the pipeline metadata in the compiled Workflow
Browse files Browse the repository at this point in the history
  • Loading branch information
Ark-kun committed Aug 9, 2019
1 parent 90b9ad7 commit 24cdb75
Show file tree
Hide file tree
Showing 21 changed files with 81 additions and 0 deletions.
4 changes: 4 additions & 0 deletions sdk/python/kfp/compiler/compiler.py
Original file line number Diff line number Diff line change
Expand Up @@ -655,6 +655,10 @@ def _compile(self, pipeline_func):
op_transformers = [add_pod_env]
op_transformers.extend(p.conf.op_transformers)
workflow = self._create_pipeline_workflow(args_list_with_defaults, p, op_transformers)

import json
workflow.setdefault('metadata', {}).setdefault('annotations', {})['kubeflow.org/pipelines/pipeline_spec'] = json.dumps(pipeline_meta.to_dict())

return workflow

def compile(self, pipeline_func, package_path, type_check=True):
Expand Down
5 changes: 5 additions & 0 deletions sdk/python/tests/compiler/testdata/artifact_location.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,11 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "foo", "description": "hello world",
"inputs": [{"name": "tag", "description": "", "type": "", "default": null},
{"name": "namespace", "description": "", "type": "", "default": "kubeflow"},
{"name": "bucket", "description": "", "type": "", "default": "foobar"}]}'
generateName: foo-
spec:
arguments:
Expand Down
5 changes: 5 additions & 0 deletions sdk/python/tests/compiler/testdata/basic.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,11 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "Save Most Frequent", "description":
"Get Most Frequent Word and Save to GCS", "inputs": [{"name": "message", "description":
"", "type": "", "default": null}, {"name": "outputpath", "description": "",
"type": "", "default": null}]}'
generateName: save-most-frequent-
spec:
arguments:
Expand Down
3 changes: 3 additions & 0 deletions sdk/python/tests/compiler/testdata/coin.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "pipeline flip coin", "description":
"shows how to use dsl.Condition.", "inputs": []}'
generateName: pipeline-flip-coin-
spec:
arguments:
Expand Down
5 changes: 5 additions & 0 deletions sdk/python/tests/compiler/testdata/compose.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,11 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "Download and Save Most Frequent",
"description": "Download and Get Most Frequent Word and Save to GCS", "inputs":
[{"name": "url", "description": "", "type": "", "default": null}, {"name": "outputpath",
"description": "", "type": "", "default": null}]}'
generateName: download-and-save-most-frequent-
spec:
arguments:
Expand Down
4 changes: 4 additions & 0 deletions sdk/python/tests/compiler/testdata/default_value.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,10 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "Default Value", "description":
"A pipeline with parameter and default value.", "inputs": [{"name": "url", "description":
"", "type": "", "default": "gs://ml-pipeline/shakespeare1.txt"}]}'
generateName: default-value-
spec:
arguments:
Expand Down
4 changes: 4 additions & 0 deletions sdk/python/tests/compiler/testdata/imagepullsecrets.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "Save Most Frequent", "description":
"Get Most Frequent Word and Save to GCS", "inputs": [{"name": "message", "description":
"", "type": "", "default": null}]}'
generateName: save-most-frequent-
spec:
arguments:
Expand Down
4 changes: 4 additions & 0 deletions sdk/python/tests/compiler/testdata/param_substitutions.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "Param Substitutions", "description":
"Test the same PipelineParam getting substituted in multiple places", "inputs":
[]}'
generateName: param-substitutions-
spec:
arguments:
Expand Down
5 changes: 5 additions & 0 deletions sdk/python/tests/compiler/testdata/pipelineparams.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,11 @@
---
apiVersion: argoproj.io/v1alpha1
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "PipelineParams", "description":
"A pipeline with multiple pipeline params.", "inputs": [{"name": "tag", "description":
"", "type": "", "default": "latest"}, {"name": "sleep_ms", "description": "",
"type": "", "default": 10}]}'
generateName: pipelineparams-
spec:
entrypoint: pipelineparams
Expand Down
3 changes: 3 additions & 0 deletions sdk/python/tests/compiler/testdata/recursive_do_while.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "pipeline flip coin", "description":
"shows how to use graph_component.", "inputs": []}'
generateName: pipeline-flip-coin-
spec:
arguments:
Expand Down
3 changes: 3 additions & 0 deletions sdk/python/tests/compiler/testdata/recursive_while.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "pipeline flip coin", "description":
"shows how to use dsl.Condition.", "inputs": []}'
generateName: pipeline-flip-coin-
spec:
arguments:
Expand Down
5 changes: 5 additions & 0 deletions sdk/python/tests/compiler/testdata/resourceop_basic.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "ResourceOp Basic", "description":
"A Basic Example on ResourceOp Usage.", "inputs": [{"name": "username", "description":
"", "type": "", "default": null}, {"name": "password", "description": "", "type":
"", "default": null}]}'
generateName: resourceop-basic-
spec:
arguments:
Expand Down
4 changes: 4 additions & 0 deletions sdk/python/tests/compiler/testdata/retry.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "pipeline includes two steps which
fail randomly.", "description": "shows how to use ContainerOp set_retry().",
"inputs": []}'
generateName: pipeline-includes-two-steps-which-fail-randomly-
spec:
arguments:
Expand Down
3 changes: 3 additions & 0 deletions sdk/python/tests/compiler/testdata/sidecar.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,9 @@
# limitations under the License.
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "Sidecar", "description": "A pipeline
with sidecars.", "inputs": []}'
generateName: sidecar-
apiVersion: argoproj.io/v1alpha1
spec:
Expand Down
3 changes: 3 additions & 0 deletions sdk/python/tests/compiler/testdata/volume.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "Volume", "description": "A pipeline
with volume.", "inputs": []}'
generateName: volume-
spec:
arguments:
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "VolumeSnapshotOp RokURL", "description":
"The fifth example of the design doc.", "inputs": [{"name": "rok_url", "description":
"", "type": "", "default": null}]}'
generateName: volumesnapshotop-rokurl-
spec:
arguments:
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "VolumeSnapshotOp Sequential",
"description": "The fourth example of the design doc.", "inputs": [{"name":
"url", "description": "", "type": "", "default": null}]}'
generateName: volumesnapshotop-sequential-
spec:
arguments:
Expand Down
4 changes: 4 additions & 0 deletions sdk/python/tests/compiler/testdata/volumeop_basic.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "VolumeOp Basic", "description":
"A Basic Example on VolumeOp Usage.", "inputs": [{"name": "size", "description":
"", "type": "", "default": null}]}'
generateName: volumeop-basic-
spec:
arguments:
Expand Down
3 changes: 3 additions & 0 deletions sdk/python/tests/compiler/testdata/volumeop_dag.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "Volume Op DAG", "description":
"The second example of the design doc.", "inputs": []}'
generateName: volume-op-dag-
spec:
arguments:
Expand Down
3 changes: 3 additions & 0 deletions sdk/python/tests/compiler/testdata/volumeop_parallel.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "VolumeOp Parallel", "description":
"The first example of the design doc.", "inputs": []}'
generateName: volumeop-parallel-
spec:
arguments:
Expand Down
3 changes: 3 additions & 0 deletions sdk/python/tests/compiler/testdata/volumeop_sequential.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
apiVersion: argoproj.io/v1alpha1
kind: Workflow
metadata:
annotations:
kubeflow.org/pipelines/pipeline_spec: '{"name": "VolumeOp Sequential", "description":
"The third example of the design doc.", "inputs": []}'
generateName: volumeop-sequential-
spec:
arguments:
Expand Down

0 comments on commit 24cdb75

Please sign in to comment.