2012-02-01 04:53:55 +00:00
|
|
|
<?php
|
|
|
|
|
/**
|
|
|
|
|
* @author Amir E. Aharoni
|
|
|
|
|
* @copyright Copyright © 2012, Amir E. Aharoni
|
|
|
|
|
* @file
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
/** Tests for MediaWiki languages/classes/LanguagePl.php */
|
2012-10-23 20:53:17 +00:00
|
|
|
class LanguagePlTest extends LanguageClassesTestCase {
|
2013-10-22 10:32:29 +00:00
|
|
|
/**
|
|
|
|
|
* @dataProvider providePlural
|
|
|
|
|
* @covers Language::convertPlural
|
|
|
|
|
*/
|
|
|
|
|
public function testPlural( $result, $value ) {
|
2016-02-17 09:09:32 +00:00
|
|
|
$forms = [ 'one', 'few', 'many' ];
|
2012-10-23 20:53:17 +00:00
|
|
|
$this->assertEquals( $result, $this->getLang()->convertPlural( $value, $forms ) );
|
2012-02-01 04:53:55 +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() {
|
2016-02-17 09:09:32 +00:00
|
|
|
return [
|
|
|
|
|
[ 'many', 0 ],
|
|
|
|
|
[ 'one', 1 ],
|
|
|
|
|
[ 'few', 2 ],
|
|
|
|
|
[ 'few', 3 ],
|
|
|
|
|
[ 'few', 4 ],
|
|
|
|
|
[ 'many', 5 ],
|
|
|
|
|
[ 'many', 9 ],
|
|
|
|
|
[ 'many', 10 ],
|
|
|
|
|
[ 'many', 11 ],
|
|
|
|
|
[ 'many', 21 ],
|
|
|
|
|
[ 'few', 22 ],
|
|
|
|
|
[ 'few', 23 ],
|
|
|
|
|
[ 'few', 24 ],
|
|
|
|
|
[ 'many', 25 ],
|
|
|
|
|
[ 'many', 200 ],
|
|
|
|
|
[ 'many', 201 ],
|
|
|
|
|
];
|
2012-02-01 04:53:55 +00:00
|
|
|
}
|
|
|
|
|
|
2013-10-22 10:32:29 +00:00
|
|
|
/**
|
|
|
|
|
* @dataProvider providePluralTwoForms
|
|
|
|
|
* @covers Language::convertPlural
|
|
|
|
|
*/
|
|
|
|
|
public function testPluralTwoForms( $result, $value ) {
|
2016-02-17 09:09:32 +00:00
|
|
|
$forms = [ 'one', 'other' ];
|
2012-10-23 20:53:17 +00:00
|
|
|
$this->assertEquals( $result, $this->getLang()->convertPlural( $value, $forms ) );
|
2012-02-01 04:53:55 +00:00
|
|
|
}
|
|
|
|
|
|
2013-10-22 10:32:29 +00:00
|
|
|
public static function providePluralTwoForms() {
|
2016-02-17 09:09:32 +00:00
|
|
|
return [
|
|
|
|
|
[ 'other', 0 ],
|
|
|
|
|
[ 'one', 1 ],
|
|
|
|
|
[ 'other', 2 ],
|
|
|
|
|
[ 'other', 3 ],
|
|
|
|
|
[ 'other', 4 ],
|
|
|
|
|
[ 'other', 5 ],
|
|
|
|
|
[ 'other', 9 ],
|
|
|
|
|
[ 'other', 10 ],
|
|
|
|
|
[ 'other', 11 ],
|
|
|
|
|
[ 'other', 21 ],
|
|
|
|
|
[ 'other', 22 ],
|
|
|
|
|
[ 'other', 23 ],
|
|
|
|
|
[ 'other', 24 ],
|
|
|
|
|
[ 'other', 25 ],
|
|
|
|
|
[ 'other', 200 ],
|
|
|
|
|
[ 'other', 201 ],
|
|
|
|
|
];
|
2012-02-01 04:53:55 +00:00
|
|
|
}
|
2017-10-10 20:36:31 +00:00
|
|
|
|
|
|
|
|
/**
|
2017-10-10 18:51:50 +00:00
|
|
|
* @covers Language::commafy()
|
2017-10-10 20:36:31 +00:00
|
|
|
* @dataProvider provideCommafyData
|
|
|
|
|
*/
|
|
|
|
|
public function testCommafy( $number, $numbersWithCommas ) {
|
|
|
|
|
$this->assertEquals(
|
|
|
|
|
$numbersWithCommas,
|
|
|
|
|
$this->getLang()->commafy( $number ),
|
|
|
|
|
"commafy('$number')"
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static function provideCommafyData() {
|
|
|
|
|
// Note that commafy() always uses English separators (',' and '.') instead of
|
|
|
|
|
// Polish (' ' and ','). There is another function that converts them later.
|
|
|
|
|
return [
|
|
|
|
|
[ 1000, '1000' ],
|
|
|
|
|
[ 10000, '10,000' ],
|
|
|
|
|
[ 1000.0001, '1000.0001' ],
|
|
|
|
|
[ 10000.0001, '10,000.0001' ],
|
|
|
|
|
[ -1000, '-1000' ],
|
|
|
|
|
[ -10000, '-10,000' ],
|
|
|
|
|
[ -1000.0001, '-1000.0001' ],
|
|
|
|
|
[ -10000.0001, '-10,000.0001' ],
|
|
|
|
|
];
|
|
|
|
|
}
|
2012-02-01 04:53:55 +00:00
|
|
|
}
|