mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2026-02-06 19:41:13 -05:00
* Complete PHPStan Level 6 Fix https://github.com/FreshRSS/FreshRSS/issues/4112 And initiate PHPStan Level 7 * PHPStan Level 6 for tests * Use phpstan/phpstan-phpunit * Update to PHPStan version 1.10 * Fix mixed bug * Fix mixed return bug * Fix paginator bug * Fix FreshRSS_UserConfiguration * A couple more Minz_Configuration bug fixes * A few trivial PHPStan Level 7 fixes * A few more simple PHPStan Level 7 * More files passing PHPStan Level 7 Add interface to replace removed class from https://github.com/FreshRSS/FreshRSS/pull/5251 * A few more PHPStan Level 7 preparations * A few last details
124 lines
3.6 KiB
PHP
124 lines
3.6 KiB
PHP
<?php
|
|
|
|
require_once __DIR__ . '/../../../cli/i18n/I18nValue.php';
|
|
require_once __DIR__ . '/../../../cli/i18n/I18nUsageValidator.php';
|
|
|
|
class I18nUsageValidatorTest extends PHPUnit\Framework\TestCase {
|
|
/** @var I18nValue */
|
|
private $value;
|
|
|
|
public function setUp(): void {
|
|
$this->value = $this->getMockBuilder(I18nValue::class)
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
}
|
|
|
|
public function testDisplayReport(): void {
|
|
$validator = new I18nUsageValidator([], []);
|
|
|
|
$this->assertEquals("There is no data.\n", $validator->displayReport());
|
|
|
|
$reflectionTotalEntries = new ReflectionProperty(I18nUsageValidator::class, 'totalEntries');
|
|
$reflectionTotalEntries->setAccessible(true);
|
|
$reflectionTotalEntries->setValue($validator, 100);
|
|
|
|
$this->assertEquals(" 0.0% of translation keys are unused.\n", $validator->displayReport());
|
|
|
|
$reflectionFailedEntries = new ReflectionProperty(I18nUsageValidator::class, 'failedEntries');
|
|
$reflectionFailedEntries->setAccessible(true);
|
|
$reflectionFailedEntries->setValue($validator, 25);
|
|
|
|
$this->assertEquals(" 25.0% of translation keys are unused.\n", $validator->displayReport());
|
|
|
|
$reflectionFailedEntries->setValue($validator, 100);
|
|
|
|
$this->assertEquals("100.0% of translation keys are unused.\n", $validator->displayReport());
|
|
|
|
$reflectionFailedEntries->setValue($validator, 200);
|
|
|
|
$this->expectException(\RuntimeException::class);
|
|
$this->expectExceptionMessage('The number of unused strings cannot be higher than the number of strings');
|
|
$validator->displayReport();
|
|
}
|
|
|
|
public function testValidateWhenNoData(): void {
|
|
$validator = new I18nUsageValidator([], []);
|
|
$this->assertTrue($validator->validate());
|
|
$this->assertEquals('', $validator->displayResult());
|
|
}
|
|
|
|
public function testValidateWhenParentKeyExistsWithoutTransformation(): void {
|
|
$validator = new I18nUsageValidator([
|
|
'file1' => [
|
|
'file1.l1.l2._' => $this->value,
|
|
],
|
|
'file2' => [
|
|
'file2.l1.l2._' => $this->value,
|
|
],
|
|
], [
|
|
'file1.l1.l2._',
|
|
'file2.l1.l2._',
|
|
]);
|
|
$this->assertTrue($validator->validate());
|
|
$this->assertEquals('', $validator->displayResult());
|
|
}
|
|
|
|
public function testValidateWhenParentKeyExistsWithTransformation(): void {
|
|
$validator = new I18nUsageValidator([
|
|
'file1' => [
|
|
'file1.l1.l2._' => $this->value,
|
|
],
|
|
'file2' => [
|
|
'file2.l1.l2._' => $this->value,
|
|
],
|
|
], [
|
|
'file1.l1.l2',
|
|
'file2.l1.l2',
|
|
]);
|
|
$this->assertTrue($validator->validate());
|
|
$this->assertEquals('', $validator->displayResult());
|
|
}
|
|
|
|
public function testValidateWhenParentKeyDoesNotExist(): void {
|
|
$validator = new I18nUsageValidator([
|
|
'file1' => [
|
|
'file1.l1.l2._' => $this->value,
|
|
],
|
|
'file2' => [
|
|
'file2.l1.l2._' => $this->value,
|
|
],
|
|
], []);
|
|
$this->assertFalse($validator->validate());
|
|
$this->assertEquals("Unused key file1.l1.l2._ - \nUnused key file2.l1.l2._ - \n", $validator->displayResult());
|
|
}
|
|
|
|
public function testValidateWhenChildKeyExists(): void {
|
|
$validator = new I18nUsageValidator([
|
|
'file1' => [
|
|
'file1.l1.l2.k1' => $this->value,
|
|
],
|
|
'file2' => [
|
|
'file2.l1.l2.k1' => $this->value,
|
|
],
|
|
], [
|
|
'file1.l1.l2.k1',
|
|
'file2.l1.l2.k1',
|
|
]);
|
|
$this->assertTrue($validator->validate());
|
|
$this->assertEquals('', $validator->displayResult());
|
|
}
|
|
|
|
public function testValidateWhenChildKeyDoesNotExist(): void {
|
|
$validator = new I18nUsageValidator([
|
|
'file1' => [
|
|
'file1.l1.l2.k1' => $this->value,
|
|
],
|
|
'file2' => [
|
|
'file2.l1.l2.k1' => $this->value,
|
|
],
|
|
], []);
|
|
$this->assertFalse($validator->validate());
|
|
$this->assertEquals("Unused key file1.l1.l2.k1 - \nUnused key file2.l1.l2.k1 - \n", $validator->displayResult());
|
|
}
|
|
}
|