From 2c6a7b0cfbb9f1aeee65b52904bc7466f0507f48 Mon Sep 17 00:00:00 2001 From: Sebastien HEYD Date: Tue, 1 Sep 2020 11:36:26 +0200 Subject: [PATCH] Fix vendor-name package-name not converted to studly case --- changelog.md | 3 +++ src/Commands/NewPackage.php | 4 ++-- src/Conveyor.php | 20 ++++++++++++++++++++ src/FileHandler.php | 2 +- tests/IntegratedTest.php | 9 +++++++++ 5 files changed, 35 insertions(+), 3 deletions(-) diff --git a/changelog.md b/changelog.md index 3a760b8..ac95cc1 100644 --- a/changelog.md +++ b/changelog.md @@ -11,6 +11,9 @@ All Notable changes to Packager will be documented in this file. - Support for Laravel 7 and PHPUnit 9. - `packager:new` now also supports separating vendor and name with a forward slash. +### Fixed +- vendor-name and package-name not converted to StudlyCase with `packager:new` + ## Version 2.4 ### Added diff --git a/src/Commands/NewPackage.php b/src/Commands/NewPackage.php index 187b080..d3ecd22 100644 --- a/src/Commands/NewPackage.php +++ b/src/Commands/NewPackage.php @@ -114,8 +114,8 @@ public function handle() ':lc:vendor', ':lc:package', ], [ - $this->conveyor->vendor(), - $this->conveyor->package(), + $this->conveyor->vendorStudly(), + $this->conveyor->packageStudly(), strtolower($this->conveyor->vendor()), strtolower($this->conveyor->package()), ]); diff --git a/src/Conveyor.php b/src/Conveyor.php index 5cf9638..36dada8 100644 --- a/src/Conveyor.php +++ b/src/Conveyor.php @@ -42,6 +42,16 @@ public function vendor($vendor = null) return $this->vendor; } + /** + * Get the vendor name converted to StudlyCase. + * + * @return string|RuntimeException + */ + public function vendorStudly() + { + return Str::studly($this->vendor()); + } + /** * Set or get the package name. * @@ -61,6 +71,16 @@ public function package($package = null) return $this->package; } + /** + * Get the package name converted to StudlyCase. + * + * @return string|RuntimeException + */ + public function packageStudly() + { + return Str::studly($this->package()); + } + /** * Download the skeleton package. */ diff --git a/src/FileHandler.php b/src/FileHandler.php index ecd37f4..e2d2b03 100644 --- a/src/FileHandler.php +++ b/src/FileHandler.php @@ -169,7 +169,7 @@ public function renameFiles($manifest = null) { $bindings = [ [':uc:vendor', ':uc:package', ':lc:vendor', ':lc:package'], - [$this->vendor(), $this->package(), strtolower($this->vendor()), strtolower($this->package())], + [$this->vendorStudly(), $this->packageStudly(), strtolower($this->vendor()), strtolower($this->package())], ]; $rewrites = require ($manifest === null) ? [ diff --git a/tests/IntegratedTest.php b/tests/IntegratedTest.php index 0459a14..b6b8c82 100644 --- a/tests/IntegratedTest.php +++ b/tests/IntegratedTest.php @@ -22,6 +22,15 @@ public function test_new_package_is_installed() $this->assertStringContainsString('MyVendor/MyPackage', $composer); } + public function test_new_package_studly_install() + { + Artisan::call('packager:new', ['vendor' => 'my-vendor', 'name' => 'my-package']); + + $this->seeInConsoleOutput('Package created successfully!'); + $this->assertStringContainsString('my-vendor/my-package', file_get_contents(base_path('composer.json'))); + $this->assertTrue(is_file(base_path('packages/my-vendor/my-package/src/MyPackageServiceProvider.php'))); + } + public function test_new_package_is_installed_from_custom_skeleton() { Artisan::call('packager:new', [