wiki.techinc.nl/tests/phpunit/includes/collation/CollationTest.php
Brian Wolff 73f5937047 Add collation for Bashkir (ba)
This is based on a numeric uppercase collation. Bashkir characters
will be remapped to the private use area for the purpose of sorting.

Bug: T162823
Change-Id: I65f1af0b57ff6ded7d464e39efd401f178a3519e
2017-05-10 04:17:46 +00:00

118 lines
3.2 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
/**
* Class CollationTest
* @covers Collation
* @covers IcuCollation
* @covers IdentityCollation
* @covers UppercaseCollation
*/
class CollationTest extends MediaWikiLangTestCase {
protected function setUp() {
parent::setUp();
$this->checkPHPExtension( 'intl' );
}
/**
* Test to make sure, that if you
* have "X" and "XY", the binary
* sortkey also has "X" being a
* prefix of "XY". Our collation
* code makes this assumption.
*
* @param string $lang Language code for collator
* @param string $base Base string
* @param string $extended String containing base as a prefix.
*
* @dataProvider prefixDataProvider
*/
public function testIsPrefix( $lang, $base, $extended ) {
$cp = Collator::create( $lang );
$cp->setStrength( Collator::PRIMARY );
$baseBin = $cp->getSortKey( $base );
// Remove sortkey terminator
$baseBin = rtrim( $baseBin, "\0" );
$extendedBin = $cp->getSortKey( $extended );
$this->assertStringStartsWith( $baseBin, $extendedBin, "$base is not a prefix of $extended" );
}
public static function prefixDataProvider() {
return [
[ 'en', 'A', 'AA' ],
[ 'en', 'A', 'AAA' ],
[ 'en', 'Д', 'ДЂ' ],
[ 'en', 'Д', 'ДA' ],
// 'Ʒ' should expand to 'Z ' (note space).
[ 'fi', 'Z', 'Ʒ' ],
// 'Þ' should expand to 'th'
[ 'sv', 't', 'Þ' ],
// Javanese is a limited use alphabet, so should have 3 bytes
// per character, so do some tests with it.
[ 'en', 'ꦲ', 'ꦲꦤ' ],
[ 'en', 'ꦲ', 'ꦲД' ],
[ 'en', 'A', 'Aꦲ' ],
];
}
/**
* Opposite of testIsPrefix
*
* @dataProvider notPrefixDataProvider
*/
public function testNotIsPrefix( $lang, $base, $extended ) {
$cp = Collator::create( $lang );
$cp->setStrength( Collator::PRIMARY );
$baseBin = $cp->getSortKey( $base );
// Remove sortkey terminator
$baseBin = rtrim( $baseBin, "\0" );
$extendedBin = $cp->getSortKey( $extended );
$this->assertStringStartsNotWith( $baseBin, $extendedBin, "$base is a prefix of $extended" );
}
public static function notPrefixDataProvider() {
return [
[ 'en', 'A', 'B' ],
[ 'en', 'AC', 'ABC' ],
[ 'en', 'Z', 'Ʒ' ],
[ 'en', 'A', 'ꦲ' ],
];
}
/**
* Test correct first letter is fetched.
*
* @param string $collation Collation name (aka uca-en)
* @param string $string String to get first letter of
* @param string $firstLetter Expected first letter.
*
* @dataProvider firstLetterProvider
*/
public function testGetFirstLetter( $collation, $string, $firstLetter ) {
$col = Collation::factory( $collation );
$this->assertEquals( $firstLetter, $col->getFirstLetter( $string ) );
}
function firstLetterProvider() {
return [
[ 'uppercase', 'Abc', 'A' ],
[ 'uppercase', 'abc', 'A' ],
[ 'identity', 'abc', 'a' ],
[ 'uca-en', 'abc', 'A' ],
[ 'uca-en', ' ', ' ' ],
[ 'uca-en', 'Êveryone', 'E' ],
[ 'uca-vi', 'Êveryone', 'Ê' ],
// Make sure thorn is not a first letter.
[ 'uca-sv', 'The', 'T' ],
[ 'uca-sv', 'Å', 'Å' ],
[ 'uca-hu', 'dzsdo', 'Dzs' ],
[ 'uca-hu', 'dzdso', 'Dz' ],
[ 'uca-hu', 'CSD', 'Cs' ],
[ 'uca-root', 'CSD', 'C' ],
[ 'uca-fi', 'Ǥ', 'G' ],
[ 'uca-fi', 'Ŧ', 'T' ],
[ 'uca-fi', 'Ʒ', 'Z' ],
[ 'uca-fi', 'Ŋ', 'N' ],
[ 'uppercase-ba', 'в', 'В' ],
];
}
}