From 5701008273af70c958426510a33e7a23fa7779b4 Mon Sep 17 00:00:00 2001 From: Nuno Maduro Date: Tue, 12 Mar 2024 18:18:48 +0000 Subject: [PATCH] [11.x] Adds `--graceful` to `php artisan migrate` (#50486) * Adds `--graceful` * Update MigrateCommand.php * Update MigrateCommand.php --------- Co-authored-by: Taylor Otwell --- .../Console/Migrations/MigrateCommand.php | 27 ++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/src/Illuminate/Database/Console/Migrations/MigrateCommand.php b/src/Illuminate/Database/Console/Migrations/MigrateCommand.php index 5f7e1c87b10f..12cab1eb1032 100755 --- a/src/Illuminate/Database/Console/Migrations/MigrateCommand.php +++ b/src/Illuminate/Database/Console/Migrations/MigrateCommand.php @@ -31,7 +31,8 @@ class MigrateCommand extends BaseCommand implements Isolatable {--pretend : Dump the SQL queries that would be run} {--seed : Indicates if the seed task should be re-run} {--seeder= : The class name of the root seeder} - {--step : Force the migrations to be run so they can be rolled back individually}'; + {--step : Force the migrations to be run so they can be rolled back individually} + {--graceful : Return a successful exit code even if an error occurs}'; /** * The console command description. @@ -80,6 +81,28 @@ public function handle() return 1; } + try { + $this->runMigrations(); + } catch (Throwable $e) { + if ($this->option('graceful')) { + $this->components->warn($e->getMessage()); + + return 0; + } + + throw $e; + } + + return 0; + } + + /** + * Run the pending migrations. + * + * @return void + */ + protected function runMigrations() + { $this->migrator->usingConnection($this->option('database'), function () { $this->prepareDatabase(); @@ -102,8 +125,6 @@ public function handle() ]); } }); - - return 0; } /**