mirror of
https://github.com/yiisoft/yii2.git
synced 2025-08-14 22:30:27 +08:00
182 lines
6.6 KiB
PHP
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);
|
|
}
|
|
}
|
|
}
|