From 45a8b461a50b90c4df1ab720dff609f72d1a2487 Mon Sep 17 00:00:00 2001 From: Sebastiaan Huber Date: Fri, 28 Jun 2024 15:47:22 +0200 Subject: [PATCH] CLI: Fail early in `verdi presto` when profile name already exists (#6488) If an explicit profile name is specified with `-p/--profile-name` it should be validated as soon as possible and error if the profile already exists, before anything else is done. This prevents, for example, that a PostgreSQL user and database are created that are then not cleaned up. --- src/aiida/cmdline/commands/cmd_presto.py | 3 +++ tests/cmdline/commands/test_presto.py | 22 +++++++++++++++++++++- 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/src/aiida/cmdline/commands/cmd_presto.py b/src/aiida/cmdline/commands/cmd_presto.py index 64a17fdac2..6fa9518443 100644 --- a/src/aiida/cmdline/commands/cmd_presto.py +++ b/src/aiida/cmdline/commands/cmd_presto.py @@ -174,6 +174,9 @@ def verdi_presto( from aiida.manage.configuration import create_profile, load_profile from aiida.orm import Computer + if profile_name in ctx.obj.config.profile_names: + raise click.BadParameter(f'The profile `{profile_name}` already exists.', param_hint='--profile-name') + postgres_config_kwargs = { 'profile_name': profile_name, 'postgres_hostname': postgres_hostname, diff --git a/tests/cmdline/commands/test_presto.py b/tests/cmdline/commands/test_presto.py index 3ec1d1e5da..80c61eaa4b 100644 --- a/tests/cmdline/commands/test_presto.py +++ b/tests/cmdline/commands/test_presto.py @@ -1,5 +1,7 @@ """Tests for ``verdi presto``.""" +import textwrap + import pytest from aiida.cmdline.commands.cmd_presto import get_default_presto_profile_name, verdi_presto from aiida.manage.configuration import profile_context @@ -50,7 +52,7 @@ def detect_rabbitmq_config(**kwargs): @pytest.mark.requires_rmq @pytest.mark.usefixtures('empty_config') -def test_presto_with_rmq(pytestconfig, run_cli_command, monkeypatch): +def test_presto_with_rmq(pytestconfig, run_cli_command): """Test the ``verdi presto``.""" result = run_cli_command(verdi_presto, ['--non-interactive']) assert 'Created new profile `presto`.' in result.output @@ -91,3 +93,21 @@ def test_presto_overdose(run_cli_command, config_with_profile_factory): config_with_profile_factory(name='presto-10') result = run_cli_command(verdi_presto) assert 'Created new profile `presto-11`.' in result.output + + +@pytest.mark.requires_psql +@pytest.mark.usefixtures('empty_config') +def test_presto_profile_name_exists(run_cli_command, config_with_profile_factory): + """Test ``verdi presto`` fails early if the specified profile name already exists.""" + profile_name = 'custom-presto' + config_with_profile_factory(name=profile_name) + options = ['--non-interactive', '--use-postgres', '--profile-name', profile_name] + result = run_cli_command(verdi_presto, options, raises=True) + # Matching for the complete literal output as a way to test that nothing else of the command was run, such as + # configuring the broker or creating a database for PostgreSQL + assert result.output == textwrap.dedent("""\ + Usage: presto [OPTIONS] + Try 'presto --help' for help. + + Error: Invalid value for --profile-name: The profile `custom-presto` already exists. + """)