mediawiki-extensions-Math/tests/phpunit/unit/WikiTexVC/MMLmappings/BaseMappingsTest.php
physikerwelt 4014491c39
Fix: handling of nullary macros
In I94887f6ccb45072180a318776ae96aead8658a18 nullary macros
such as $\AA$ were missed.

Instead of adding a backslash (cf. patch set 1) we move the
functionality to texutil.

Bug: T380184
Change-Id: Ie9947b48f03dac03612a5c33bce92bf00df70aa3
2024-11-25 23:21:03 +01:00

99 lines
3.3 KiB
PHP

<?php
namespace MediaWiki\Extension\Math\Tests\WikiTexVC\MMLmappings;
use MediaWiki\Extension\Math\WikiTexVC\MMLmappings\BaseMappings;
use MediaWiki\Extension\Math\WikiTexVC\MMLmappings\BaseParsing;
use PHPUnit\Framework\TestCase;
/**
* @covers \MediaWiki\Extension\Math\WikiTexVC\MMLmappings\BaseMappings
*/
class BaseMappingsTest extends TestCase {
public function testGetAll() {
$all = BaseMappings::getAll();
$this->assertIsArray( $all );
$this->assertNotEmpty( $all );
}
public function provideTestCases(): array {
// the second argument is an array of known problems which should be removed in the future
return [
'macros' => [ 'macros', [ 'SetSize', 'Overunderset', 'Root', 'MoveRoot', 'LeftRight', 'MoveLeftRight',
'rule', 'Rule', 'Nonscript', 'BuildRel', 'FBox', 'FrameBox', 'Strut', 'Cr', 'HFill', 'BeginEnd',
'HandleLabel', 'HandleRef', 'HandleNoTag', 'MmlToken' ]
],
'cancel' => [ 'cancel' ],
'mhchem' => [ 'mhchem' ],
'custom' => [ 'custom', [ 'Insert' ] ],
'special' => [ 'special', [ 'open', 'close', 'superscript', 'subscript', 'space', 'prime', 'comment',
'entry', 'hash' ] ], // only tilde exists
];
}
/**
* @dataProvider provideTestCases
*/
public function testValidMethods( $setName, $knownProblems = [] ) {
foreach ( BaseMappings::getAll()[$setName] as $symbol => $payload ) {
$methodName = is_array( $payload ) ? $payload[0] : $payload;
if ( in_array( $methodName, $knownProblems ) ) {
continue;
}
$this->assertTrue( method_exists( BaseParsing::class, $methodName ),
'Method ' . $methodName . ' for symbol ' . $symbol . ' does not exist in BaseParsing' );
}
}
public function testGetCancelByKey() {
$this->assertEquals( 'updiagonalstrike', BaseMappings::getCancelByKey( '\\cancel' )[1] );
$this->assertEquals( 'cancelTo', BaseMappings::getCancelByKey( '\\cancelto' )[0] );
$this->assertNull( BaseMappings::getCancelByKey( '\\notCancel' ) );
}
public function testGetOperatorByKey() {
$this->assertEquals( '&#x221A;', BaseMappings::getOperatorByKey( '\\surd' )[0] );
$this->assertEquals( '&#x2212;', BaseMappings::getOperatorByKey( '-' ) );
}
public function testGetCustomByKey() {
$this->assertEquals( '\u222E', BaseMappings::getCustomByKey( '\\oint' )[1] );
}
public function testGetDelimiterByKey() {
$this->assertEquals( '(', BaseMappings::getDelimiterByKey( '(' )[0] );
}
public function testGetMacroByKey() {
$this->assertEquals( 'D', BaseMappings::getMacroByKey( '\\displaystyle' )[1] );
}
public function testGetSpecialByKey() {
$this->assertEquals( 'tilde', BaseMappings::getSpecialByKey( '~' )[1] );
$this->assertNull( BaseMappings::getSpecialByKey( '_' ) );
}
public function testGetColorByKey() {
$this->assertEquals( '#ED1B23', BaseMappings::getColorByKey( 'red' )[0] );
}
public function testGetInstance() {
$this->assertInstanceOf( BaseMappings::class, BaseMappings::getInstance() );
}
public function testGetCharacterByKey() {
$this->assertEquals( '\u0393', BaseMappings::getCharacterByKey( '\\Gamma' ) );
}
public function testGetMhChemByKey() {
$this->assertEquals( 'ce', BaseMappings::getMhChemByKey( '\\ce' )[1] );
}
public function testGetIdentifierByKey() {
$this->assertEquals( '&#x03B1;', BaseMappings::getIdentifierByKey( '\\alpha' )[0] );
}
}