From e5a3ce8cfd8f156a197b93630e92ec8855348a9a Mon Sep 17 00:00:00 2001
From: Nuno Maduro <enunomaduro@gmail.com>
Date: Tue, 23 Jan 2024 16:14:14 +0000
Subject: [PATCH] [5.x] Implies only the new migrations behaviour on L11 (#305)

* Implies only the new migrations behaviour on L11

* Improves method `usingLaravel11OrNewer`
---
 src/NewCommand.php                     | 22 ++++----
 tests/NewCommandTest.php               | 13 +++++
 tests/fixtures/laravel10/composer.json | 66 ++++++++++++++++++++++++
 tests/fixtures/laravel11/composer.json | 69 ++++++++++++++++++++++++++
 tests/fixtures/laravel12/composer.json | 69 ++++++++++++++++++++++++++
 5 files changed, 226 insertions(+), 13 deletions(-)
 create mode 100644 tests/fixtures/laravel10/composer.json
 create mode 100644 tests/fixtures/laravel11/composer.json
 create mode 100644 tests/fixtures/laravel12/composer.json

diff --git a/src/NewCommand.php b/src/NewCommand.php
index 94278795..83700006 100644
--- a/src/NewCommand.php
+++ b/src/NewCommand.php
@@ -243,7 +243,7 @@ protected function defaultBranch()
     protected function configureDefaultDatabaseConnection(string $directory, string $database, string $name, bool $migrate)
     {
         // MariaDB configuration only exists as of Laravel 11...
-        if ($database === 'mariadb' && ! $this->hasMariaDBConfig($directory)) {
+        if ($database === 'mariadb' && ! $this->usingLaravel11OrNewer($directory)) {
             $database = 'mysql';
         }
 
@@ -308,22 +308,18 @@ protected function configureDefaultDatabaseConnection(string $directory, string
     }
 
     /**
-     * Determine if the application has a MariaDB configuration entry.
+     * Determine if the application is using Laravel 11 or newer.
      *
      * @param  string  $directory
      * @return bool
      */
-    protected function hasMariaDBConfig(string $directory): bool
+    public function usingLaravel11OrNewer(string $directory): bool
     {
-        // Laravel 11+ has moved the configuration files into the framework...
-        if (! file_exists($directory.'/config/database.php')) {
-            return true;
-        }
+        $version = json_decode(file_get_contents($directory.'/composer.json'), true)['require']['laravel/framework'];
+        $version = str_replace('^', '', $version);
+        $version = explode('.', $version)[0];
 
-        return str_contains(
-            file_get_contents($directory.'/config/database.php'),
-            "'mariadb' =>"
-        );
+        return $version >= 11;
     }
 
     /**
@@ -450,7 +446,7 @@ protected function installJetstream(string $directory, InputInterface $input, Ou
     protected function promptForDatabaseOptions(string $directory, InputInterface $input)
     {
         // Laravel 11.x appliations use SQLite as default...
-        $defaultDatabase = $this->hasMariaDBConfig($directory) ? 'sqlite' : 'mysql';
+        $defaultDatabase = $this->usingLaravel11OrNewer($directory) ? 'sqlite' : 'mysql';
 
         if ($input->isInteractive()) {
             $database = select(
@@ -465,7 +461,7 @@ protected function promptForDatabaseOptions(string $directory, InputInterface $i
                 default: $defaultDatabase
             );
 
-            if ($database !== $defaultDatabase) {
+            if ($this->usingLaravel11OrNewer($directory) && $database !== $defaultDatabase) {
                 $migrate = confirm(label: 'Default database updated. Would you like to run the default database migrations?', default: true);
             }
         }
diff --git a/tests/NewCommandTest.php b/tests/NewCommandTest.php
index 4ed37aed..43ddf072 100644
--- a/tests/NewCommandTest.php
+++ b/tests/NewCommandTest.php
@@ -33,4 +33,17 @@ public function test_it_can_scaffold_a_new_laravel_app()
         $this->assertDirectoryExists($scaffoldDirectory.'/vendor');
         $this->assertFileExists($scaffoldDirectory.'/.env');
     }
+
+    public function test_on_at_least_laravel_11()
+    {
+        $command = new NewCommand;
+
+        $onLaravel10 = $command->usingLaravel11OrNewer(__DIR__.'/fixtures/laravel10');
+        $onLaravel11 = $command->usingLaravel11OrNewer(__DIR__.'/fixtures/laravel11');
+        $onLaravel12 = $command->usingLaravel11OrNewer(__DIR__.'/fixtures/laravel12');
+
+        $this->assertFalse($onLaravel10);
+        $this->assertTrue($onLaravel11);
+        $this->assertTrue($onLaravel12);
+    }
 }
diff --git a/tests/fixtures/laravel10/composer.json b/tests/fixtures/laravel10/composer.json
new file mode 100644
index 00000000..8a3d72d4
--- /dev/null
+++ b/tests/fixtures/laravel10/composer.json
@@ -0,0 +1,66 @@
+{
+    "name": "laravel/laravel",
+    "type": "project",
+    "description": "The skeleton application for the Laravel framework.",
+    "keywords": ["laravel", "framework"],
+    "license": "MIT",
+    "require": {
+        "php": "^8.1",
+        "guzzlehttp/guzzle": "^7.2",
+        "laravel/framework": "^10.10",
+        "laravel/sanctum": "^3.3",
+        "laravel/tinker": "^2.8"
+    },
+    "require-dev": {
+        "fakerphp/faker": "^1.9.1",
+        "laravel/pint": "^1.0",
+        "laravel/sail": "^1.18",
+        "mockery/mockery": "^1.4.4",
+        "nunomaduro/collision": "^7.0",
+        "phpunit/phpunit": "^10.1",
+        "spatie/laravel-ignition": "^2.0"
+    },
+    "autoload": {
+        "psr-4": {
+            "App\\": "app/",
+            "Database\\Factories\\": "database/factories/",
+            "Database\\Seeders\\": "database/seeders/"
+        }
+    },
+    "autoload-dev": {
+        "psr-4": {
+            "Tests\\": "tests/"
+        }
+    },
+    "scripts": {
+        "post-autoload-dump": [
+            "Illuminate\\Foundation\\ComposerScripts::postAutoloadDump",
+            "@php artisan package:discover --ansi"
+        ],
+        "post-update-cmd": [
+            "@php artisan vendor:publish --tag=laravel-assets --ansi --force"
+        ],
+        "post-root-package-install": [
+            "@php -r \"file_exists('.env') || copy('.env.example', '.env');\""
+        ],
+        "post-create-project-cmd": [
+            "@php artisan key:generate --ansi"
+        ]
+    },
+    "extra": {
+        "laravel": {
+            "dont-discover": []
+        }
+    },
+    "config": {
+        "optimize-autoloader": true,
+        "preferred-install": "dist",
+        "sort-packages": true,
+        "allow-plugins": {
+            "pestphp/pest-plugin": true,
+            "php-http/discovery": true
+        }
+    },
+    "minimum-stability": "stable",
+    "prefer-stable": true
+}
diff --git a/tests/fixtures/laravel11/composer.json b/tests/fixtures/laravel11/composer.json
new file mode 100644
index 00000000..3cdf16e3
--- /dev/null
+++ b/tests/fixtures/laravel11/composer.json
@@ -0,0 +1,69 @@
+{
+    "name": "laravel/laravel",
+    "type": "project",
+    "description": "The skeleton application for the Laravel framework.",
+    "keywords": ["laravel", "framework"],
+    "license": "MIT",
+    "require": {
+        "php": "^8.2",
+        "laravel/framework": "^11.0",
+        "laravel/tinker": "^2.9"
+    },
+    "require-dev": {
+        "fakerphp/faker": "^1.23",
+        "laravel/pint": "^1.13",
+        "laravel/sail": "^1.26",
+        "mockery/mockery": "^1.6",
+        "nunomaduro/collision": "^8.0",
+        "phpunit/phpunit": "^10.5",
+        "spatie/laravel-ignition": "^2.4"
+    },
+    "autoload": {
+        "psr-4": {
+            "App\\": "app/",
+            "Database\\Factories\\": "database/factories/",
+            "Database\\Seeders\\": "database/seeders/"
+        }
+    },
+    "autoload-dev": {
+        "psr-4": {
+            "Tests\\": "tests/"
+        }
+    },
+    "scripts": {
+        "post-autoload-dump": [
+            "Illuminate\\Foundation\\ComposerScripts::postAutoloadDump",
+            "@php artisan package:discover --ansi"
+        ],
+        "post-update-cmd": [
+            "@php artisan vendor:publish --tag=laravel-assets --ansi --force"
+        ],
+        "post-root-package-install": [
+            "@php -r \"file_exists('.env') || copy('.env.example', '.env');\""
+        ],
+        "post-create-project-cmd": [
+            "@php artisan key:generate --ansi",
+            "@php -r \"file_exists('database/database.sqlite') || touch('database/database.sqlite');\"",
+            "@php artisan migrate --ansi"
+        ]
+    },
+    "extra": {
+        "branch-alias": {
+            "dev-master": "11.x-dev"
+        },
+        "laravel": {
+            "dont-discover": []
+        }
+    },
+    "config": {
+        "optimize-autoloader": true,
+        "preferred-install": "dist",
+        "sort-packages": true,
+        "allow-plugins": {
+            "pestphp/pest-plugin": true,
+            "php-http/discovery": true
+        }
+    },
+    "minimum-stability": "dev",
+    "prefer-stable": true
+}
diff --git a/tests/fixtures/laravel12/composer.json b/tests/fixtures/laravel12/composer.json
new file mode 100644
index 00000000..71811458
--- /dev/null
+++ b/tests/fixtures/laravel12/composer.json
@@ -0,0 +1,69 @@
+{
+    "name": "laravel/laravel",
+    "type": "project",
+    "description": "The skeleton application for the Laravel framework.",
+    "keywords": ["laravel", "framework"],
+    "license": "MIT",
+    "require": {
+        "php": "^8.2",
+        "laravel/framework": "^12.0.1",
+        "laravel/tinker": "^2.9"
+    },
+    "require-dev": {
+        "fakerphp/faker": "^1.23",
+        "laravel/pint": "^1.13",
+        "laravel/sail": "^1.26",
+        "mockery/mockery": "^1.6",
+        "nunomaduro/collision": "^8.0",
+        "phpunit/phpunit": "^10.5",
+        "spatie/laravel-ignition": "^2.4"
+    },
+    "autoload": {
+        "psr-4": {
+            "App\\": "app/",
+            "Database\\Factories\\": "database/factories/",
+            "Database\\Seeders\\": "database/seeders/"
+        }
+    },
+    "autoload-dev": {
+        "psr-4": {
+            "Tests\\": "tests/"
+        }
+    },
+    "scripts": {
+        "post-autoload-dump": [
+            "Illuminate\\Foundation\\ComposerScripts::postAutoloadDump",
+            "@php artisan package:discover --ansi"
+        ],
+        "post-update-cmd": [
+            "@php artisan vendor:publish --tag=laravel-assets --ansi --force"
+        ],
+        "post-root-package-install": [
+            "@php -r \"file_exists('.env') || copy('.env.example', '.env');\""
+        ],
+        "post-create-project-cmd": [
+            "@php artisan key:generate --ansi",
+            "@php -r \"file_exists('database/database.sqlite') || touch('database/database.sqlite');\"",
+            "@php artisan migrate --ansi"
+        ]
+    },
+    "extra": {
+        "branch-alias": {
+            "dev-master": "11.x-dev"
+        },
+        "laravel": {
+            "dont-discover": []
+        }
+    },
+    "config": {
+        "optimize-autoloader": true,
+        "preferred-install": "dist",
+        "sort-packages": true,
+        "allow-plugins": {
+            "pestphp/pest-plugin": true,
+            "php-http/discovery": true
+        }
+    },
+    "minimum-stability": "dev",
+    "prefer-stable": true
+}