mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-08 17:02:41 +00:00
Refactor language test boilerplate into trait
This commit is contained in:
parent
fcfc7863f1
commit
f78048317e
5 changed files with 47 additions and 80 deletions
|
@ -1,6 +1,8 @@
|
||||||
<?php
|
<?php
|
||||||
return [
|
return [
|
||||||
'Exception.JKingWeb/NewsSync/Exception.uncoded' => 'The specified exception symbol {0} has no code specified in Exception.php',
|
'Exception.JKingWeb/NewsSync/Exception.uncoded' => 'The specified exception symbol {0} has no code specified in Exception.php',
|
||||||
|
//this should not usually be encountered
|
||||||
|
'Exception.JKingWeb/NewsSync/Exception.unknown' => 'An unknown error has occurred',
|
||||||
|
|
||||||
'Exception.JKingWeb/NewsSync/Lang/Exception.defaultFileMissing' => 'Default language file "{0}" missing',
|
'Exception.JKingWeb/NewsSync/Lang/Exception.defaultFileMissing' => 'Default language file "{0}" missing',
|
||||||
'Exception.JKingWeb/NewsSync/Lang/Exception.fileMissing' => 'Language file "{0}" is not available',
|
'Exception.JKingWeb/NewsSync/Lang/Exception.fileMissing' => 'Language file "{0}" is not available',
|
||||||
|
|
|
@ -5,51 +5,13 @@ use \org\bovigo\vfs\vfsStream;
|
||||||
|
|
||||||
|
|
||||||
class TestLang extends \PHPUnit\Framework\TestCase {
|
class TestLang extends \PHPUnit\Framework\TestCase {
|
||||||
use TestingHelpers;
|
use TestingHelpers, LanguageTestingHelpers;
|
||||||
|
|
||||||
static $vfs;
|
static $vfs;
|
||||||
static $path;
|
static $path;
|
||||||
static $files;
|
static $files;
|
||||||
static $defaultPath;
|
static $defaultPath;
|
||||||
|
|
||||||
static function setUpBeforeClass() {
|
|
||||||
// this is required to keep from having exceptions in Lang::msg() in turn calling Lang::msg() and looping
|
|
||||||
Lang\Exception::$test = true;
|
|
||||||
// test files
|
|
||||||
self::$files = [
|
|
||||||
'en.php' => '<?php return ["Test.presentText" => "and the Philosopher\'s Stone"];',
|
|
||||||
'en_ca.php' => '<?php return ["Test.presentText" => "{0} and {1}"];',
|
|
||||||
'en_us.php' => '<?php return ["Test.presentText" => "and the Sorcerer\'s Stone"];',
|
|
||||||
'fr.php' => '<?php return ["Test.presentText" => "à l\'école des sorciers"];',
|
|
||||||
'ja.php' => '<?php return ["Test.absentText" => "賢者の石"];',
|
|
||||||
'de.php' => '<?php return ["Test.presentText" => "und der Stein der Weisen"];',
|
|
||||||
// corrupt files
|
|
||||||
'it.php' => '<?php return 0;',
|
|
||||||
'zh.php' => '<?php return 0',
|
|
||||||
'ko.php' => 'DEAD BEEF',
|
|
||||||
'fr_ca.php' => '',
|
|
||||||
// unreadable file
|
|
||||||
'ru.php' => '',
|
|
||||||
];
|
|
||||||
self::$vfs = vfsStream::setup("langtest", 0777, self::$files);
|
|
||||||
self::$path = self::$vfs->url();
|
|
||||||
// set up a file without read access
|
|
||||||
chmod(self::$path."/ru.php", 0000);
|
|
||||||
// make the Lang class use the vfs files
|
|
||||||
self::$defaultPath = Lang::$path;
|
|
||||||
Lang::$path = self::$path."/";
|
|
||||||
}
|
|
||||||
|
|
||||||
static function tearDownAfterClass() {
|
|
||||||
Lang\Exception::$test = false;
|
|
||||||
Lang::$path = self::$defaultPath;
|
|
||||||
self::$path = null;
|
|
||||||
self::$vfs = null;
|
|
||||||
self::$files = null;
|
|
||||||
Lang::set("", true);
|
|
||||||
Lang::set(Lang::DEFAULT, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
function testList() {
|
function testList() {
|
||||||
$this->assertCount(sizeof(self::$files), Lang::list("en"));
|
$this->assertCount(sizeof(self::$files), Lang::list("en"));
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,10 @@
|
||||||
<?php
|
<?php
|
||||||
declare(strict_types=1);
|
declare(strict_types=1);
|
||||||
namespace JKingWeb\NewsSync;
|
namespace JKingWeb\NewsSync;
|
||||||
|
|
||||||
require_once __DIR__.DIRECTORY_SEPARATOR."..".DIRECTORY_SEPARATOR."bootstrap.php";
|
require_once __DIR__.DIRECTORY_SEPARATOR."..".DIRECTORY_SEPARATOR."bootstrap.php";
|
||||||
|
|
||||||
|
use \org\bovigo\vfs\vfsStream;
|
||||||
|
|
||||||
trait TestingHelpers {
|
trait TestingHelpers {
|
||||||
function assertException(string $msg, string $prefix = "", string $type = "Exception") {
|
function assertException(string $msg, string $prefix = "", string $type = "Exception") {
|
||||||
$class = NS_BASE . ($prefix !== "" ? str_replace("/", "\\", $prefix) . "\\" : "") . $type;
|
$class = NS_BASE . ($prefix !== "" ? str_replace("/", "\\", $prefix) . "\\" : "") . $type;
|
||||||
|
@ -17,3 +18,43 @@ trait TestingHelpers {
|
||||||
$this->expectExceptionCode($code);
|
$this->expectExceptionCode($code);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
trait LanguageTestingHelpers {
|
||||||
|
static function setUpBeforeClass() {
|
||||||
|
// this is required to keep from having exceptions in Lang::msg() in turn calling Lang::msg() and looping
|
||||||
|
Lang\Exception::$test = true;
|
||||||
|
// test files
|
||||||
|
self::$files = [
|
||||||
|
'en.php' => '<?php return ["Test.presentText" => "and the Philosopher\'s Stone"];',
|
||||||
|
'en_ca.php' => '<?php return ["Test.presentText" => "{0} and {1}"];',
|
||||||
|
'en_us.php' => '<?php return ["Test.presentText" => "and the Sorcerer\'s Stone"];',
|
||||||
|
'fr.php' => '<?php return ["Test.presentText" => "à l\'école des sorciers"];',
|
||||||
|
'ja.php' => '<?php return ["Test.absentText" => "賢者の石"];',
|
||||||
|
'de.php' => '<?php return ["Test.presentText" => "und der Stein der Weisen"];',
|
||||||
|
// corrupt files
|
||||||
|
'it.php' => '<?php return 0;',
|
||||||
|
'zh.php' => '<?php return 0',
|
||||||
|
'ko.php' => 'DEAD BEEF',
|
||||||
|
'fr_ca.php' => '',
|
||||||
|
// unreadable file
|
||||||
|
'ru.php' => '',
|
||||||
|
];
|
||||||
|
self::$vfs = vfsStream::setup("langtest", 0777, self::$files);
|
||||||
|
self::$path = self::$vfs->url();
|
||||||
|
// set up a file without read access
|
||||||
|
chmod(self::$path."/ru.php", 0000);
|
||||||
|
// make the Lang class use the vfs files
|
||||||
|
self::$defaultPath = Lang::$path;
|
||||||
|
Lang::$path = self::$path."/";
|
||||||
|
}
|
||||||
|
|
||||||
|
static function tearDownAfterClass() {
|
||||||
|
Lang\Exception::$test = false;
|
||||||
|
Lang::$path = self::$defaultPath;
|
||||||
|
self::$path = null;
|
||||||
|
self::$vfs = null;
|
||||||
|
self::$files = null;
|
||||||
|
Lang::set("", true);
|
||||||
|
Lang::set(Lang::DEFAULT, true);
|
||||||
|
}
|
||||||
|
}
|
|
@ -5,51 +5,13 @@ use \org\bovigo\vfs\vfsStream;
|
||||||
|
|
||||||
|
|
||||||
class TestLangComplex extends \PHPUnit\Framework\TestCase {
|
class TestLangComplex extends \PHPUnit\Framework\TestCase {
|
||||||
use TestingHelpers;
|
use TestingHelpers, LanguageTestingHelpers;
|
||||||
|
|
||||||
static $vfs;
|
static $vfs;
|
||||||
static $path;
|
static $path;
|
||||||
static $files;
|
static $files;
|
||||||
static $defaultPath;
|
static $defaultPath;
|
||||||
|
|
||||||
static function setUpBeforeClass() {
|
|
||||||
// this is required to keep from having exceptions in Lang::msg() in turn calling Lang::msg() and looping
|
|
||||||
Lang\Exception::$test = true;
|
|
||||||
// test files
|
|
||||||
self::$files = [
|
|
||||||
'en.php' => '<?php return ["Test.presentText" => "and the Philosopher\'s Stone"];',
|
|
||||||
'en_ca.php' => '<?php return ["Test.presentText" => "{0} and {1}"];',
|
|
||||||
'en_us.php' => '<?php return ["Test.presentText" => "and the Sorcerer\'s Stone"];',
|
|
||||||
'fr.php' => '<?php return ["Test.presentText" => "à l\'école des sorciers"];',
|
|
||||||
'ja.php' => '<?php return ["Test.absentText" => "賢者の石"];',
|
|
||||||
'de.php' => '<?php return ["Test.presentText" => "und der Stein der Weisen"];',
|
|
||||||
// corrupt files
|
|
||||||
'it.php' => '<?php return 0;',
|
|
||||||
'zh.php' => '<?php return 0',
|
|
||||||
'ko.php' => 'DEAD BEEF',
|
|
||||||
'fr_ca.php' => '',
|
|
||||||
// unreadable file
|
|
||||||
'ru.php' => '',
|
|
||||||
];
|
|
||||||
self::$vfs = vfsStream::setup("langtest", 0777, self::$files);
|
|
||||||
self::$path = self::$vfs->url();
|
|
||||||
// set up a file without read access
|
|
||||||
chmod(self::$path."/ru.php", 0000);
|
|
||||||
// make the Lang class use the vfs files
|
|
||||||
self::$defaultPath = Lang::$path;
|
|
||||||
Lang::$path = self::$path."/";
|
|
||||||
}
|
|
||||||
|
|
||||||
static function tearDownAfterClass() {
|
|
||||||
Lang\Exception::$test = false;
|
|
||||||
Lang::$path = self::$defaultPath;
|
|
||||||
self::$path = null;
|
|
||||||
self::$vfs = null;
|
|
||||||
self::$files = null;
|
|
||||||
Lang::set("", true);
|
|
||||||
Lang::set(Lang::DEFAULT, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
function setUp() {
|
function setUp() {
|
||||||
Lang::set(Lang::DEFAULT, true);
|
Lang::set(Lang::DEFAULT, true);
|
||||||
}
|
}
|
||||||
|
|
2
vendor/JKingWeb/NewsSync/Exception.php
vendored
2
vendor/JKingWeb/NewsSync/Exception.php
vendored
|
@ -6,7 +6,7 @@ class Exception extends \Exception {
|
||||||
|
|
||||||
const CODES = [
|
const CODES = [
|
||||||
"Exception.uncoded" => -1,
|
"Exception.uncoded" => -1,
|
||||||
"Exception.misc" => 10000,
|
"Exception.unknown" => 10000,
|
||||||
"Lang/Exception.defaultFileMissing" => 10101,
|
"Lang/Exception.defaultFileMissing" => 10101,
|
||||||
"Lang/Exception.fileMissing" => 10102,
|
"Lang/Exception.fileMissing" => 10102,
|
||||||
"Lang/Exception.fileUnreadable" => 10103,
|
"Lang/Exception.fileUnreadable" => 10103,
|
||||||
|
|
Loading…
Reference in a new issue