wiki.techinc.nl/tests/phpunit/unit/includes/language/LanguageFallbackTest.php
Aryeh Gregor 8c4f59db64 New LanguageFallback service
This replaces the static Language methods getFallbackFor(),
getFallbacksFor(), and getFallbacksIncludingSiteLanguage(). There is
100% unit and integration test coverage for the new class.

One deliberate functional change: I changed one place where we threw
MWException to InvalidArgumentException.

Bug: T201405
Depends-On: Ie7a89f6ed7d52a0bc01672019ff92e7ee105a1f3
Change-Id: I49222eb55f1feec5b1dcd40f364cffe0c8801855
2019-10-08 15:11:39 -07:00

52 lines
1.3 KiB
PHP

<?php
use MediaWiki\Languages\LanguageFallback;
use MediaWiki\Languages\LanguageNameUtils;
/**
* @coversDefaultClass MediaWiki\Languages\LanguageFallback
* @covers ::__construct
*/
class LanguageFallbackTest extends MediaWikiUnitTestCase {
use LanguageFallbackTestTrait;
const DATA = [
'en' => [],
'fr' => [],
'sco' => [ 'en' ],
'yi' => [ 'he' ],
'ruq' => [ 'ruq-latn', 'ro' ],
'sh' => [ 'bs', 'sr-el', 'hr' ],
];
private function getLanguageNameUtils() {
$mockLangNameUtils = $this->createMock( LanguageNameUtils::class );
$mockLangNameUtils->method( 'isValidBuiltInCode' )
->will( $this->returnCallback( function ( $code ) {
// One-line copy-paste
return (bool)preg_match( '/^[a-z0-9-]{2,}$/', $code );
} ) );
$mockLangNameUtils->expects( $this->never() )
->method( $this->anythingBut( 'isValidBuiltInCode' ) );
return $mockLangNameUtils;
}
private function getCallee( array $options = [] ) : LanguageFallback {
return new LanguageFallback(
$options['siteLangCode'] ?? 'en',
$this->getMockLocalisationCache(
$options['expectedGets'] ?? 1,
$options['fallbackMap'] ?? self::DATA
),
$this->getLanguageNameUtils()
);
}
private function getMessagesKey() {
return LanguageFallback::MESSAGES;
}
private function getStrictKey() {
return LanguageFallback::STRICT;
}
}