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:
parent
e2786afa58
commit
70424149e9
1
changelog.d/20241031_144431_regis_no_delete_env.md
Normal file
1
changelog.d/20241031_144431_regis_no_delete_env.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
- [Improvement] Do not prompt for environment deletion by default on `tutor config save --interactive`. (by @regisb)
|
@ -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)))
|
||||||
|
@ -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)
|
||||||
|
@ -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)
|
||||||
if interactive:
|
|
||||||
interactive_config.ask_questions(config, context.root, clean_env_prompt=True)
|
# 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:
|
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:
|
||||||
|
interactive_config.ask_questions(config)
|
||||||
|
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:
|
||||||
|
@ -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)
|
||||||
|
@ -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}")
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user