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
45 lines
987 B
PHP
45 lines
987 B
PHP
<?php
|
|
/**
|
|
* @author Santhosh Thottingal
|
|
* @copyright Copyright © 2012, Santhosh Thottingal
|
|
* @file
|
|
*/
|
|
|
|
/**
|
|
* @group Language
|
|
*/
|
|
class LanguageCyTest extends LanguageClassesTestCase {
|
|
/**
|
|
* @dataProvider providePlural
|
|
* @covers Language::convertPlural
|
|
*/
|
|
public function testPlural( $result, $value ) {
|
|
$forms = [ 'zero', 'one', 'two', 'few', 'many', '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 [
|
|
[ 'zero', 0 ],
|
|
[ 'one', 1 ],
|
|
[ 'two', 2 ],
|
|
[ 'few', 3 ],
|
|
[ 'many', 6 ],
|
|
[ 'other', 4 ],
|
|
[ 'other', 5 ],
|
|
[ 'other', 11 ],
|
|
[ 'other', 20 ],
|
|
[ 'other', 22 ],
|
|
[ 'other', 223 ],
|
|
[ 'other', 200.00 ],
|
|
];
|
|
}
|
|
}
|