mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2026-03-02 13:36:15 -05:00
* PHPStan 2.0 fix https://github.com/FreshRSS/FreshRSS/issues/6989 https://github.com/phpstan/phpstan/releases/tag/2.0.0 https://github.com/phpstan/phpstan/blob/2.0.x/UPGRADING.md * More * More * Done * fix i18n CLI * Restore a PHPStan Next test For work towards PHPStan Level 10 * 4 more on Level 10 * fix getTagsForEntry * API at Level 10 * More Level 10 * Finish Minz at Level 10 * Finish CLI at Level 10 * Finish Controllers at Level 10 * More Level 10 * More * Pass bleedingEdge * Clean PHPStan options and add TODOs * Level 10 for main config * More * Consitency array vs. list * Sanitize themes get_infos * Simplify TagDAO->getTagsForEntries() * Finish reportAnyTypeWideningInVarTag * Prepare checkBenevolentUnionTypes and checkImplicitMixed * Fixes * Refix * Another fix * Casing of __METHOD__ constant
125 lines
3.6 KiB
PHP
125 lines
3.6 KiB
PHP
<?php
|
|
declare(strict_types=1);
|
|
require_once __DIR__ . '/../../../cli/i18n/I18nValue.php';
|
|
require_once __DIR__ . '/../../../cli/i18n/I18nUsageValidator.php';
|
|
|
|
class I18nUsageValidatorTest extends PHPUnit\Framework\TestCase {
|
|
|
|
private I18nValue $value;
|
|
|
|
#[\Override]
|
|
public function setUp(): void {
|
|
$this->value = $this->getMockBuilder(I18nValue::class)
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
}
|
|
|
|
public function testDisplayReport(): void {
|
|
$validator = new I18nUsageValidator([], []);
|
|
|
|
self::assertSame("There is no data.\n", $validator->displayReport());
|
|
|
|
$reflectionTotalEntries = new ReflectionProperty(I18nUsageValidator::class, 'totalEntries');
|
|
$reflectionTotalEntries->setAccessible(true);
|
|
$reflectionTotalEntries->setValue($validator, 100);
|
|
|
|
self::assertSame(" 0.0% of translation keys are unused.\n", $validator->displayReport());
|
|
|
|
$reflectionFailedEntries = new ReflectionProperty(I18nUsageValidator::class, 'failedEntries');
|
|
$reflectionFailedEntries->setAccessible(true);
|
|
$reflectionFailedEntries->setValue($validator, 25);
|
|
|
|
self::assertSame(" 25.0% of translation keys are unused.\n", $validator->displayReport());
|
|
|
|
$reflectionFailedEntries->setValue($validator, 100);
|
|
|
|
self::assertSame("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 static function testValidateWhenNoData(): void {
|
|
$validator = new I18nUsageValidator([], []);
|
|
self::assertTrue($validator->validate());
|
|
self::assertSame('', $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._',
|
|
]);
|
|
self::assertTrue($validator->validate());
|
|
self::assertSame('', $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',
|
|
]);
|
|
self::assertTrue($validator->validate());
|
|
self::assertSame('', $validator->displayResult());
|
|
}
|
|
|
|
public function testValidateWhenParentKeyDoesNotExist(): void {
|
|
$validator = new I18nUsageValidator([
|
|
'file1' => [
|
|
'file1.l1.l2._' => $this->value,
|
|
],
|
|
'file2' => [
|
|
'file2.l1.l2._' => $this->value,
|
|
],
|
|
], []);
|
|
self::assertFalse($validator->validate());
|
|
self::assertSame("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',
|
|
]);
|
|
self::assertTrue($validator->validate());
|
|
self::assertSame('', $validator->displayResult());
|
|
}
|
|
|
|
public function testValidateWhenChildKeyDoesNotExist(): void {
|
|
$validator = new I18nUsageValidator([
|
|
'file1' => [
|
|
'file1.l1.l2.k1' => $this->value,
|
|
],
|
|
'file2' => [
|
|
'file2.l1.l2.k1' => $this->value,
|
|
],
|
|
], []);
|
|
self::assertFalse($validator->validate());
|
|
self::assertSame("Unused key file1.l1.l2.k1 - \nUnused key file2.l1.l2.k1 - \n", $validator->displayResult());
|
|
}
|
|
}
|