6
0
mirror of https://github.com/ChristianLight/tutor.git synced 2025-01-10 00:37:54 +00:00

feat: don't prompt for env deletion on tutor config save -i

The introduction of the `-c/--clean` option caused the deletion prompt
to be displayed for every call to `tutor config save --interactive`.
This is not the desired behaviour, as decided here:
https://github.com/overhangio/tutor/pull/1086#discussion_r1681744804

With this change, the prompt is only displayed when running: `tutor
config save --interactive --clean`. The environment is still deleted on
`tutor config save --clean`, but without prompt.

We refactored the code with hooks, which simplifies the signature of the
interactive prompt function.
This commit is contained in:
Régis Behmo 2024-10-31 14:45:35 +01:00 committed by Régis Behmo
parent e2786afa58
commit 70424149e9
7 changed files with 24 additions and 25 deletions

View File

@ -0,0 +1 @@
- [Improvement] Do not prompt for environment deletion by default on `tutor config save --interactive`. (by @regisb)

View File

@ -48,7 +48,7 @@ class ConfigTests(unittest.TestCase):
with patch.object(click, "prompt", new=mock_prompt): with patch.object(click, "prompt", new=mock_prompt):
with patch.object(click, "confirm", new=mock_prompt): with patch.object(click, "confirm", new=mock_prompt):
config = tutor_config.load_minimal(rootdir) config = tutor_config.load_minimal(rootdir)
interactive.ask_questions(config, rootdir) interactive.ask_questions(config)
self.assertIn("MYSQL_ROOT_PASSWORD", config) self.assertIn("MYSQL_ROOT_PASSWORD", config)
self.assertEqual(8, len(get_typed(config, "MYSQL_ROOT_PASSWORD", str))) self.assertEqual(8, len(get_typed(config, "MYSQL_ROOT_PASSWORD", str)))

View File

@ -197,7 +197,6 @@ def interactive_configuration(
click.echo(fmt.title("Interactive platform configuration")) click.echo(fmt.title("Interactive platform configuration"))
interactive_config.ask_questions( interactive_config.ask_questions(
config, config,
context.obj.root,
run_for_prod=run_for_prod, run_for_prod=run_for_prod,
) )
tutor_config.save_config_file(context.obj.root, config) tutor_config.save_config_file(context.obj.root, config)

View File

@ -7,12 +7,12 @@ import click
import click.shell_completion import click.shell_completion
from tutor import config as tutor_config from tutor import config as tutor_config
from tutor import env, exceptions, fmt from tutor import env, exceptions, fmt, hooks
from tutor import interactive as interactive_config from tutor import interactive as interactive_config
from tutor import serialize from tutor import serialize
from tutor.commands.context import Context from tutor.commands.context import Context
from tutor.commands.params import ConfigLoaderParam from tutor.commands.params import ConfigLoaderParam
from tutor.types import ConfigValue from tutor.types import Config, ConfigValue
@click.group( @click.group(
@ -155,9 +155,23 @@ def save(
clean_env: bool, clean_env: bool,
) -> None: ) -> None:
config = tutor_config.load_minimal(context.root) config = tutor_config.load_minimal(context.root)
# Add question to interactive prompt, such that the environment is automatically
# deleted if necessary in interactive mode.
@hooks.Actions.CONFIG_INTERACTIVE.add()
def _prompt_for_env_deletion(_config: Config) -> None:
if clean_env:
run_clean = click.confirm(
fmt.question("Remove existing Tutor environment directory?"),
prompt_suffix=" ",
default=True,
)
if run_clean:
env.delete_env_dir(context.root)
if interactive: if interactive:
interactive_config.ask_questions(config, context.root, clean_env_prompt=True) interactive_config.ask_questions(config)
if clean_env: elif clean_env:
env.delete_env_dir(context.root) env.delete_env_dir(context.root)
if set_vars: if set_vars:
for key, value in set_vars: for key, value in set_vars:

View File

@ -228,7 +228,7 @@ def launch(context: click.Context, non_interactive: bool) -> None:
config = tutor_config.load_minimal(context.obj.root) config = tutor_config.load_minimal(context.obj.root)
if not non_interactive: if not non_interactive:
click.echo(fmt.title("Interactive platform configuration")) click.echo(fmt.title("Interactive platform configuration"))
interactive_config.ask_questions(config, context.obj.root, run_for_prod=True) interactive_config.ask_questions(config, run_for_prod=True)
tutor_config.save_config_file(context.obj.root, config) tutor_config.save_config_file(context.obj.root, config)
config = tutor_config.load_full(context.obj.root) config = tutor_config.load_full(context.obj.root)
tutor_env.save(context.obj.root, config) tutor_env.save(context.obj.root, config)

View File

@ -539,10 +539,10 @@ def delete_env_dir(root: str) -> None:
try: try:
shutil.rmtree(env_path) shutil.rmtree(env_path)
fmt.echo_alert(f"Removed existing Tutor environment at: {env_path}") fmt.echo_alert(f"Removed existing Tutor environment at: {env_path}")
except PermissionError: except PermissionError as e:
raise exceptions.TutorError( raise exceptions.TutorError(
f"Permission Denied while trying to remove existing Tutor environment at: {env_path}" f"Permission Denied while trying to remove existing Tutor environment at: {env_path}"
) ) from e
except FileNotFoundError: except FileNotFoundError:
fmt.echo_info(f"No existing Tutor environment to remove at: {env_path}") fmt.echo_info(f"No existing Tutor environment to remove at: {env_path}")

View File

@ -7,12 +7,7 @@ from . import env, exceptions, fmt, hooks
from .types import Config, get_typed from .types import Config, get_typed
def ask_questions( def ask_questions(config: Config, run_for_prod: Optional[bool] = None) -> None:
config: Config,
root: str,
run_for_prod: Optional[bool] = None,
clean_env_prompt: bool = False,
) -> None:
""" """
Interactively ask questions to collect configuration values from the user. Interactively ask questions to collect configuration values from the user.
@ -20,8 +15,6 @@ def ask_questions(
config: Existing (or minimal) configuration. Modified in-place. config: Existing (or minimal) configuration. Modified in-place.
run_for_prod: Whether platform should be configured for production. run_for_prod: Whether platform should be configured for production.
If None, then ask the user. If None, then ask the user.
clean_env_prompt: Whether to show the clean environment prompt before running.
defaults to False.
Returns: Returns:
None None
""" """
@ -157,14 +150,6 @@ def ask_questions(
config, config,
defaults, defaults,
) )
if clean_env_prompt:
run_clean = click.confirm(
fmt.question("Remove existing Tutor environment directory?"),
prompt_suffix=" ",
default=True,
)
if run_clean:
env.delete_env_dir(root)
hooks.Actions.CONFIG_INTERACTIVE.do(config) hooks.Actions.CONFIG_INTERACTIVE.do(config)