Depending on which namespace we want these classes to have after T166010 they could either stay in includes/languages/ (plural) in their own MediaWiki\Languages\-namespace dedicated to Language subclasses, or they could go in into a subdirectory like `includes/language/languages/` if we want to keep them in the same top-level namespace as other Language classes and services, but in a more nested namespace. For now, I've made the smaller change and kept the Language subclasses in their own directory directly under includes/, not nested further. Bug: T225756 Change-Id: I01015424707b442853879fd50c97f00215e5c2fa
47 lines
995 B
PHP
47 lines
995 B
PHP
<?php
|
|
/**
|
|
* @author Amir E. Aharoni
|
|
* @copyright Copyright © 2012, Amir E. Aharoni
|
|
* @file
|
|
*/
|
|
|
|
/**
|
|
* @group Language
|
|
*/
|
|
class LanguageRoTest extends LanguageClassesTestCase {
|
|
/**
|
|
* @dataProvider providePlural
|
|
* @covers Language::convertPlural
|
|
*/
|
|
public function testPlural( $result, $value ) {
|
|
$forms = [ 'one', 'few', 'other' ];
|
|
$this->assertEquals( $result, $this->getLang()->convertPlural( $value, $forms ) );
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providePlural
|
|
* @covers Language::getPluralRuleType
|
|
*/
|
|
public function testGetPluralRuleType( $result, $value ) {
|
|
$this->assertEquals( $result, $this->getLang()->getPluralRuleType( $value ) );
|
|
}
|
|
|
|
public static function providePlural() {
|
|
return [
|
|
[ 'few', 0 ],
|
|
[ 'one', 1 ],
|
|
[ 'few', 2 ],
|
|
[ 'few', 19 ],
|
|
[ 'other', 20 ],
|
|
[ 'other', 99 ],
|
|
[ 'other', 100 ],
|
|
[ 'few', 101 ],
|
|
[ 'few', 119 ],
|
|
[ 'other', 120 ],
|
|
[ 'other', 200 ],
|
|
[ 'few', 201 ],
|
|
[ 'few', 219 ],
|
|
[ 'other', 220 ],
|
|
];
|
|
}
|
|
}
|