2012-01-02 10:41:58 +00:00
|
|
|
<?php
|
|
|
|
|
/**
|
|
|
|
|
* Based on LanguagMlTest
|
|
|
|
|
* @file
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
/** Tests for MediaWiki languages/LanguageAr.php */
|
2012-10-23 20:53:17 +00:00
|
|
|
class LanguageArTest extends LanguageClassesTestCase {
|
2013-10-22 10:32:29 +00:00
|
|
|
/**
|
|
|
|
|
* @covers Language::formatNum
|
|
|
|
|
* @todo split into a test and a dataprovider
|
|
|
|
|
*/
|
|
|
|
|
public function testFormatNum() {
|
2012-10-23 20:53:17 +00:00
|
|
|
$this->assertEquals( '١٬٢٣٤٬٥٦٧', $this->getLang()->formatNum( '1234567' ) );
|
|
|
|
|
$this->assertEquals( '-١٢٫٨٩', $this->getLang()->formatNum( -12.89 ) );
|
2012-01-02 10:41:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Mostly to test the raw ascii feature.
|
|
|
|
|
* @dataProvider providerSprintfDate
|
2013-10-22 10:32:29 +00:00
|
|
|
* @covers Language::sprintfDate
|
2012-01-02 10:41:58 +00:00
|
|
|
*/
|
2013-10-22 10:32:29 +00:00
|
|
|
public function testSprintfDate( $format, $date, $expected ) {
|
2012-10-23 20:53:17 +00:00
|
|
|
$this->assertEquals( $expected, $this->getLang()->sprintfDate( $format, $date ) );
|
2012-01-02 10:41:58 +00:00
|
|
|
}
|
|
|
|
|
|
2013-03-22 02:12:37 +00:00
|
|
|
public static function providerSprintfDate() {
|
2012-01-02 10:41:58 +00:00
|
|
|
return array(
|
|
|
|
|
array(
|
|
|
|
|
'xg "vs" g',
|
|
|
|
|
'20120102030410',
|
|
|
|
|
'يناير vs ٣'
|
|
|
|
|
),
|
|
|
|
|
array(
|
|
|
|
|
'xmY',
|
|
|
|
|
'20120102030410',
|
|
|
|
|
'١٤٣٣'
|
|
|
|
|
),
|
|
|
|
|
array(
|
|
|
|
|
'xnxmY',
|
|
|
|
|
'20120102030410',
|
|
|
|
|
'1433'
|
|
|
|
|
),
|
|
|
|
|
array(
|
|
|
|
|
'xN xmj xmn xN xmY',
|
|
|
|
|
'20120102030410',
|
|
|
|
|
' 7 2 ١٤٣٣'
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
2013-02-15 10:27:48 +00:00
|
|
|
|
2013-10-22 10:32:29 +00:00
|
|
|
/**
|
|
|
|
|
* @dataProvider providePlural
|
|
|
|
|
* @covers Language::convertPlural
|
|
|
|
|
*/
|
|
|
|
|
public function testPlural( $result, $value ) {
|
2013-02-15 10:27:48 +00:00
|
|
|
$forms = array( 'zero', 'one', 'two', 'few', 'many', 'other' );
|
2012-10-23 20:53:17 +00:00
|
|
|
$this->assertEquals( $result, $this->getLang()->convertPlural( $value, $forms ) );
|
2012-01-27 06:01:43 +00:00
|
|
|
}
|
2013-02-15 10:27:48 +00:00
|
|
|
|
2013-10-22 10:32:29 +00:00
|
|
|
/**
|
|
|
|
|
* @dataProvider providePlural
|
|
|
|
|
* @covers Language::getPluralRuleType
|
|
|
|
|
*/
|
|
|
|
|
public function testGetPluralRuleType( $result, $value ) {
|
2013-01-25 01:10:37 +00:00
|
|
|
$this->assertEquals( $result, $this->getLang()->getPluralRuleType( $value ) );
|
|
|
|
|
}
|
|
|
|
|
|
2013-03-22 02:12:37 +00:00
|
|
|
public static function providePlural() {
|
2013-02-15 10:27:48 +00:00
|
|
|
return array(
|
2012-01-27 06:01:43 +00:00
|
|
|
array( 'zero', 0 ),
|
|
|
|
|
array( 'one', 1 ),
|
|
|
|
|
array( 'two', 2 ),
|
|
|
|
|
array( 'few', 3 ),
|
|
|
|
|
array( 'few', 9 ),
|
|
|
|
|
array( 'few', 110 ),
|
|
|
|
|
array( 'many', 11 ),
|
|
|
|
|
array( 'many', 15 ),
|
|
|
|
|
array( 'many', 99 ),
|
|
|
|
|
array( 'many', 9999 ),
|
|
|
|
|
array( 'other', 100 ),
|
|
|
|
|
array( 'other', 102 ),
|
|
|
|
|
array( 'other', 1000 ),
|
|
|
|
|
array( 'other', 1.7 ),
|
|
|
|
|
);
|
|
|
|
|
}
|
2012-01-02 10:41:58 +00:00
|
|
|
}
|