Skip to content

Commit

Permalink
feat: add config:check command to check Config vaules
Browse files Browse the repository at this point in the history
  • Loading branch information
kenjis committed Oct 28, 2023
1 parent 76edbf4 commit 2543adc
Show file tree
Hide file tree
Showing 2 changed files with 186 additions and 0 deletions.
125 changes: 125 additions & 0 deletions system/Commands/Utilities/ConfigCheck.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,125 @@
<?php

/**
* 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\Utilities;

use CodeIgniter\CLI\BaseCommand;
use CodeIgniter\CLI\CLI;
use CodeIgniter\Config\BaseConfig;
use Kint\Kint;

/**
* Check the Config values.
*
* @see \CodeIgniter\Commands\Utilities\ConfigCheckTest
*/
final class ConfigCheck extends BaseCommand
{
/**
* The group the command is lumped under
* when listing commands.
*
* @var string
*/
protected $group = 'CodeIgniter';

/**
* The Command's name
*
* @var string
*/
protected $name = 'config:check';

/**
* The Command's short description
*
* @var string
*/
protected $description = 'Check your Config values.';

/**
* The Command's usage
*
* @var string
*/
protected $usage = 'config:check <classname>';

/**
* The Command's arguments
*
* @var array<string, string>
*/
protected $arguments = [

Check failure on line 60 in system/Commands/Utilities/ConfigCheck.php

View workflow job for this annotation

GitHub Actions / PHP Static Analysis

PHPDoc type array<string, string> of property CodeIgniter\Commands\Utilities\ConfigCheck::$arguments is not the same as PHPDoc type array of overridden property CodeIgniter\CLI\BaseCommand::$arguments.
'classname' => 'The config classname to check. Short classname or FQCN.',
];

/**
* The Command's options
*
* @var array
*/
protected $options = [];

/**
* {@inheritDoc}
*/
public function run(array $params)
{
if (! isset($params[0])) {
CLI::error('You must specify a Config classname.');
CLI::write(' Usage: ' . $this->usage);
CLI::write('Example: config:check App');
CLI::write(' config:check \'CodeIgniter\Shield\Config\Auth\'');

return EXIT_ERROR;
}

/** @var class-string<BaseConfig> $class */
$class = $params[0];

$config = config($class);

if ($config === null) {
CLI::error('No such Config class: ' . $class);

return EXIT_ERROR;
}

if (defined('KINT_DIR') && Kint::$enabled_mode !== false) {
ob_start();
d($config);
$output = ob_get_clean();

$output = trim($output);
$output = preg_replace('/\x1b\[36m.*┘\x1b\[0m/su', '', $output);
$output = preg_replace('/\x1b\[36m.*Called from .*\x1b\[0m/su', '', $output);
$output = trim($output);

CLI::write($output);
} else {
ob_start();
var_dump($config);
$output = ob_get_clean();

$output = preg_replace(
'!.*system/Commands/Utilities/Config.php.*\n!u',
'',
$output
);

CLI::write(
CLI::color($output, 'cyan')
);
}

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

/**
* 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\Utilities;

use CodeIgniter\Test\CIUnitTestCase;
use CodeIgniter\Test\StreamFilterTrait;
use Config\App;

/**
* @internal
*
* @group Others
*/
final class ConfigCheckTest extends CIUnitTestCase
{
use StreamFilterTrait;

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

protected function tearDown(): void
{
$this->resetServices();
parent::tearDown();
}

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

public function testConfigApp(): void
{
command('config:check App');

$this->assertStringContainsString(App::class, $this->getBuffer());
$this->assertStringContainsString("public 'baseURL", $this->getBuffer());
}

public function testConfigNonexistentClass(): void
{
command('config:check NotExist');

$this->assertStringContainsString(
'No such Config class: NotExist',
$this->getBuffer()
);
}
}

0 comments on commit 2543adc

Please sign in to comment.