From e436ac2a197fb5251f3582dfbe6b01a231b054b6 Mon Sep 17 00:00:00 2001 From: Patrick Dawkins Date: Wed, 21 Sep 2022 10:43:05 +0100 Subject: [PATCH] Distinguish (again) between "deactivate" and "delete" in the env:delete command This is to match more closely the wording on Console --- .../Environment/EnvironmentDeleteCommand.php | 49 +++++++++---------- 1 file changed, 24 insertions(+), 25 deletions(-) diff --git a/src/Command/Environment/EnvironmentDeleteCommand.php b/src/Command/Environment/EnvironmentDeleteCommand.php index 0313f3e0a..1d55e70f6 100644 --- a/src/Command/Environment/EnvironmentDeleteCommand.php +++ b/src/Command/Environment/EnvironmentDeleteCommand.php @@ -17,31 +17,29 @@ protected function configure() { $this ->setName('environment:delete') - ->setHiddenAliases(['environment:deactivate']) - ->setDescription('Delete one or more environments') - ->addArgument('environment', InputArgument::IS_ARRAY, "The environment(s) to delete.\nThe % character may be used as a wildcard." . "\n" . ArrayArgument::SPLIT_HELP) + ->setAliases(['environment:deactivate']) + ->setDescription('Deactivate or delete one or more environments') + ->addArgument('environment', InputArgument::IS_ARRAY, "Select environment(s) by ID.\nThe % character may be used as a wildcard." . "\n" . ArrayArgument::SPLIT_HELP) ->addOption('delete-branch', null, InputOption::VALUE_NONE, 'Delete Git branch(es) (inactive environments)') ->addOption('no-delete-branch', null, InputOption::VALUE_NONE, 'Do not delete Git branch(es) (inactive environments)') - ->addOption('type', null, InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, 'Delete all environments of a type (adding to any others selected)' . "\n" . ArrayArgument::SPLIT_HELP) - ->addOption('only-type', 't', InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, 'Only delete environment(s) of a specific type' . "\n" . ArrayArgument::SPLIT_HELP) - ->addOption('exclude', null, InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, "Environment(s) not to delete.\nThe % character may be used as a wildcard.\n" . ArrayArgument::SPLIT_HELP) - ->addOption('exclude-type', null, InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, 'Environment type(s) of which not to delete' . "\n" . ArrayArgument::SPLIT_HELP) - ->addOption('inactive', null, InputOption::VALUE_NONE, 'Delete all inactive environments (adding to any others selected') - ->addOption('merged', null, InputOption::VALUE_NONE, 'Delete all merged environments (adding to any others selected)'); + ->addOption('type', null, InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, 'Select all environments of a type (adding to any others selected)' . "\n" . ArrayArgument::SPLIT_HELP) + ->addOption('only-type', 't', InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, 'Include only environment(s) of a specific type' . "\n" . ArrayArgument::SPLIT_HELP) + ->addOption('exclude', null, InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, "Environment(s) to exclude.\nThe % character may be used as a wildcard.\n" . ArrayArgument::SPLIT_HELP) + ->addOption('exclude-type', null, InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, 'Environment type(s) to exclude' . "\n" . ArrayArgument::SPLIT_HELP) + ->addOption('inactive', null, InputOption::VALUE_NONE, 'Select all inactive environments (adding to any others selected') + ->addOption('merged', null, InputOption::VALUE_NONE, 'Select all merged environments (adding to any others selected)'); $this->addProjectOption() ->addEnvironmentOption() ->addWaitOptions(); - $this->addExample('Delete the currently checked out environment'); - $this->addExample('Delete the environments "test" and "example-1"', 'test example-1'); + $this->addExample('Deactivate and delete the currently checked out environment'); + $this->addExample('Deactivate and delete the environments "test" and "example-1"', 'test example-1'); $this->addExample('Delete all inactive environments', '--inactive'); - $this->addExample('Delete all environments merged with their parent', '--merged'); - $service = $this->config()->get('service.name'); + $this->addExample('Deactivate and delete all environments merged with their parent', '--merged'); $this->setHelp(<<stdErr->writeln(''); } - // Confirm which of the environments the user wishes to be deleted. + // Confirm which of the environments the user wishes to be deactivated + // or deleted. $this->api()->sortResources($selectedEnvironments, 'id'); $toDeleteBranch = []; $toDeactivate = []; @@ -194,7 +193,7 @@ function ($environment) { foreach ($environments as $potentialChild) { if ($potentialChild->parent === $environment->id) { $this->stdErr->writeln(\sprintf( - "The environment %s has children and therefore can't be deleted.", + "The environment %s has children and therefore can't be deactivated or deleted.", $this->api()->getEnvironmentLabel($environment, 'error') )); $this->stdErr->writeln("Please delete the environment's children first."); @@ -214,12 +213,12 @@ function ($environment) { continue; } if ($environment->status === 'deleting') { - $this->stdErr->writeln("The environment $environmentId is already being deleted."); + $this->stdErr->writeln("The environment $environmentId is already being deactivated or deleted."); $needNewline = true; continue; } if ($environment->status === 'dirty') { - $this->stdErr->writeln("The environment $environmentId is currently building, and therefore can't be deleted. Please wait."); + $this->stdErr->writeln("The environment $environmentId is currently building, and therefore can't be deactivated or deleted. Please wait."); $error = $needNewline = true; continue; } @@ -228,10 +227,10 @@ function ($environment) { if ($environment->isActive()) { $needNewline = true; $this->stdErr->writeln(\sprintf( - 'The environment %s is currently active: deleting it will delete all associated data.', + 'The environment %s is currently active. Deactivating it will destroy all associated data and services.', $this->api()->getEnvironmentLabel($environment, 'comment') )); - if ($questionHelper->confirm('Are you sure you want to delete this environment?')) { + if ($questionHelper->confirm('Are you sure you want to deactivate this environment?')) { $toDeactivate[$environmentId] = $environment; } else { $error = true; @@ -259,7 +258,7 @@ function ($environment) { } if (empty($toDeleteBranch) && empty($toDeactivate)) { - $this->stdErr->writeln('No environment(s) to delete.'); + $this->stdErr->writeln('No environments to deactivate or delete.'); if (!$anythingSpecified) { $this->stdErr->writeln(\sprintf('For help, run: %s help environment:delete', $this->config()->get('application.executable'))); } @@ -299,7 +298,7 @@ protected function deleteMultiple(array $toDeactivate, array $toDeleteBranch, In /** @var Environment $environment */ foreach ($toDeactivate as $environmentId => $environment) { try { - $this->stdErr->writeln("Deleting environment $environmentId"); + $this->stdErr->writeln("Deactivating environment $environmentId"); $deactivateActivities[] = $environment->deactivate(); $deactivated++; } catch (\Exception $e) {