From 71af82d1c7d498490f94babe53c488f74fa0b1ed Mon Sep 17 00:00:00 2001 From: Chen Sun Date: Tue, 11 Apr 2023 23:56:45 +0000 Subject: [PATCH] fix cli --- sdk/python/kfp/cli/experiment.py | 4 +- sdk/python/kfp/cli/output.py | 90 +++++++++++------------------ sdk/python/kfp/cli/pipeline.py | 12 ++-- sdk/python/kfp/cli/recurring_run.py | 46 ++++++++------- sdk/python/kfp/cli/run.py | 6 +- 5 files changed, 70 insertions(+), 88 deletions(-) diff --git a/sdk/python/kfp/cli/experiment.py b/sdk/python/kfp/cli/experiment.py index 2212148ef66c..cf94fd904fc0 100644 --- a/sdk/python/kfp/cli/experiment.py +++ b/sdk/python/kfp/cli/experiment.py @@ -126,7 +126,7 @@ def archive(ctx: click.Context, experiment_id: str, experiment_name: str): if not experiment_id: experiment = client_obj.get_experiment(experiment_name=experiment_name) - experiment_id = experiment.id + experiment_id = experiment.experiment_id client_obj.archive_experiment(experiment_id=experiment_id) if experiment_id: @@ -162,7 +162,7 @@ def unarchive(ctx: click.Context, experiment_id: str, experiment_name: str): if not experiment_id: experiment = client_obj.get_experiment(experiment_name=experiment_name) - experiment_id = experiment.id + experiment_id = experiment.experiment_id client_obj.unarchive_experiment(experiment_id=experiment_id) if experiment_id: diff --git a/sdk/python/kfp/cli/output.py b/sdk/python/kfp/cli/output.py index 8202dc78020e..1b6e9881ddd2 100644 --- a/sdk/python/kfp/cli/output.py +++ b/sdk/python/kfp/cli/output.py @@ -45,17 +45,6 @@ class OutputFormat(enum.Enum): json = 'json' -RUN_STORAGE_STATE_MAP = { - kfp_server_api.ApiRunStorageState.AVAILABLE: 'Available', - kfp_server_api.ApiRunStorageState.ARCHIVED: 'Archived', -} -EXPERIMENT_STORAGE_STATE_MAP = { - kfp_server_api.ApiExperimentStorageState.AVAILABLE: 'Available', - kfp_server_api.ApiExperimentStorageState.ARCHIVED: 'Archived', - kfp_server_api.ApiExperimentStorageState.UNSPECIFIED: 'Unspecified', -} - - def snake_to_header(string: str) -> str: """Converts a snake case string to a table header by replacing underscores with spaces and making uppercase. @@ -74,18 +63,17 @@ class ExperimentData: id: str name: str created_at: str - state: str + storage_state: str -def transform_experiment(exp: kfp_server_api.ApiExperiment) -> Dict[str, Any]: +def transform_experiment( + exp: kfp_server_api.V2beta1Experiment) -> Dict[str, Any]: return dataclasses.asdict( ExperimentData( - id=exp.id, - name=exp.name, + id=exp.experiment_id, + name=exp.display_name, created_at=exp.created_at.isoformat(), - state=EXPERIMENT_STORAGE_STATE_MAP.get( - exp.storage_state, EXPERIMENT_STORAGE_STATE_MAP[ - kfp_server_api.ApiExperimentStorageState.AVAILABLE]))) + storage_state=exp.storage_state)) @dataclasses.dataclass @@ -93,20 +81,16 @@ class PipelineData: id: str name: str created_at: str - default_version: str -def transform_pipeline(pipeline: kfp_server_api.ApiPipeline) -> Dict[str, Any]: - default_version_id = pipeline.default_version.id if hasattr( - pipeline, - 'default_version') and pipeline.default_version is not None and hasattr( - pipeline.default_version, 'id') else None +def transform_pipeline( + pipeline: kfp_server_api.V2beta1Pipeline) -> Dict[str, Any]: return dataclasses.asdict( PipelineData( - id=pipeline.id, - name=pipeline.name, + id=pipeline.pipeline_id, + name=pipeline.display_name, created_at=pipeline.created_at.isoformat(), - default_version=default_version_id)) + )) @dataclasses.dataclass @@ -118,16 +102,14 @@ class PipelineVersionData: def transform_pipeline_version( - pipeline_version: kfp_server_api.ApiPipelineVersion) -> Dict[str, Any]: - parent_id = next( - rr for rr in pipeline_version.resource_references - if rr.relationship == kfp_server_api.ApiRelationship.OWNER).key.id + pipeline_version: kfp_server_api.V2beta1PipelineVersion +) -> Dict[str, Any]: return dataclasses.asdict( PipelineVersionData( - id=pipeline_version.id, - name=pipeline_version.name, + id=pipeline_version.pipeline_version_id, + name=pipeline_version.display_name, created_at=pipeline_version.created_at.isoformat(), - parent_id=parent_id, + parent_id=pipeline_version.pipeline_id, )) @@ -136,26 +118,22 @@ class RunData: id: str name: str created_at: str - status: str state: str + storage_state: str -def transform_run( - run: Union[kfp_server_api.ApiRun, kfp_server_api.ApiRunDetail] -) -> Dict[str, Any]: +def transform_run(run: kfp_server_api.V2beta1Run) -> Dict[str, Any]: return dataclasses.asdict((RunData( - id=run.id, - name=run.name, + id=run.run_id, + name=run.display_name, created_at=run.created_at.isoformat(), - status=run.status, - state=RUN_STORAGE_STATE_MAP.get( - run.storage_state, - RUN_STORAGE_STATE_MAP[kfp_server_api.ApiRunStorageState.AVAILABLE])) - )) + state=run.state, + storage_state=run.storage_state, + ))) @dataclasses.dataclass -class JobData: +class RecurringRunData: id: str name: str created_at: str @@ -163,16 +141,14 @@ class JobData: status: str -def transform_job(recurring_run: kfp_server_api.ApiJob) -> Dict[str, Any]: - experiment_id = next( - rr for rr in recurring_run.resource_references - if rr.key.type == kfp_server_api.ApiResourceType.EXPERIMENT).key.id +def transform_recurring_run( + recurring_run: kfp_server_api.V2beta1RecurringRun) -> Dict[str, Any]: return dataclasses.asdict( - JobData( - id=recurring_run.id, - name=recurring_run.name, + RecurringRunData( + id=recurring_run.recurring_run_id, + name=recurring_run.display_name, created_at=recurring_run.created_at.isoformat(), - experiment_id=experiment_id, + experiment_id=recurring_run.experiment_id, status=recurring_run.status)) @@ -183,7 +159,7 @@ class ModelType(enum.Enum): PIPELINE = 'PIPELINE' PIPELINE_VERSION = 'PIPELINE_VERSION' RUN = 'RUN' - JOB = 'JOB' + RECURRING_RUN = 'RECURRING_RUN' transformer_map = { @@ -191,7 +167,7 @@ class ModelType(enum.Enum): ModelType.PIPELINE: transform_pipeline, ModelType.PIPELINE_VERSION: transform_pipeline_version, ModelType.RUN: transform_run, - ModelType.JOB: transform_job, + ModelType.RECURRING_RUN: transform_recurring_run, } dataclass_map = { @@ -199,7 +175,7 @@ class ModelType(enum.Enum): ModelType.PIPELINE: PipelineData, ModelType.PIPELINE_VERSION: PipelineVersionData, ModelType.RUN: RunData, - ModelType.JOB: JobData, + ModelType.RECURRING_RUN: RecurringRunData, } diff --git a/sdk/python/kfp/cli/pipeline.py b/sdk/python/kfp/cli/pipeline.py index 205d179567d9..42e9ecc567a9 100644 --- a/sdk/python/kfp/cli/pipeline.py +++ b/sdk/python/kfp/cli/pipeline.py @@ -198,9 +198,10 @@ def list_versions(ctx: click.Context, pipeline_id: str, page_token: str, @pipeline.command() +@click.argument('pipeline-id') @click.argument('version-id') @click.pass_context -def delete_version(ctx: click.Context, version_id: str): +def delete_version(ctx: click.Context, pipeline_id: str, version_id: str): """Delete a version of a pipeline.""" confirmation = f'Are you sure you want to delete pipeline version {version_id}?' if not click.confirm(confirmation): @@ -209,7 +210,8 @@ def delete_version(ctx: click.Context, version_id: str): client_obj: client.Client = ctx.obj['client'] output_format = ctx.obj['output'] - client_obj.delete_pipeline_version(version_id) + client_obj.delete_pipeline_version( + pipeline_id=pipeline_id, pipeline_version_id=version_id) output.print_deleted_text('pipeline version', version_id, output_format) @@ -230,14 +232,16 @@ def get(ctx: click.Context, pipeline_id: str): @pipeline.command() +@click.argument('pipeline-id') @click.argument('version-id') @click.pass_context -def get_version(ctx: click.Context, version_id: str): +def get_version(ctx: click.Context, pipeline_id: str, version_id: str): """Get information about a version of a pipeline.""" client_obj: client.Client = ctx.obj['client'] output_format = ctx.obj['output'] - version = client_obj.get_pipeline_version(version_id=version_id) + version = client_obj.get_pipeline_version( + pipeline_id=pipeline_id, pipeline_version_id=version_id) output.print_output( version, output.ModelType.PIPELINE, diff --git a/sdk/python/kfp/cli/recurring_run.py b/sdk/python/kfp/cli/recurring_run.py index 9a6a1df4d595..11c937306377 100644 --- a/sdk/python/kfp/cli/recurring_run.py +++ b/sdk/python/kfp/cli/recurring_run.py @@ -159,7 +159,7 @@ def create(ctx: click.Context, version_id=version_id) output.print_output( recurring_run, - output.ModelType.JOB, + output.ModelType.RECURRING_RUN, output_format, ) @@ -202,73 +202,75 @@ def list(ctx: click.Context, experiment_id: str, page_token: str, max_size: int, sort_by=sort_by, filter=filter) output.print_output( - response.jobs or [], - output.ModelType.JOB, + response.recurring_runs or [], + output.ModelType.RECURRING_RUN, output_format, ) @recurring_run.command() -@click.argument('job-id') +@click.argument('recurring-run-id') @click.pass_context -def get(ctx: click.Context, job_id: str): +def get(ctx: click.Context, recurring_run_id: str): """Get information about a recurring run.""" client_obj: client.Client = ctx.obj['client'] output_format = ctx.obj['output'] - recurring_run = client_obj.get_recurring_run(job_id) + recurring_run = client_obj.get_recurring_run(recurring_run_id) output.print_output( recurring_run, - output.ModelType.JOB, + output.ModelType.RECURRING_RUN, output_format, ) @recurring_run.command() -@click.argument('job-id') +@click.argument('recurring-run-id') @click.pass_context -def delete(ctx: click.Context, job_id: str): +def delete(ctx: click.Context, recurring_run_id: str): """Delete a recurring run.""" client_obj: client.Client = ctx.obj['client'] output_format = ctx.obj['output'] - confirmation = f'Are you sure you want to delete job {job_id}?' + confirmation = f'Are you sure you want to delete job {recurring_run_id}?' if not click.confirm(confirmation): return - client_obj.delete_job(job_id) - output.print_deleted_text('job', job_id, output_format) + client_obj.delete_recurring_run(recurring_run_id) + output.print_deleted_text('recurring_run', recurring_run_id, output_format) @recurring_run.command() -@click.argument('job-id') +@click.argument('recurring-run-id') @click.pass_context -def enable(ctx: click.Context, job_id: str): +def enable(ctx: click.Context, recurring_run_id: str): """Enable a recurring run.""" client_obj: client.Client = ctx.obj['client'] output_format = ctx.obj['output'] - client_obj.enable_job(job_id=job_id) + client_obj.enable_recurring_run(recurring_run_id=recurring_run_id) # TODO: add wait option, since enable takes time to complete - recurring_run = client_obj.get_recurring_run(job_id=job_id) + recurring_run = client_obj.get_recurring_run( + recurring_run_id=recurring_run_id) output.print_output( recurring_run, - output.ModelType.JOB, + output.ModelType.RECURRING_RUN, output_format, ) @recurring_run.command() -@click.argument('job-id') +@click.argument('recurring-run-id') @click.pass_context -def disable(ctx: click.Context, job_id: str): +def disable(ctx: click.Context, recurring_run_id: str): """Disable a recurring run.""" client_obj: client.Client = ctx.obj['client'] output_format = ctx.obj['output'] - client_obj.disable_job(job_id=job_id) + client_obj.disable_recurring_run(recurring_run_id=recurring_run_id) # TODO: add wait option, since disable takes time to complete - recurring_run = client_obj.get_recurring_run(job_id=job_id) + recurring_run = client_obj.get_recurring_run( + recurring_run_id=recurring_run_id) output.print_output( recurring_run, - output.ModelType.JOB, + output.ModelType.RECURRING_RUN, output_format, ) diff --git a/sdk/python/kfp/cli/run.py b/sdk/python/kfp/cli/run.py index 06b94251bef5..14cce73952ed 100644 --- a/sdk/python/kfp/cli/run.py +++ b/sdk/python/kfp/cli/run.py @@ -133,21 +133,21 @@ def create(ctx: click.Context, experiment_name: str, run_name: str, experiment = client_obj.create_experiment(experiment_name) run = client_obj.run_pipeline( - experiment_id=experiment.id, + experiment_id=experiment.experiment_id, job_name=run_name, pipeline_package_path=package_file, params=arg_dict, pipeline_id=pipeline_id, version_id=version) if timeout > 0: - run_detail = client_obj.wait_for_run_completion(run.id, timeout) + run_detail = client_obj.wait_for_run_completion(run.run_id, timeout) output.print_output( run_detail.run, output.ModelType.RUN, output_format, ) else: - display_run(client_obj, namespace, run.id, watch, output_format) + display_run(client_obj, namespace, run.run_id, watch, output_format) @run.command()