Skip to content

Commit

Permalink
Merge pull request #8898 from kenjis/fix-command-discovery
Browse files Browse the repository at this point in the history
fix: precedence of command classes with the same `$name`
  • Loading branch information
kenjis authored Jun 24, 2024
2 parents 61d2742 + e6b5931 commit 9d02066
Show file tree
Hide file tree
Showing 3 changed files with 124 additions and 1 deletion.
2 changes: 1 addition & 1 deletion system/CLI/Commands.php
Original file line number Diff line number Diff line change
Expand Up @@ -125,7 +125,7 @@ public function discoverCommands()
/** @var BaseCommand $class */
$class = new $className($this->logger, $this);

if (isset($class->group)) {
if (isset($class->group) && ! isset($this->commands[$class->name])) {
$this->commands[$class->name] = [
'class' => $className,
'file' => $file,
Expand Down
59 changes: 59 additions & 0 deletions tests/_support/_command/ListCommands.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
<?php

declare(strict_types=1);

/**
* This file is part of CodeIgniter 4 framework.
*
* (c) CodeIgniter Foundation <[email protected]>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/

namespace App\Commands;

use CodeIgniter\CLI\CLI;
use CodeIgniter\Commands\ListCommands as BaseListCommands;

class ListCommands extends BaseListCommands
{
/**
* The group the command is lumped under
* when listing commands.
*
* @var string
*/
protected $group = 'App';

/**
* The Command's name
*
* @var string
*/
protected $name = 'list';

/**
* the Command's short description
*
* @var string
*/
protected $description = 'This is testing to override `list` command.';

/**
* the Command's usage
*
* @var string
*/
protected $usage = 'list';

/**
* Displays the help for the spark cli script itself.
*/
public function run(array $params)
{
CLI::write('This is ' . self::class);

return EXIT_SUCCESS;
}
}
64 changes: 64 additions & 0 deletions tests/system/Commands/CommandOverrideTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
<?php

declare(strict_types=1);

/**
* This file is part of CodeIgniter 4 framework.
*
* (c) CodeIgniter Foundation <[email protected]>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/

namespace CodeIgniter\Commands;

use CodeIgniter\Test\CIUnitTestCase;
use CodeIgniter\Test\StreamFilterTrait;
use PHPUnit\Framework\Attributes\Group;

/**
* @internal
*/
#[Group('Others')]
final class CommandOverrideTest extends CIUnitTestCase
{
use StreamFilterTrait;

protected function setUp(): void
{
$this->resetServices();

parent::setUp();
}

protected function getBuffer(): string
{
return $this->getStreamFilterBuffer();
}

public function testOverrideListCommands(): void
{
$this->copyListCommands();

command('list');

$this->assertStringContainsString('This is App\Commands\ListCommands', $this->getBuffer());
$this->assertStringNotContainsString('Displays basic usage information.', $this->getBuffer());

$this->deleteListCommands();
}

private function copyListCommands(): void
{
if (! is_dir(APPPATH . 'Commands')) {
mkdir(APPPATH . 'Commands');
}
copy(SUPPORTPATH . '_command/ListCommands.php', APPPATH . 'Commands/ListCommands.php');
}

private function deleteListCommands(): void
{
unlink(APPPATH . 'Commands/ListCommands.php');
}
}

0 comments on commit 9d02066

Please sign in to comment.