diff --git a/.github/workflows/analyse.yaml b/.github/workflows/analyse.yaml index c21b200c..743046ec 100644 --- a/.github/workflows/analyse.yaml +++ b/.github/workflows/analyse.yaml @@ -3,6 +3,7 @@ name: analyse on: push: pull_request: + workflow_dispatch: jobs: analyse: @@ -14,10 +15,12 @@ jobs: - "ubuntu-latest" php: - 8.2 + dependencies: + - "highest" experimental: - false - name: PHP${{ matrix.php }} on ${{ matrix.os }} + name: PHP${{ matrix.php }} PHPStan & Pint steps: - name: Checkout code @@ -27,20 +30,50 @@ jobs: uses: shivammathur/setup-php@v2 with: php-version: ${{ matrix.php }} - extensions: dom, curl, libxml, mbstring, zip, pcntl, pdo, sqlite, pdo_sqlite, mysql, mysqli, pdo_mysql, bcmath, intl, fileinfo + extensions: dom, curl, libxml, mbstring, zip, pcntl, sqlite3, pdo_sqlite, bcmath, fileinfo coverage: none - name: Install dependencies uses: "ramsey/composer-install@v2" with: - dependency-versions: "highest" + dependency-versions: "${{ matrix.dependencies }}" composer-options: "--prefer-dist --no-cache" - - name: Installed dependencies - run: composer show -D - - - name: Execute Code Style Analysis - run: vendor/bin/pint --test - - name: Execute Static Code Analysis run: vendor/bin/phpstan analyse + + lint: + runs-on: ${{ matrix.os }} + continue-on-error: ${{ matrix.experimental }} + strategy: + matrix: + os: + - "ubuntu-latest" + php: + - 8.3 + dependencies: + - "highest" + experimental: + - false + + name: PHP${{ matrix.php }} Code Lint + + steps: + - name: Checkout code + uses: actions/checkout@v3 + + - name: Setup PHP + uses: shivammathur/setup-php@v2 + with: + php-version: ${{ matrix.php }} + extensions: dom, curl, libxml, mbstring, zip, pcntl, sqlite3, pdo_sqlite, bcmath, fileinfo + coverage: none + + - name: Install dependencies + uses: "ramsey/composer-install@v2" + with: + dependency-versions: "${{ matrix.dependencies }}" + composer-options: "--prefer-dist --no-cache" + + - name: PHP Lint + run: php -l ./src diff --git a/.github/workflows/audits.yaml b/.github/workflows/audits.yaml index 8e72e0c9..e5ea1e67 100644 --- a/.github/workflows/audits.yaml +++ b/.github/workflows/audits.yaml @@ -14,6 +14,7 @@ jobs: - "ubuntu-latest" php: - 8.2 + - 8.3 experimental: - true diff --git a/.github/workflows/tests.yaml b/.github/workflows/tests.yaml index 7dc251ad..41440231 100644 --- a/.github/workflows/tests.yaml +++ b/.github/workflows/tests.yaml @@ -3,6 +3,7 @@ name: tests on: push: pull_request: + workflow_dispatch: schedule: - cron: '0 0 * * 4' diff --git a/composer.json b/composer.json index b19f061c..5e531453 100644 --- a/composer.json +++ b/composer.json @@ -36,6 +36,7 @@ "illuminate/support": "^11.0", "orchestra/canvas-core": "^9.0", "orchestra/testbench-core": "^9.0", + "symfony/polyfill-php83": "^1.28", "symfony/yaml": "^7.0" }, "require-dev": { diff --git a/src/Console/BatchesTableCommand.php b/src/Console/BatchesTableCommand.php index 7f054eb9..413c4c5a 100644 --- a/src/Console/BatchesTableCommand.php +++ b/src/Console/BatchesTableCommand.php @@ -33,6 +33,7 @@ public function __construct(Filesystem $files) * @param string $table * @return string */ + #[\Override] protected function createBaseMigration($table) { return $this->createBaseMigrationUsingCanvas($table); @@ -44,6 +45,7 @@ protected function createBaseMigration($table) * @param string $table * @return bool */ + #[\Override] protected function migrationExists($table) { return $this->migrationExistsUsingCanvas($table); diff --git a/src/Console/CacheTableCommand.php b/src/Console/CacheTableCommand.php index b579a206..7103d686 100644 --- a/src/Console/CacheTableCommand.php +++ b/src/Console/CacheTableCommand.php @@ -33,6 +33,7 @@ public function __construct(Filesystem $files) * @param string $table * @return string */ + #[\Override] protected function createBaseMigration($table) { return $this->createBaseMigrationUsingCanvas($table); @@ -44,6 +45,7 @@ protected function createBaseMigration($table) * @param string $table * @return bool */ + #[\Override] protected function migrationExists($table) { return $this->migrationExistsUsingCanvas($table); diff --git a/src/Console/CastMakeCommand.php b/src/Console/CastMakeCommand.php index 7b2b0b32..d6491c89 100644 --- a/src/Console/CastMakeCommand.php +++ b/src/Console/CastMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -56,6 +58,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/ChannelMakeCommand.php b/src/Console/ChannelMakeCommand.php index 6bcbd29c..dc5cf6f4 100644 --- a/src/Console/ChannelMakeCommand.php +++ b/src/Console/ChannelMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -48,6 +49,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -58,6 +60,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/CodeMakeCommand.php b/src/Console/CodeMakeCommand.php index f12b0d58..32533d32 100644 --- a/src/Console/CodeMakeCommand.php +++ b/src/Console/CodeMakeCommand.php @@ -43,6 +43,7 @@ protected function resolveDefaultStubPath($stub) * * @return array */ + #[\Override] protected function getOptions() { return [ diff --git a/src/Console/Commander.php b/src/Console/Commander.php index 02c58453..14e467df 100644 --- a/src/Console/Commander.php +++ b/src/Console/Commander.php @@ -6,7 +6,6 @@ use Illuminate\Contracts\Console\Kernel as ConsoleKernel; use Illuminate\Foundation\Application as LaravelApplication; use Illuminate\Support\Collection; -use Illuminate\Support\Str; use Orchestra\Canvas\CanvasServiceProvider; use Orchestra\Canvas\LaravelServiceProvider; use Symfony\Component\Console\Command\Command as SymfonyCommand; @@ -25,9 +24,10 @@ class Commander extends \Orchestra\Testbench\Console\Commander * * @return \Closure(\Illuminate\Foundation\Application):void */ + #[\Override] protected function resolveApplicationCallback() { - return function ($app) { + return static function ($app) { $app->register(CanvasServiceProvider::class); }; } @@ -37,6 +37,7 @@ protected function resolveApplicationCallback() * * @return \Illuminate\Foundation\Application */ + #[\Override] public function laravel() { if (! $this->app instanceof LaravelApplication) { @@ -47,9 +48,9 @@ public function laravel() $app->register(LaravelServiceProvider::class); Collection::make($kernel->all()) - ->reject(function (SymfonyCommand $command, string $name) { - return Str::startsWith('make:', $name) || $command instanceof GeneratorCommand; - })->each(function (SymfonyCommand $command) { + ->reject(static function (SymfonyCommand $command, string $name) { + return str_starts_with('make:', $name) || $command instanceof GeneratorCommand; + })->each(static function (SymfonyCommand $command) { $command->setHidden(true); }); } diff --git a/src/Console/ComponentMakeCommand.php b/src/Console/ComponentMakeCommand.php index 96ca3990..060ff1bb 100644 --- a/src/Console/ComponentMakeCommand.php +++ b/src/Console/ComponentMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -60,6 +61,7 @@ public function afterCodeHasBeenGenerated(string $className, string $path): void * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -70,6 +72,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); @@ -81,6 +84,7 @@ protected function rootNamespace() * @param string $path * @return string */ + #[\Override] protected function viewPath($path = '') { return $this->viewPathUsingCanvas($path); diff --git a/src/Console/ConsoleMakeCommand.php b/src/Console/ConsoleMakeCommand.php index 9f6524da..dc005524 100644 --- a/src/Console/ConsoleMakeCommand.php +++ b/src/Console/ConsoleMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -48,6 +49,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -58,6 +60,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); @@ -69,6 +72,7 @@ protected function rootNamespace() * @param string $rootNamespace * @return string */ + #[\Override] protected function getDefaultNamespace($rootNamespace) { return rtrim($this->generatorPreset()->commandNamespace(), '\\'); diff --git a/src/Console/ControllerMakeCommand.php b/src/Console/ControllerMakeCommand.php index f5b4790e..fa8adbca 100644 --- a/src/Console/ControllerMakeCommand.php +++ b/src/Console/ControllerMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -48,6 +49,7 @@ public function handle() * @param string $model * @return string */ + #[\Override] protected function qualifyModel(string $model) { return $this->qualifyModelUsingCanvas($model); @@ -58,6 +60,7 @@ protected function qualifyModel(string $model) * * @return array */ + #[\Override] protected function buildParentReplacements() { $parentModelClass = $this->parseModel($this->option('parent')); @@ -86,6 +89,7 @@ protected function buildParentReplacements() * @param array $replace * @return array */ + #[\Override] protected function buildModelReplacements(array $replace) { $modelClass = $this->parseModel($this->option('model')); @@ -96,6 +100,12 @@ protected function buildModelReplacements(array $replace) $replace = $this->buildFormRequestReplacements($replace, $modelClass); + if ($this->option('requests')) { + $namespace = $this->rootNamespace(); + $replace['{{ namespacedRequests }}'] = str_replace('App\\', $namespace, $replace['{{ namespacedRequests }}']); + $replace['{{namespacedRequests}}'] = str_replace('App\\', $namespace, $replace['{{namespacedRequests}}']); + } + return array_merge($replace, [ 'DummyFullModelClass' => $modelClass, '{{ namespacedModel }}' => $modelClass, @@ -115,6 +125,7 @@ protected function buildModelReplacements(array $replace) * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -125,6 +136,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); @@ -135,8 +147,37 @@ protected function rootNamespace() * * @return array */ + #[\Override] protected function possibleModels() { return $this->possibleModelsUsingCanvas(); } + + /** + * Generate the form requests for the given model and classes. + * + * @param string $modelClass + * @param string $storeRequestClass + * @param string $updateRequestClass + * @return array + */ + #[\Override] + protected function generateFormRequests($modelClass, $storeRequestClass, $updateRequestClass) + { + $storeRequestClass = 'Store'.class_basename($modelClass).'Request'; + + $this->call('make:request', [ + 'name' => $storeRequestClass, + '--preset' => $this->option('preset'), + ]); + + $updateRequestClass = 'Update'.class_basename($modelClass).'Request'; + + $this->call('make:request', [ + 'name' => $updateRequestClass, + '--preset' => $this->option('preset'), + ]); + + return [$storeRequestClass, $updateRequestClass]; + } } diff --git a/src/Console/EventMakeCommand.php b/src/Console/EventMakeCommand.php index d69b680a..bf44bc77 100644 --- a/src/Console/EventMakeCommand.php +++ b/src/Console/EventMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -56,6 +58,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/ExceptionMakeCommand.php b/src/Console/ExceptionMakeCommand.php index 1a41532b..2393af35 100644 --- a/src/Console/ExceptionMakeCommand.php +++ b/src/Console/ExceptionMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -56,6 +58,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/FactoryMakeCommand.php b/src/Console/FactoryMakeCommand.php index 2dcb792f..1fdc9de9 100644 --- a/src/Console/FactoryMakeCommand.php +++ b/src/Console/FactoryMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -59,6 +60,7 @@ protected function resolveDefaultStubPath($stub) * @param string $name * @return string */ + #[\Override] protected function getNamespace($name) { return rtrim($this->generatorPreset()->factoryNamespace(), '\\'); @@ -78,6 +80,7 @@ protected function getGeneratorSourcePath(): string * @param string $name * @return string */ + #[\Override] protected function guessModelName($name) { if (str_ends_with($name, 'Factory')) { @@ -93,6 +96,7 @@ protected function guessModelName($name) * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -103,6 +107,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); @@ -113,6 +118,7 @@ protected function rootNamespace() * * @return string|null */ + #[\Override] protected function userProviderModel() { return $this->userProviderModelUsingCanvas(); diff --git a/src/Console/FailedTableCommand.php b/src/Console/FailedTableCommand.php index e2c0d071..54756d1b 100644 --- a/src/Console/FailedTableCommand.php +++ b/src/Console/FailedTableCommand.php @@ -33,6 +33,7 @@ public function __construct(Filesystem $files) * @param string $table * @return string */ + #[\Override] protected function createBaseMigration($table) { return $this->createBaseMigrationUsingCanvas($table); @@ -44,6 +45,7 @@ protected function createBaseMigration($table) * @param string $table * @return bool */ + #[\Override] protected function migrationExists($table) { return $this->migrationExistsUsingCanvas($table); diff --git a/src/Console/GeneratorMakeCommand.php b/src/Console/GeneratorMakeCommand.php index 8a3f6697..de1e2137 100644 --- a/src/Console/GeneratorMakeCommand.php +++ b/src/Console/GeneratorMakeCommand.php @@ -27,6 +27,7 @@ class GeneratorMakeCommand extends GeneratorCommand * @param string $name * @return string */ + #[\Override] protected function replaceClass($stub, $name) { $stub = parent::replaceClass($stub, $name); @@ -42,6 +43,7 @@ protected function replaceClass($stub, $name) * * @return string */ + #[\Override] protected function getStub() { return $this->resolveStubPath('/stubs/generator.stub'); @@ -64,6 +66,7 @@ protected function resolveDefaultStubPath($stub) * @param string $rootNamespace * @return string */ + #[\Override] protected function getDefaultNamespace($rootNamespace) { return rtrim($this->generatorPreset()->commandNamespace(), '\\'); @@ -74,6 +77,7 @@ protected function getDefaultNamespace($rootNamespace) * * @return array */ + #[\Override] protected function getOptions() { return [ diff --git a/src/Console/JobMakeCommand.php b/src/Console/JobMakeCommand.php index 36b9c223..186e5ad9 100644 --- a/src/Console/JobMakeCommand.php +++ b/src/Console/JobMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -48,6 +49,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -58,6 +60,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/ListenerMakeCommand.php b/src/Console/ListenerMakeCommand.php index fada698b..c33036f7 100644 --- a/src/Console/ListenerMakeCommand.php +++ b/src/Console/ListenerMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -48,6 +49,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -58,6 +60,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); @@ -68,6 +71,7 @@ protected function rootNamespace() * * @return array */ + #[\Override] protected function possibleEvents() { return $this->possibleEventsUsingCanvas(); diff --git a/src/Console/MailMakeCommand.php b/src/Console/MailMakeCommand.php index 363aacb4..91d7cb9a 100644 --- a/src/Console/MailMakeCommand.php +++ b/src/Console/MailMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -58,6 +59,7 @@ public function afterCodeHasBeenGenerated(string $className, string $path): void * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -68,6 +70,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/MiddlewareMakeCommand.php b/src/Console/MiddlewareMakeCommand.php index f1010e4b..ec54f2f1 100644 --- a/src/Console/MiddlewareMakeCommand.php +++ b/src/Console/MiddlewareMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -48,6 +49,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -58,6 +60,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/MigrateMakeCommand.php b/src/Console/MigrateMakeCommand.php index b5d1b81a..d11f5ef4 100644 --- a/src/Console/MigrateMakeCommand.php +++ b/src/Console/MigrateMakeCommand.php @@ -42,6 +42,7 @@ public function __construct(MigrationCreator $creator, Composer $composer) * * @return void */ + #[\Override] public function handle() { $preset = $this->generatorPreset(); diff --git a/src/Console/ModelMakeCommand.php b/src/Console/ModelMakeCommand.php index 342cef1b..06e00294 100644 --- a/src/Console/ModelMakeCommand.php +++ b/src/Console/ModelMakeCommand.php @@ -38,11 +38,15 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; } + /** + * Run after code successfully generated. + */ protected function afterCodeHasBeenGenerated(): void { if ($this->option('all')) { @@ -80,6 +84,7 @@ protected function afterCodeHasBeenGenerated(): void * * @return void */ + #[\Override] protected function createFactory() { $factory = Str::studly($this->getNameInput()); @@ -87,6 +92,7 @@ protected function createFactory() $this->call('make:factory', [ 'name' => "{$factory}Factory", '--model' => $this->qualifyClass($this->getNameInput()), + '--preset' => $this->option('preset'), ]); } @@ -95,6 +101,7 @@ protected function createFactory() * * @return void */ + #[\Override] protected function createMigration() { $table = Str::snake(Str::pluralStudly(class_basename($this->getNameInput()))); @@ -116,6 +123,7 @@ protected function createMigration() * * @return void */ + #[\Override] protected function createSeeder() { $seeder = Str::studly(class_basename($this->getNameInput())); @@ -131,6 +139,7 @@ protected function createSeeder() * * @return void */ + #[\Override] protected function createController() { $controller = Str::studly(class_basename($this->getNameInput())); @@ -151,6 +160,7 @@ protected function createController() * * @return void */ + #[\Override] protected function createPolicy() { $policy = Str::studly(class_basename($this->getNameInput())); @@ -168,6 +178,7 @@ protected function createPolicy() * @param string $rootNamespace * @return string */ + #[\Override] protected function getDefaultNamespace($rootNamespace) { return rtrim($this->generatorPreset()->modelNamespace(), '\\'); @@ -179,6 +190,7 @@ protected function getDefaultNamespace($rootNamespace) * @param string $model * @return string */ + #[\Override] protected function qualifyModel(string $model) { return $this->qualifyModelUsingCanvas($model); @@ -190,6 +202,7 @@ protected function qualifyModel(string $model) * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -200,6 +213,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/NotificationMakeCommand.php b/src/Console/NotificationMakeCommand.php index 3e02b38e..d3c4bdbf 100644 --- a/src/Console/NotificationMakeCommand.php +++ b/src/Console/NotificationMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -58,6 +59,7 @@ public function afterCodeHasBeenGenerated(string $className, string $path): void * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -68,6 +70,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/NotificationTableCommand.php b/src/Console/NotificationTableCommand.php index 1da9fa08..630fe080 100644 --- a/src/Console/NotificationTableCommand.php +++ b/src/Console/NotificationTableCommand.php @@ -33,6 +33,7 @@ public function __construct(Filesystem $files) * @param string $table * @return string */ + #[\Override] protected function createBaseMigration($table) { return $this->createBaseMigrationUsingCanvas($table); @@ -44,6 +45,7 @@ protected function createBaseMigration($table) * @param string $table * @return bool */ + #[\Override] protected function migrationExists($table) { return $this->migrationExistsUsingCanvas($table); diff --git a/src/Console/ObserverMakeCommand.php b/src/Console/ObserverMakeCommand.php index e44bcf88..fec9e22c 100644 --- a/src/Console/ObserverMakeCommand.php +++ b/src/Console/ObserverMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $model * @return string */ + #[\Override] protected function qualifyModel(string $model) { return $this->qualifyModelUsingCanvas($model); @@ -57,6 +59,7 @@ protected function qualifyModel(string $model) * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -67,6 +70,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); @@ -77,6 +81,7 @@ protected function rootNamespace() * * @return array */ + #[\Override] protected function possibleModels() { return $this->possibleModelsUsingCanvas(); diff --git a/src/Console/PolicyMakeCommand.php b/src/Console/PolicyMakeCommand.php index 8cce2eb5..1d44d6f5 100644 --- a/src/Console/PolicyMakeCommand.php +++ b/src/Console/PolicyMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $model * @return string */ + #[\Override] protected function qualifyModel(string $model) { return $this->qualifyModelUsingCanvas($model); @@ -57,6 +59,7 @@ protected function qualifyModel(string $model) * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -67,6 +70,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); @@ -77,6 +81,7 @@ protected function rootNamespace() * * @return string|null */ + #[\Override] protected function userProviderModel() { /** @var string|null $guard */ @@ -90,6 +95,7 @@ protected function userProviderModel() * * @return array */ + #[\Override] protected function possibleModels() { return $this->possibleModelsUsingCanvas(); diff --git a/src/Console/PresetMakeCommand.php b/src/Console/PresetMakeCommand.php index 8a4c9209..ca953746 100644 --- a/src/Console/PresetMakeCommand.php +++ b/src/Console/PresetMakeCommand.php @@ -42,6 +42,7 @@ protected function getStub() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->generatorPreset()->basePath().'/canvas.yaml'; @@ -50,6 +51,7 @@ protected function getPath($name) /** * Get the root namespace for the class. */ + #[\Override] protected function rootNamespace(): string { $namespace = transform($this->option('namespace'), function (string $namespace) { @@ -74,6 +76,7 @@ protected function rootNamespace(): string * * @return array */ + #[\Override] protected function getOptions() { return [ diff --git a/src/Console/ProviderMakeCommand.php b/src/Console/ProviderMakeCommand.php index e7a71ea8..41ba0269 100644 --- a/src/Console/ProviderMakeCommand.php +++ b/src/Console/ProviderMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -56,6 +58,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); @@ -67,6 +70,7 @@ protected function rootNamespace() * @param string $rootNamespace * @return string */ + #[\Override] protected function getDefaultNamespace($rootNamespace) { return rtrim($this->generatorPreset()->providerNamespace(), '\\'); diff --git a/src/Console/QueueTableCommand.php b/src/Console/QueueTableCommand.php index 3e235e49..c4ffea32 100644 --- a/src/Console/QueueTableCommand.php +++ b/src/Console/QueueTableCommand.php @@ -34,6 +34,7 @@ public function __construct(Filesystem $files) * @param string $table * @return string */ + #[\Override] protected function createBaseMigration($table) { return $this->createBaseMigrationUsingCanvas($table); @@ -45,6 +46,7 @@ protected function createBaseMigration($table) * @param string $table * @return bool */ + #[\Override] protected function migrationExists($table) { return $this->migrationExistsUsingCanvas($table); diff --git a/src/Console/RequestMakeCommand.php b/src/Console/RequestMakeCommand.php index 820f367b..6c4eddce 100644 --- a/src/Console/RequestMakeCommand.php +++ b/src/Console/RequestMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -56,6 +58,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/ResourceMakeCommand.php b/src/Console/ResourceMakeCommand.php index ab69423a..e44d634f 100644 --- a/src/Console/ResourceMakeCommand.php +++ b/src/Console/ResourceMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -56,6 +58,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/RuleMakeCommand.php b/src/Console/RuleMakeCommand.php index 4881c292..473db560 100644 --- a/src/Console/RuleMakeCommand.php +++ b/src/Console/RuleMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -56,6 +58,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/ScopeMakeCommand.php b/src/Console/ScopeMakeCommand.php index 2b30066f..88f6d3e6 100644 --- a/src/Console/ScopeMakeCommand.php +++ b/src/Console/ScopeMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -46,6 +47,7 @@ public function handle() * @param string $model * @return string */ + #[\Override] protected function qualifyModel(string $model) { return $this->qualifyModelUsingCanvas($model); @@ -57,6 +59,7 @@ protected function qualifyModel(string $model) * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -67,6 +70,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); diff --git a/src/Console/SeederMakeCommand.php b/src/Console/SeederMakeCommand.php index 36a25ec4..3d3af4b0 100644 --- a/src/Console/SeederMakeCommand.php +++ b/src/Console/SeederMakeCommand.php @@ -35,6 +35,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -54,6 +55,7 @@ protected function getGeneratorSourcePath(): string * @param string $name * @return string */ + #[\Override] protected function getPath($name) { return $this->getPathUsingCanvas($name); @@ -64,6 +66,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->generatorPreset()->seederNamespace(); diff --git a/src/Console/SessionTableCommand.php b/src/Console/SessionTableCommand.php index 9e2d9d4f..6dcf9dc3 100644 --- a/src/Console/SessionTableCommand.php +++ b/src/Console/SessionTableCommand.php @@ -33,6 +33,7 @@ public function __construct(Filesystem $files) * @param string $table * @return string */ + #[\Override] protected function createBaseMigration($table) { return $this->createBaseMigrationUsingCanvas($table); @@ -44,6 +45,7 @@ protected function createBaseMigration($table) * @param string $table * @return bool */ + #[\Override] protected function migrationExists($table) { return $this->migrationExistsUsingCanvas($table); diff --git a/src/Console/TestMakeCommand.php b/src/Console/TestMakeCommand.php index 2301cf70..c447e1d7 100644 --- a/src/Console/TestMakeCommand.php +++ b/src/Console/TestMakeCommand.php @@ -37,6 +37,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; diff --git a/src/Console/UserFactoryMakeCommand.php b/src/Console/UserFactoryMakeCommand.php index 15785244..5ab94916 100644 --- a/src/Console/UserFactoryMakeCommand.php +++ b/src/Console/UserFactoryMakeCommand.php @@ -45,6 +45,7 @@ protected function resolveDefaultStubPath($stub) * * @return string */ + #[\Override] protected function rootNamespace() { return $this->generatorPreset()->factoryNamespace(); @@ -81,6 +82,7 @@ public function generatingCode(string $stub, string $className): string * * @return string */ + #[\Override] protected function getNameInput() { return 'UserFactory'; @@ -91,6 +93,7 @@ protected function getNameInput() * * @return array */ + #[\Override] protected function getArguments() { return []; @@ -101,6 +104,7 @@ protected function getArguments() * * @return array */ + #[\Override] protected function getOptions() { return [ diff --git a/src/Console/UserModelMakeCommand.php b/src/Console/UserModelMakeCommand.php index 105b2b68..f049c8e7 100644 --- a/src/Console/UserModelMakeCommand.php +++ b/src/Console/UserModelMakeCommand.php @@ -43,6 +43,7 @@ protected function resolveDefaultStubPath($stub) /** * Get the default namespace for the class. */ + #[\Override] public function getDefaultNamespace($rootNamespace) { return rtrim($this->generatorPreset()->modelNamespace(), '\\'); @@ -53,6 +54,7 @@ public function getDefaultNamespace($rootNamespace) * * @return string */ + #[\Override] protected function getNameInput() { return 'User'; @@ -63,6 +65,7 @@ protected function getNameInput() * * @return array */ + #[\Override] protected function getArguments() { return []; @@ -73,6 +76,7 @@ protected function getArguments() * * @return array */ + #[\Override] protected function getOptions() { return [ diff --git a/src/Console/ViewMakeCommand.php b/src/Console/ViewMakeCommand.php index edc5ea9c..fd1959a8 100644 --- a/src/Console/ViewMakeCommand.php +++ b/src/Console/ViewMakeCommand.php @@ -38,6 +38,7 @@ public function __construct(Filesystem $files) * * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException */ + #[\Override] public function handle() { return $this->generateCode() ? self::SUCCESS : self::FAILURE; @@ -79,6 +80,7 @@ protected function resolveDefaultStubPath($stub) * @param string $name * @return string */ + #[\Override] protected function getPath($name) { /** @var string $extension */ @@ -94,6 +96,7 @@ protected function getPath($name) * * @return string */ + #[\Override] protected function getNameInput() { return transform($this->argument('name'), function (string $name) { @@ -147,6 +150,7 @@ protected function handleTestCreationUsingCanvas($path): bool * * @return string */ + #[\Override] protected function rootNamespace() { return $this->rootNamespaceUsingCanvas(); @@ -157,6 +161,7 @@ protected function rootNamespace() * * @return string */ + #[\Override] protected function getTestPath() { $preset = $this->generatorPreset(); @@ -175,6 +180,7 @@ protected function getTestPath() * * @return string */ + #[\Override] protected function getTestStub() { $stubName = 'view.'.($this->option('pest') ? 'pest' : 'test').'.stub'; diff --git a/src/Console/stubs/user-factory.stub b/src/Console/stubs/user-factory.stub index 0ed2cdac..1caebfe6 100644 --- a/src/Console/stubs/user-factory.stub +++ b/src/Console/stubs/user-factory.stub @@ -3,6 +3,7 @@ namespace {{ factoryNamespace }}; use Illuminate\Database\Eloquent\Factories\Factory; +use Illuminate\Support\Facades\Hash; use Illuminate\Support\Str; use {{ namespacedModel }}; @@ -11,6 +12,8 @@ use {{ namespacedModel }}; */ class UserFactory extends Factory { + protected static ?string $password; + /** * The name of the factory's corresponding model. * @@ -29,7 +32,7 @@ class UserFactory extends Factory 'name' => fake()->name(), 'email' => fake()->unique()->safeEmail(), 'email_verified_at' => now(), - 'password' => '$2y$10$92IXUNpkjO0rOQ5byMi.Ye4oKoEa3Ro9llC/.og/at2.uheWG/igi', // password + 'password' => static::$password ??= Hash::make('password'), 'remember_token' => Str::random(10), ]; } diff --git a/tests/Feature/Console/ControllerMakeCommandTest.php b/tests/Feature/Console/ControllerMakeCommandTest.php index 14e19944..5df68db6 100644 --- a/tests/Feature/Console/ControllerMakeCommandTest.php +++ b/tests/Feature/Console/ControllerMakeCommandTest.php @@ -10,6 +10,8 @@ class ControllerMakeCommandTest extends TestCase { protected $files = [ 'app/Http/Controllers/FooController.php', + 'app/Http/Requests/StoreFooRequest.php', + 'app/Http/Requests/UpdateFooRequest.php', 'tests/Feature/Http/Controllers/FooControllerTest.php', ]; @@ -227,4 +229,60 @@ public function it_can_generate_controller_file_with_tests() $this->assertFilenameExists('app/Http/Controllers/FooController.php'); $this->assertFilenameExists('tests/Feature/Http/Controllers/FooControllerTest.php'); } + + /** @test */ + public function it_can_generate_controller_with_model_and_requests() + { + $this->artisan('make:controller', ['name' => 'FooController', '--model' => 'Foo', '--requests' => true, '--preset' => 'canvas']) + ->expectsQuestion('A App\Models\Foo model does not exist. Do you want to generate it?', false) + ->assertSuccessful(); + + $this->assertFileContains([ + 'namespace App\Http\Controllers;', + 'use App\Models\Foo;', + 'use App\Http\Requests\StoreFooRequest;', + 'use App\Http\Requests\UpdateFooRequest;', + 'public function index()', + 'public function create()', + 'public function store(StoreFooRequest $request)', + 'public function show(Foo $foo)', + 'public function edit(Foo $foo)', + 'public function update(UpdateFooRequest $request, Foo $foo)', + 'public function destroy(Foo $foo)', + ], 'app/Http/Controllers/FooController.php'); + + $this->assertFilenameExists('app/Http/Controllers/FooController.php'); + $this->assertFilenameExists('app/Http/Requests/StoreFooRequest.php'); + $this->assertFilenameExists('app/Http/Requests/UpdateFooRequest.php'); + } + + /** @test */ + public function it_can_generate_controller_with_model_and_requests_with_custom_preset() + { + $this->instance('orchestra.canvas', new Laravel( + ['namespace' => 'Acme', 'model' => ['namespace' => 'Acme\Models']], $this->app->basePath() + )); + + $this->artisan('make:controller', ['name' => 'FooController', '--model' => 'Foo', '--requests' => true, '--preset' => 'canvas']) + ->expectsQuestion('A Acme\Models\Foo model does not exist. Do you want to generate it?', false) + ->assertSuccessful(); + + $this->assertFileContains([ + 'namespace Acme\Http\Controllers;', + 'use Acme\Models\Foo;', + 'use Acme\Http\Requests\StoreFooRequest;', + 'use Acme\Http\Requests\UpdateFooRequest;', + 'public function index()', + 'public function create()', + 'public function store(StoreFooRequest $request)', + 'public function show(Foo $foo)', + 'public function edit(Foo $foo)', + 'public function update(UpdateFooRequest $request, Foo $foo)', + 'public function destroy(Foo $foo)', + ], 'app/Http/Controllers/FooController.php'); + + $this->assertFilenameExists('app/Http/Controllers/FooController.php'); + $this->assertFilenameExists('app/Http/Requests/StoreFooRequest.php'); + $this->assertFilenameExists('app/Http/Requests/UpdateFooRequest.php'); + } }