Fix issues identified by SpaceBeforeSingleLineComment sniff
[lhc/web/wiklou.git] / tests / phpunit / includes / cache / GenderCacheTest.php
1 <?php
2
3 /**
4 * @group Database
5 * @group Cache
6 */
7 class GenderCacheTest extends MediaWikiLangTestCase {
8
9 function addDBData() {
10 // ensure the correct default gender
11 $this->mergeMwGlobalArrayValue( 'wgDefaultUserOptions', array( 'gender' => 'unknown' ) );
12
13 $user = User::newFromName( 'UTMale' );
14 if ( $user->getID() == 0 ) {
15 $user->addToDatabase();
16 $user->setPassword( 'UTMalePassword' );
17 }
18 // ensure the right gender
19 $user->setOption( 'gender', 'male' );
20 $user->saveSettings();
21
22 $user = User::newFromName( 'UTFemale' );
23 if ( $user->getID() == 0 ) {
24 $user->addToDatabase();
25 $user->setPassword( 'UTFemalePassword' );
26 }
27 // ensure the right gender
28 $user->setOption( 'gender', 'female' );
29 $user->saveSettings();
30
31 $user = User::newFromName( 'UTDefaultGender' );
32 if ( $user->getID() == 0 ) {
33 $user->addToDatabase();
34 $user->setPassword( 'UTDefaultGenderPassword' );
35 }
36 // ensure the default gender
37 $user->setOption( 'gender', null );
38 $user->saveSettings();
39 }
40
41 /**
42 * test usernames
43 *
44 * @dataProvider provideUserGenders
45 * @covers GenderCache::getGenderOf
46 */
47 public function testUserName( $username, $expectedGender ) {
48 $genderCache = GenderCache::singleton();
49 $gender = $genderCache->getGenderOf( $username );
50 $this->assertEquals( $gender, $expectedGender, "GenderCache normal" );
51 }
52
53 /**
54 * genderCache should work with user objects, too
55 *
56 * @dataProvider provideUserGenders
57 * @covers GenderCache::getGenderOf
58 */
59 public function testUserObjects( $username, $expectedGender ) {
60 $genderCache = GenderCache::singleton();
61 $user = User::newFromName( $username );
62 $gender = $genderCache->getGenderOf( $user );
63 $this->assertEquals( $gender, $expectedGender, "GenderCache normal" );
64 }
65
66 public static function provideUserGenders() {
67 return array(
68 array( 'UTMale', 'male' ),
69 array( 'UTFemale', 'female' ),
70 array( 'UTDefaultGender', 'unknown' ),
71 array( 'UTNotExist', 'unknown' ),
72 // some not valid user
73 array( '127.0.0.1', 'unknown' ),
74 array( 'user@test', 'unknown' ),
75 );
76 }
77
78 /**
79 * test strip of subpages to avoid unnecessary queries
80 * against the never existing username
81 *
82 * @dataProvider provideStripSubpages
83 * @covers GenderCache::getGenderOf
84 */
85 public function testStripSubpages( $pageWithSubpage, $expectedGender ) {
86 $genderCache = GenderCache::singleton();
87 $gender = $genderCache->getGenderOf( $pageWithSubpage );
88 $this->assertEquals( $gender, $expectedGender, "GenderCache must strip of subpages" );
89 }
90
91 public static function provideStripSubpages() {
92 return array(
93 array( 'UTMale/subpage', 'male' ),
94 array( 'UTFemale/subpage', 'female' ),
95 array( 'UTDefaultGender/subpage', 'unknown' ),
96 array( 'UTNotExist/subpage', 'unknown' ),
97 array( '127.0.0.1/subpage', 'unknown' ),
98 );
99 }
100 }