wiki.techinc.nl/tests/phpunit/languages/LanguageSrTest.php

200 lines
5.1 KiB
PHP
Raw Normal View History

<?php
/**
* PHPUnit tests for the Serbian language.
* The language can be represented using two scripts:
* - Latin (SR_el)
* - Cyrillic (SR_ec)
* Both representations seems to be bijective, hence MediaWiki can convert
* from one script to the other.
*
* @author Antoine Musso <hashar at free dot fr>
* @copyright Copyright © 2011, Antoine Musso <hashar at free dot fr>
* @file
*/
2012-02-02 11:14:26 +00:00
require_once dirname( dirname( __FILE__ ) ) . '/bootstrap.php';
/** Tests for MediaWiki languages/LanguageTr.php */
class LanguageSrTest extends MediaWikiTestCase {
/* Language object. Initialized before each test */
private $lang;
function setUp() {
2012-02-02 11:14:26 +00:00
$this->lang = Language::factory( 'sr' );
}
function tearDown() {
unset( $this->lang );
}
##### TESTS #######################################################
function testEasyConversions( ) {
$this->assertCyrillic(
'шђчћжШЂЧЋЖ',
'Cyrillic guessing characters'
);
$this->assertLatin(
'šđč枊ĐČĆŽ',
'Latin guessing characters'
);
}
function testMixedConversions() {
$this->assertCyrillic(
'шђчћжШЂЧЋЖ - šđčćž',
'Mostly cyrillic characters'
);
$this->assertLatin(
'šđč枊ĐČĆŽ - шђчћж',
'Mostly latin characters'
);
}
function testSameAmountOfLatinAndCyrillicGetConverted() {
$this->assertConverted(
'4 latin: šđčć | 4 cyrillic: шђчћ',
'sr-ec'
);
$this->assertConverted(
'4 latin: šđčć | 4 cyrillic: шђчћ',
'sr-el'
);
}
/**
2012-02-02 11:14:26 +00:00
* @author Nikola Smolenski
*/
function testConversionToCyrillic() {
$this->assertEquals( 'абвг',
$this->convertToCyrillic( 'abvg' )
);
$this->assertEquals( 'абвг',
$this->convertToCyrillic( 'абвг' )
);
$this->assertEquals( 'abvgшђжчћ',
$this->convertToCyrillic( 'abvgшђжчћ' )
);
$this->assertEquals( 'абвгшђжчћ',
$this->convertToCyrillic( 'абвгšđžčć' )
);
2012-02-02 11:14:26 +00:00
// Roman numerals are not converted
$this->assertEquals( 'а I б II в III г IV шђжчћ',
$this->convertToCyrillic( 'a I b II v III g IV šđžčć' )
);
}
function testConversionToLatin() {
$this->assertEquals( 'abcd',
$this->convertToLatin( 'abcd' )
);
$this->assertEquals( 'abcd',
$this->convertToLatin( 'абцд' )
);
$this->assertEquals( 'abcdšđžčć',
$this->convertToLatin( 'abcdшђжчћ' )
);
$this->assertEquals( 'абцдšđžčć',
$this->convertToLatin( 'абцдšđžčć' )
);
}
/** @dataProvider providePluralFourForms */
function testPluralFourForms( $result, $value ) {
$forms = array( 'one', 'few', 'many', 'other' );
$this->assertEquals( $result, $this->lang->convertPlural( $value, $forms ) );
}
function providePluralFourForms() {
return array (
array( 'one', 1 ),
array( 'many', 11 ),
array( 'one', 91 ),
array( 'one', 121 ),
array( 'few', 2 ),
array( 'few', 3 ),
array( 'few', 4 ),
array( 'few', 334 ),
array( 'many', 5 ),
array( 'many', 15 ),
array( 'many', 120 ),
);
}
/** @dataProvider providePluralTwoForms */
function testPluralTwoForms( $result, $value ) {
2012-02-02 11:14:26 +00:00
$forms = array( 'one', 'several' );
$this->assertEquals( $result, $this->lang->convertPlural( $value, $forms ) );
}
function providePluralTwoForms() {
return array (
array( 'one', 1 ),
array( 'several', 11 ),
array( 'several', 91 ),
array( 'several', 121 ),
);
}
##### HELPERS #####################################################
/**
*Wrapper to verify text stay the same after applying conversion
* @param $text string Text to convert
* @param $variant string Language variant 'sr-ec' or 'sr-el'
* @param $msg string Optional message
*/
function assertUnConverted( $text, $variant, $msg = '' ) {
$this->assertEquals(
$text,
$this->convertTo( $text, $variant ),
$msg
);
}
/**
* Wrapper to verify a text is different once converted to a variant.
* @param $text string Text to convert
* @param $variant string Language variant 'sr-ec' or 'sr-el'
* @param $msg string Optional message
*/
function assertConverted( $text, $variant, $msg = '' ) {
$this->assertNotEquals(
$text,
$this->convertTo( $text, $variant ),
$msg
);
}
/**
* Verifiy the given Cyrillic text is not converted when using
* using the cyrillic variant and converted to Latin when using
* the Latin variant.
*/
function assertCyrillic( $text, $msg = '' ) {
$this->assertUnConverted( $text, 'sr-ec', $msg );
$this->assertConverted( $text, 'sr-el', $msg );
}
/**
* Verifiy the given Latin text is not converted when using
* using the Latin variant and converted to Cyrillic when using
* the Cyrillic variant.
*/
function assertLatin( $text, $msg = '' ) {
$this->assertUnConverted( $text, 'sr-el', $msg );
$this->assertConverted( $text, 'sr-ec', $msg );
}
/** Wrapper for converter::convertTo() method*/
function convertTo( $text, $variant ) {
return $this
->lang
->mConverter
->convertTo(
$text, $variant
);
}
function convertToCyrillic( $text ) {
return $this->convertTo( $text, 'sr-ec' );
}
function convertToLatin( $text ) {
return $this->convertTo( $text, 'sr-el' );
}
}