mediawiki-extensions-Scribunto/tests/phpunit/engines/LuaCommon/UstringLibraryTest.php
Reedy 073a365759 "Namespace LuaCommon" take 2
Revert "Revert "Namespace LuaCommon""

This reverts commit 18d122b60d.

Change-Id: I74fd43f7920c8772e9078f745ac6062d5461a7f1
2022-09-30 00:52:27 +00:00

109 lines
3.1 KiB
PHP

<?php
use MediaWiki\Extension\Scribunto\Engines\LuaCommon\LuaError;
use Wikimedia\ScopedCallback;
/**
* @covers \MediaWiki\Extension\Scribunto\Engines\LuaCommon\UstringLibrary
*/
class UstringLibraryTest extends LuaEngineUnitTestBase {
/** @inheritDoc */
protected static $moduleName = 'UstringLibraryTests';
/** @var UstringLibraryNormalizationTestProvider|null */
private $normalizationDataProvider = null;
protected function tearDown(): void {
if ( $this->normalizationDataProvider ) {
$this->normalizationDataProvider->destroy();
$this->normalizationDataProvider = null;
}
parent::tearDown();
}
protected function getTestModules() {
return parent::getTestModules() + [
'UstringLibraryTests' => __DIR__ . '/UstringLibraryTests.lua',
'UstringLibraryNormalizationTests' => __DIR__ . '/UstringLibraryNormalizationTests.lua',
];
}
public function testUstringLibraryNormalizationTestsAvailable() {
if ( UstringLibraryNormalizationTestProvider::available( $err ) ) {
$this->assertTrue( true );
} else {
$this->markTestSkipped( $err );
}
}
public function provideUstringLibraryNormalizationTests() {
if ( !$this->normalizationDataProvider ) {
$this->normalizationDataProvider =
new UstringLibraryNormalizationTestProvider( $this->getEngine() );
}
return $this->normalizationDataProvider;
}
/**
* @dataProvider provideUstringLibraryNormalizationTests
*/
public function testUstringLibraryNormalizationTests( $name, $c1, $c2, $c3, $c4, $c5 ) {
$this->luaTestName = "UstringLibraryNormalization: $name";
$dataProvider = $this->provideUstringLibraryNormalizationTests();
$expected = [
// NFC
$c2, $c2, $c2, $c4, $c4,
// NFD
$c3, $c3, $c3, $c5, $c5,
// NFKC
$c4, $c4, $c4, $c4, $c4,
// NFKD
$c5, $c5, $c5, $c5, $c5,
];
foreach ( $expected as &$e ) {
$chars = array_values( unpack( 'N*', mb_convert_encoding( $e, 'UTF-32BE', 'UTF-8' ) ) );
foreach ( $chars as &$c ) {
$c = sprintf( "%x", $c );
}
$e = "$e\t" . implode( "\t", $chars );
}
$actual = $dataProvider->runNorm( $c1, $c2, $c3, $c4, $c5 );
$this->assertSame( $expected, $actual );
$this->luaTestName = null;
}
/**
* @dataProvider providePCREErrors
*/
public function testPCREErrors( $ini, $args, $error ) {
$reset = [];
foreach ( $ini as $key => $value ) {
$old = ini_set( $key, $value );
if ( $old === false ) {
$this->markTestSkipped( "Failed to set ini setting $key = $value" );
}
$reset[] = new ScopedCallback( 'ini_set', [ $key, $old ] );
}
$interpreter = $this->getEngine()->getInterpreter();
$func = $interpreter->loadString( 'return mw.ustring.gsub( ... )', 'fortest' );
try {
$interpreter->callFunction( $func, ...$args );
$this->fail( 'Expected exception not thrown' );
} catch ( LuaError $e ) {
$this->assertSame( $error, $e->getMessage() );
}
}
public static function providePCREErrors() {
return [
[
[ 'pcre.backtrack_limit' => 10 ],
[ 'zzzzzzzzzzzzzzzzzzzz', '^(.-)[abc]*$', '%1' ],
'Lua error: PCRE backtrack limit reached while matching pattern \'^(.-)[abc]*$\'.'
],
// @TODO: Figure out patterns that hit other PCRE limits
];
}
}