Files
yii2/tests/framework/console/controllers/PHPMessageControllerTest.php
2025-04-26 19:03:07 -04:00

182 lines
6.6 KiB
PHP

<?php
/**
* @link https://www.yiiframework.com/
* @copyright Copyright (c) 2008 Yii Software LLC
* @license https://www.yiiframework.com/license/
*/
namespace yiiunit\framework\console\controllers;
use Yii;
use yii\helpers\FileHelper;
use yii\helpers\VarDumper;
/**
* Tests that [[\yii\console\controllers\MessageController]] works as expected with PHP message format.
*/
class PHPMessageControllerTest extends BaseMessageControllerTest
{
protected $messagePath;
protected function setUp(): void
{
parent::setUp();
$this->messagePath = Yii::getAlias('@yiiunit/runtime/test_messages');
FileHelper::createDirectory($this->messagePath, 0777);
}
protected function tearDown(): void
{
parent::tearDown();
FileHelper::removeDirectory($this->messagePath);
}
/**
* {@inheritdoc}
*/
protected function getDefaultConfig()
{
return [
'format' => 'php',
'languages' => [$this->language],
'sourcePath' => $this->sourcePath,
'messagePath' => $this->messagePath,
'overwrite' => true,
'phpFileHeader' => "/*file header*/\n",
'phpDocBlock' => '/*doc block*/',
];
}
/**
* @param string $category
* @return string message file path
*/
protected function getMessageFilePath($category)
{
return $this->messagePath . '/' . $this->language . '/' . $category . '.php';
}
/**
* {@inheritdoc}
*/
protected function saveMessages($messages, $category)
{
$fileName = $this->getMessageFilePath($category);
if (file_exists($fileName)) {
unlink($fileName);
} else {
$dirName = dirname($fileName);
if (!file_exists($dirName)) {
mkdir($dirName, 0777, true);
}
}
$fileContent = '<?php return ' . VarDumper::export($messages) . ';';
file_put_contents($fileName, $fileContent);
}
/**
* {@inheritdoc}
*/
protected function loadMessages($category)
{
$messageFilePath = $this->getMessageFilePath($category);
if (!file_exists($messageFilePath)) {
return [];
}
if (defined('HHVM_VERSION')) {
// use eval() to bypass HHVM content cache
// https://github.com/facebook/hhvm/issues/1447
$content = file_get_contents($messageFilePath);
return eval(substr($content, strpos($content, 'return ')));
}
return require $messageFilePath;
}
// By default phpunit runs inherited test after inline tests, so `testCreateTranslation()` would be run after
// `testCustomFileHeaderAndDocBlock()` (that would break `@depends` annotation). This ensures that
// `testCreateTranslation() will be run before `testCustomFileHeaderAndDocBlock()`.
public function testCreateTranslation(): void
{
parent::testCreateTranslation();
}
/**
* @depends testCreateTranslation
*/
public function testCustomFileHeaderAndDocBlock(): void
{
$category = 'test_headers_category';
$message = 'test message';
$sourceFileContent = "Yii::t('{$category}', '{$message}');";
$this->createSourceFile($sourceFileContent);
$this->saveConfigFile($this->getConfig());
$this->runMessageControllerAction('extract', [$this->configFileName]);
$messageFilePath = $this->getMessageFilePath('test_headers_category');
$content = file_get_contents($messageFilePath);
$head = substr($content, 0, strpos($content, 'return '));
$expected = "<?php\n/*file header*/\n/*doc block*/\n";
$this->assertEqualsWithoutLE($expected, $head);
}
public static function messageFileCategoriesDataProvider(): array
{
return [
'removeUnused:false - unused category should not be removed - normal category' => ['test_delete_category', true, false, true],
'removeUnused:false - unused category should not be removed - nested category' => ['nested/category', true, false, true],
'removeUnused:false - unused category should not be removed - nested 3 level category' => ['multi-level/nested/category', true, false, true],
'removeUnused:false - used category should not be removed - normal category' => ['test_delete_category', false, false, true],
'removeUnused:false - used category should not be removed - nested category' => ['nested/category', false, false, true],
'removeUnused:false - used category should not be removed - nested 3 level category' => ['multi-level/nested/category', false, false, true],
'removeUnused:true - used category should not be removed - normal category' => ['test_delete_category', false, true, true],
'removeUnused:true - used category should not be removed - nested category' => ['nested/category', false, true, true],
'removeUnused:true - used category should not be removed - nested 3 level category' => ['multi-level/nested/category', false, true, true],
'removeUnused:true - unused category should be removed - normal category' => ['test_delete_category', true, true, false],
'removeUnused:true - unused category should be removed - nested category' => ['nested/category', true, true, false],
'removeUnused:true - unused category should be removed - nested 3 level category' => ['multi-level/nested/category', true, true, false],
];
}
/**
* @dataProvider messageFileCategoriesDataProvider
*
* @param string $category The category name.
* @param bool $isUnused Whether the category is unused.
* @param bool $removeUnused Whether to remove unused categories.
* @param bool $isExpectedToExist Whether the category is expected to exist.
*/
public function testRemoveUnusedBehavior(
string $category,
bool $isUnused,
bool $removeUnused,
bool $isExpectedToExist
): void {
$this->saveMessages(['test message' => 'test translation'], $category);
$filePath = $this->getMessageFilePath($category);
$this->saveConfigFile($this->getConfig([
'removeUnused' => $removeUnused,
]));
if (!$isUnused) {
$message = 'test message';
$sourceFileContent = "Yii::t('{$category}', '{$message}');";
$this->createSourceFile($sourceFileContent);
}
$this->runMessageControllerAction('extract', [$this->configFileName]);
if ($isExpectedToExist) {
$this->assertFileExists($filePath);
} else {
$this->assertFileDoesNotExist($filePath);
}
}
}