wiki.techinc.nl/tests/phpunit/includes/MessageTest.php
aude 3df8366e9a Allow to optionally set language in Message constructor
This helps with testability to not have to rely on $wgLang
and setting globals in tests.

This also provides convenience, so one does not necessarily
need to call Message::inLanguage() if language is known
at time of constructing the message object.

Also added tests to cover this change.

Change-Id: I14ee98972c7be954e04398ece9e6103f96ab60dd
2014-03-28 17:59:48 +01:00

255 lines
8.2 KiB
PHP

<?php
class MessageTest extends MediaWikiLangTestCase {
protected function setUp() {
parent::setUp();
$this->setMwGlobals( array(
'wgLang' => Language::factory( 'en' ),
'wgForceUIMsgAsContentMsg' => array(),
) );
}
/**
* @covers Message::__construct
* @dataProvider provideConstructor
*/
public function testConstructor( $expectedLang, $key, $params, $language ) {
$reflection = new ReflectionClass( 'Message' );
$keyProperty = $reflection->getProperty( 'key' );
$keyProperty->setAccessible( true );
$paramsProperty = $reflection->getProperty( 'parameters' );
$paramsProperty->setAccessible( true );
$langProperty = $reflection->getProperty( 'language' );
$langProperty->setAccessible( true );
$message = new Message( $key, $params, $language );
$this->assertEquals( $key, $keyProperty->getValue( $message ) );
$this->assertEquals( $params, $paramsProperty->getValue( $message ) );
$this->assertEquals( $expectedLang, $langProperty->getValue( $message ) );
}
public function provideConstructor() {
$langDe = Language::factory( 'de' );
$langEn = Language::factory( 'en' );
return array(
array( $langDe, 'foo', array(), $langDe ),
array( $langDe, 'foo', array( 'bar' ), $langDe ),
array( $langEn, 'foo', array( 'bar' ), null )
);
}
public function provideTestParams() {
return array(
array( array() ),
array( array( 'foo' ), 'foo' ),
array( array( 'foo', 'bar' ), 'foo', 'bar' ),
array( array( 'baz' ), array( 'baz' ) ),
array( array( 'baz', 'foo' ), array( 'baz', 'foo' ) ),
array( array( 'baz', 'foo' ), array( 'baz', 'foo' ), 'hhh' ),
array( array( 'baz', 'foo' ), array( 'baz', 'foo' ), 'hhh', array( 'ahahahahha' ) ),
array( array( 'baz', 'foo' ), array( 'baz', 'foo' ), array( 'ahahahahha' ) ),
array( array( 'baz' ), array( 'baz' ), array( 'ahahahahha' ) ),
);
}
/**
* @covers Message::params
* @dataProvider provideTestParams
*/
public function testParams( $expected ) {
$msg = new Message( 'imasomething' );
$returned = call_user_func_array( array( $msg, 'params' ), array_slice( func_get_args(), 1 ) );
$this->assertSame( $msg, $returned );
$this->assertEquals( $expected, $msg->getParams() );
}
/**
* @covers Message::exists
*/
public function testExists() {
$this->assertTrue( wfMessage( 'mainpage' )->exists() );
$this->assertTrue( wfMessage( 'mainpage' )->params( array() )->exists() );
$this->assertTrue( wfMessage( 'mainpage' )->rawParams( 'foo', 123 )->exists() );
$this->assertFalse( wfMessage( 'i-dont-exist-evar' )->exists() );
$this->assertFalse( wfMessage( 'i-dont-exist-evar' )->params( array() )->exists() );
$this->assertFalse( wfMessage( 'i-dont-exist-evar' )->rawParams( 'foo', 123 )->exists() );
}
/**
* @covers Message::__construct
*/
public function testKey() {
$this->assertInstanceOf( 'Message', wfMessage( 'mainpage' ) );
$this->assertInstanceOf( 'Message', wfMessage( 'i-dont-exist-evar' ) );
$this->assertEquals( 'Main Page', wfMessage( 'mainpage' )->text() );
$this->assertEquals( '&lt;i-dont-exist-evar&gt;', wfMessage( 'i-dont-exist-evar' )->text() );
$this->assertEquals( '<i-dont-exist-evar>', wfMessage( 'i-dont-exist-evar' )->plain() );
$this->assertEquals( '&lt;i-dont-exist-evar&gt;', wfMessage( 'i-dont-exist-evar' )->escaped() );
}
/**
* @covers Message::inLanguage
*/
public function testInLanguage() {
$this->assertEquals( 'Main Page', wfMessage( 'mainpage' )->inLanguage( 'en' )->text() );
$this->assertEquals( 'Заглавная страница', wfMessage( 'mainpage' )->inLanguage( 'ru' )->text() );
$this->assertEquals( 'Main Page', wfMessage( 'mainpage' )->inLanguage( Language::factory( 'en' ) )->text() );
$this->assertEquals( 'Заглавная страница', wfMessage( 'mainpage' )->inLanguage( Language::factory( 'ru' ) )->text() );
}
/**
* @covers Message::__construct
*/
public function testMessageParams() {
$this->assertEquals( 'Return to $1.', wfMessage( 'returnto' )->text() );
$this->assertEquals( 'Return to $1.', wfMessage( 'returnto', array() )->text() );
$this->assertEquals( 'You have foo (bar).', wfMessage( 'youhavenewmessages', 'foo', 'bar' )->text() );
$this->assertEquals( 'You have foo (bar).', wfMessage( 'youhavenewmessages', array( 'foo', 'bar' ) )->text() );
}
/**
* @covers Message::__construct
* @covers Message::rawParams
*/
public function testMessageParamSubstitution() {
$this->assertEquals( '(Заглавная страница)', wfMessage( 'parentheses', 'Заглавная страница' )->plain() );
$this->assertEquals( '(Заглавная страница $1)', wfMessage( 'parentheses', 'Заглавная страница $1' )->plain() );
$this->assertEquals( '(Заглавная страница)', wfMessage( 'parentheses' )->rawParams( 'Заглавная страница' )->plain() );
$this->assertEquals( '(Заглавная страница $1)', wfMessage( 'parentheses' )->rawParams( 'Заглавная страница $1' )->plain() );
}
/**
* @covers Message::__construct
* @covers Message::params
*/
public function testDeliciouslyManyParams() {
$msg = new RawMessage( '$1$2$3$4$5$6$7$8$9$10$11$12' );
// One less than above has placeholders
$params = array( 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k' );
$this->assertEquals( 'abcdefghijka2', $msg->params( $params )->plain(), 'Params > 9 are replaced correctly' );
}
/**
* @covers Message::numParams
*/
public function testMessageNumParams() {
$lang = Language::factory( 'en' );
$msg = new RawMessage( '$1' );
$this->assertEquals(
$lang->formatNum( 123456.789 ),
$msg->inLanguage( $lang )->numParams( 123456.789 )->plain(),
'numParams is handled correctly'
);
}
/**
* @covers Message::durationParams
*/
public function testMessageDurationParams() {
$lang = Language::factory( 'en' );
$msg = new RawMessage( '$1' );
$this->assertEquals(
$lang->formatDuration( 1234 ),
$msg->inLanguage( $lang )->durationParams( 1234 )->plain(),
'durationParams is handled correctly'
);
}
/**
* FIXME: This should not need database, but Language#formatExpiry does (bug 55912)
* @group Database
* @covers Message::expiryParams
*/
public function testMessageExpiryParams() {
$lang = Language::factory( 'en' );
$msg = new RawMessage( '$1' );
$this->assertEquals(
$lang->formatExpiry( wfTimestampNow() ),
$msg->inLanguage( $lang )->expiryParams( wfTimestampNow() )->plain(),
'expiryParams is handled correctly'
);
}
/**
* @covers Message::timeperiodParams
*/
public function testMessageTimeperiodParams() {
$lang = Language::factory( 'en' );
$msg = new RawMessage( '$1' );
$this->assertEquals(
$lang->formatTimePeriod( 1234 ),
$msg->inLanguage( $lang )->timeperiodParams( 1234 )->plain(),
'timeperiodParams is handled correctly'
);
}
/**
* @covers Message::sizeParams
*/
public function testMessageSizeParams() {
$lang = Language::factory( 'en' );
$msg = new RawMessage( '$1' );
$this->assertEquals(
$lang->formatSize( 123456 ),
$msg->inLanguage( $lang )->sizeParams( 123456 )->plain(),
'sizeParams is handled correctly'
);
}
/**
* @covers Message::bitrateParams
*/
public function testMessageBitrateParams() {
$lang = Language::factory( 'en' );
$msg = new RawMessage( '$1' );
$this->assertEquals(
$lang->formatBitrate( 123456 ),
$msg->inLanguage( $lang )->bitrateParams( 123456 )->plain(),
'bitrateParams is handled correctly'
);
}
/**
* @covers Message::inContentLanguage
*/
public function testInContentLanguageDisabled() {
$this->setMwGlobals( 'wgLang', Language::factory( 'fr' ) );
$this->assertEquals( 'Main Page', wfMessage( 'mainpage' )->inContentLanguage()->plain(), 'ForceUIMsg disabled' );
}
/**
* @covers Message::inContentLanguage
*/
public function testInContentLanguageEnabled() {
$this->setMwGlobals( array(
'wgLang' => Language::factory( 'fr' ),
'wgForceUIMsgAsContentMsg' => array( 'mainpage' ),
) );
$this->assertEquals( 'Accueil', wfMessage( 'mainpage' )->inContentLanguage()->plain(), 'ForceUIMsg enabled' );
}
/**
* @expectedException MWException
* @covers Message::inLanguage
*/
public function testInLanguageThrows() {
wfMessage( 'foo' )->inLanguage( 123 );
}
}