From 8e967b83a32a6ea0ffe72d43b8a36c0f05833c5e Mon Sep 17 00:00:00 2001 From: Sultan Iman Date: Thu, 21 Mar 2024 18:06:11 +0100 Subject: [PATCH] Extract reusable pieces --- dlt/common/cli/runner/inquirer.py | 37 ++++++++++++++++++++----------- 1 file changed, 24 insertions(+), 13 deletions(-) diff --git a/dlt/common/cli/runner/inquirer.py b/dlt/common/cli/runner/inquirer.py index 30a5506f33..915865fad5 100644 --- a/dlt/common/cli/runner/inquirer.py +++ b/dlt/common/cli/runner/inquirer.py @@ -49,22 +49,12 @@ def maybe_ask(self) -> t.Tuple[dlt.Pipeline, t.Union[DltResource, DltSource]]: """ # save first pipeline and source pipeline_name, _ = next(iter(self.pipelines.items())) - source_name, _ = next(iter(self.pipelines.items())) + source_name, _ = next(iter(self.sources.items())) if len(self.pipelines) > 1: - message, options, values = make_select_options("pipeline", self.pipelines) - choice = fmt.prompt(message, options, default="n") - if choice == "n": - raise FriendlyExit() - else: - pipeline_name = values[int(choice)] + pipeline_name = self.ask_for_pipeline() if len(self.sources) > 1: - message, options, values = make_select_options("resource or source", self.sources) - choice = fmt.prompt(message, options, default="n") - if choice == "n": - raise FriendlyExit() - else: - source_name = values[int(choice)] + source_name = self.ask_for_source() pipeline = self.pipelines[pipeline_name] resource = self.sources[source_name] @@ -77,6 +67,27 @@ def maybe_ask(self) -> t.Tuple[dlt.Pipeline, t.Union[DltResource, DltSource]]: fmt.echo(f"{label}: " + fmt.style(source_name, fg="blue", underline=True)) return pipeline, self.sources[source_name] + def ask_for_pipeline(self) -> str: + if len(self.pipelines) > 1: + message, options, values = make_select_options("pipeline", self.pipelines) + + choice = fmt.prompt(message, options, default="n") + if choice == "n": + raise FriendlyExit() + + pipeline_name = values[int(choice)] + return pipeline_name + + def ask_for_source(self) -> str: + message, options, values = make_select_options("resource or source", self.sources) + + choice = fmt.prompt(message, options, default="n") + if choice == "n": + raise FriendlyExit() + + source_name = values[int(choice)] + return source_name + def preflight_checks(self) -> None: if self.params.current_dir != self.params.pipeline_workdir: fmt.warning(