wiki.techinc.nl/tests/phpunit/includes/cache/GenderCacheTest.php
DannyS712 29e8f74b5c GenderCacheTest: fix call to overrideMwServices()
MediaWikiIntegrationTestCase::overrideMwServices() is not static
and should not be called statically

Change-Id: I9d1f07b5bca8a39b82017e59978f2b28c399803e
2021-05-12 07:37:19 +00:00

107 lines
3.1 KiB
PHP

<?php
use MediaWiki\MediaWikiServices;
/**
* @group Database
* @group Cache
*/
class GenderCacheTest extends MediaWikiLangTestCase {
/** @var string[] User key => username */
private static $nameMap;
public function addDBDataOnce() {
// ensure the correct default gender
$this->mergeMwGlobalArrayValue( 'wgDefaultUserOptions', [ 'gender' => 'unknown' ] );
$male = $this->getMutableTestUser()->getUser();
$male->setOption( 'gender', 'male' );
$male->saveSettings();
$female = $this->getMutableTestUser()->getUser();
$female->setOption( 'gender', 'female' );
$female->saveSettings();
$default = $this->getMutableTestUser()->getUser();
$default->setOption( 'gender', null );
$default->saveSettings();
self::$nameMap = [
'UTMale' => $male->getName(),
'UTFemale' => $female->getName(),
'UTDefaultGender' => $default->getName()
];
}
/**
* test usernames
*
* @dataProvider provideUserGenders
* @covers GenderCache::getGenderOf
*/
public function testUserName( $userKey, $expectedGender ) {
$genderCache = MediaWikiServices::getInstance()->getGenderCache();
$username = self::$nameMap[$userKey] ?? $userKey;
$gender = $genderCache->getGenderOf( $username );
$this->assertEquals( $gender, $expectedGender, "GenderCache normal" );
}
/**
* genderCache should work with user objects, too
*
* @dataProvider provideUserGenders
* @covers GenderCache::getGenderOf
*/
public function testUserObjects( $userKey, $expectedGender ) {
$username = self::$nameMap[$userKey] ?? $userKey;
$genderCache = MediaWikiServices::getInstance()->getGenderCache();
$gender = $genderCache->getGenderOf( $username );
$this->assertEquals( $gender, $expectedGender, "GenderCache normal" );
}
public static function provideUserGenders() {
return [
[ 'UTMale', 'male' ],
[ 'UTFemale', 'female' ],
[ 'UTDefaultGender', 'unknown' ],
[ 'UTNotExist', 'unknown' ],
// some not valid user
[ '127.0.0.1', 'unknown' ],
[ 'user@test', 'unknown' ],
];
}
/**
* test strip of subpages to avoid unnecessary queries
* against the never existing username
*
* @dataProvider provideUserGenders
* @covers GenderCache::getGenderOf
*/
public function testStripSubpages( $userKey, $expectedGender ) {
$username = self::$nameMap[$userKey] ?? $userKey;
$genderCache = MediaWikiServices::getInstance()->getGenderCache();
$gender = $genderCache->getGenderOf( "$username/subpage" );
$this->assertEquals( $gender, $expectedGender, "GenderCache must strip of subpages" );
}
/**
* GenderCache must work without database (like Installer)
* @coversNothing
*/
public function testWithoutDB() {
$this->overrideMwServices();
$services = MediaWikiServices::getInstance();
$services->disableService( 'DBLoadBalancer' );
$services->disableService( 'DBLoadBalancerFactory' );
// Make sure the disable works
$this->assertTrue( $services->isServiceDisabled( 'DBLoadBalancer' ) );
// Test, if it is possible to create the gender cache
$genderCache = $services->getGenderCache();
$this->assertInstanceOf( GenderCache::class, $genderCache );
}
}