mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Math
synced 2024-12-12 16:05:09 +00:00
6be5724740
Texutil related functionalities and tests will come in other changeset.
Related code:
fb56991251/lib/nodes/
Bug: T312528
Change-Id: Iead338a31403348603442b43ae802270f6b1d675
73 lines
2 KiB
PHP
73 lines
2 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\Math\Tests\TexVC\Nodes;
|
|
|
|
use ArgumentCountError;
|
|
use MediaWiki\Extension\Math\TexVC\Nodes\Literal;
|
|
use MediaWiki\Extension\Math\TexVC\Nodes\TexNode;
|
|
use MediaWikiUnitTestCase;
|
|
use TypeError;
|
|
|
|
/**
|
|
* @covers \MediaWiki\Extension\Math\TexVC\Nodes\Literal
|
|
*/
|
|
class LiteralTest extends MediaWikiUnitTestCase {
|
|
|
|
public function testBaseclass() {
|
|
$this->expectException( ArgumentCountError::class );
|
|
new Literal();
|
|
throw new ArgumentCountError( 'Should not create an empty literal' );
|
|
}
|
|
|
|
public function testOneArgument() {
|
|
$this->expectException( ArgumentCountError::class );
|
|
new Literal( 'a', 'b' );
|
|
throw new ArgumentCountError( 'Should not create a literal with more than one argument' );
|
|
}
|
|
|
|
public function testArgumentType() {
|
|
$this->expectException( TypeError::class );
|
|
new Literal( new Texnode() );
|
|
throw new TypeError( 'Should not create a literal with incorrect type' );
|
|
}
|
|
|
|
public function testOnlyOneArgument() {
|
|
$lit = new Literal( 'hello world' );
|
|
$this->assertEquals( 'hello world', $lit->render(),
|
|
'Should create an literal with only one argument' );
|
|
}
|
|
|
|
public function testRenderNodeBase() {
|
|
$lit = new Literal( 'hello world' );
|
|
$node = new TexNode( $lit );
|
|
$this->assertEquals( 'hello world', $node->render(),
|
|
'Should render within node base class' );
|
|
}
|
|
|
|
public function testNode() {
|
|
$lit = new Literal( 'hello world' );
|
|
$node = new TexNode( $lit );
|
|
$this->assertEquals( 'hello world', $node->render(),
|
|
'Should render within node base class' );
|
|
}
|
|
|
|
public function testExtractIdentifierModifications() {
|
|
$n = new Literal( 'a' );
|
|
$this->assertEquals( [ 'a' ], $n->getModIdent(),
|
|
'Should extract identifier modifications' );
|
|
}
|
|
|
|
public function testExtraSpace() {
|
|
$n = new Literal( '\\ ' );
|
|
$this->assertEquals( [ '\\ ' ], $n->getModIdent(),
|
|
'Identifier modifications should report extra space' );
|
|
}
|
|
|
|
public function testExtractSubscripts() {
|
|
$n = new Literal( '\\beta' );
|
|
$this->assertEquals( [ '\\beta' ], $n->extractSubscripts(),
|
|
'Should extract subscripts' );
|
|
}
|
|
|
|
}
|