wiki.techinc.nl/tests/phpunit/unit/includes/user/ActorCacheTest.php
Tim Starling 5e30a927bc tests: Make some PHPUnit data providers static
Just methods where adding "static" to the declaration was enough, I
didn't do anything with providers that used $this.

Initially by search and replace. There were many mistakes which I
found mostly by running the PHPStorm inspection which searches for
$this usage in a static method. Later I used the PHPStorm "make static"
action which avoids the more obvious mistakes.

Bug: T332865
Change-Id: I47ed6692945607dfa5c139d42edbd934fa4f3a36
2023-03-24 02:53:57 +00:00

116 lines
4.1 KiB
PHP

<?php
namespace MediaWiki\Tests\Unit\User;
use MediaWiki\User\ActorCache;
use MediaWiki\User\UserIdentity;
use MediaWiki\User\UserIdentityValue;
use MediaWikiUnitTestCase;
/**
* @covers \MediaWiki\User\ActorCache
* @package MediaWiki\Tests\Unit\User
*/
class ActorCacheTest extends MediaWikiUnitTestCase {
/**
* @param ActorCache $cache
* @param int $actorId
* @param UserIdentity $actor
*/
private function assertCacheContains( ActorCache $cache, int $actorId, UserIdentity $actor ) {
$this->assertSame( $actor,
$cache->getActor( ActorCache::KEY_ACTOR_ID, $actorId ) );
$this->assertSame( $actor,
$cache->getActor( ActorCache::KEY_USER_NAME, $actor->getName() ) );
$this->assertSame( $actor,
$cache->getActor( ActorCache::KEY_USER_ID, $actor->getId( $actor->getWikiId() ) ) );
$this->assertSame( $actorId,
$cache->getActorId( ActorCache::KEY_ACTOR_ID, 1 ) );
$this->assertSame( $actorId,
$cache->getActorId( ActorCache::KEY_USER_NAME, $actor->getName() ) );
$this->assertSame( $actorId,
$cache->getActorId( ActorCache::KEY_USER_ID, $actor->getId( $actor->getWikiId() ) ) );
}
/**
* @param ActorCache $cache
* @param int $actorId
* @param string $actorName
* @param int $userId
*/
private function assertCacheNotContains( ActorCache $cache, int $actorId, string $actorName, int $userId ) {
$this->assertNull( $cache->getActor( ActorCache::KEY_ACTOR_ID, $actorId ) );
$this->assertNull( $cache->getActor( ActorCache::KEY_USER_NAME, $actorName ) );
$this->assertNull( $cache->getActor( ActorCache::KEY_USER_ID, $userId ) );
$this->assertNull( $cache->getActorId( ActorCache::KEY_ACTOR_ID, $actorId ) );
$this->assertNull( $cache->getActorId( ActorCache::KEY_USER_NAME, $actorName ) );
$this->assertNull( $cache->getActorId( ActorCache::KEY_USER_ID, $userId ) );
}
public static function provideGetActor() {
yield 'local' => [
'actor' => new UserIdentityValue( 10, 'Hello' ),
];
yield 'foreign' => [
'actor' => new UserIdentityValue( 10, 'Hello', 'acmewiki' ),
];
}
/**
* @dataProvider provideGetActor
*/
public function testGetActor( UserIdentity $actor ) {
$cache = new ActorCache( 5 );
$cache->add( 1, $actor );
$this->assertCacheContains( $cache, 1, $actor );
}
public static function provideRemove() {
yield 'Same actor' => [
'addedActor' => new UserIdentityValue( 10, 'Hello' ),
'removedActor' => new UserIdentityValue( 10, 'Hello' )
];
yield 'Different name' => [
'addedActor' => new UserIdentityValue( 10, 'Hello' ),
'removedActor' => new UserIdentityValue( 10, 'Goodbye' )
];
yield 'Different user ID' => [
'addedActor' => new UserIdentityValue( 10, 'Hello' ),
'removedActor' => new UserIdentityValue( 11, 'Hello' )
];
}
/**
* @dataProvider provideRemove
*/
public function testRemove( UserIdentity $added, UserIdentity $removed ) {
$cache = new ActorCache( 5 );
$cache->add( 1, $added );
$this->assertCacheContains( $cache, 1, $added );
$cache->remove( $removed );
$this->assertCacheNotContains( $cache, 1, $added->getName(), $added->getId() );
$this->assertCacheNotContains( $cache, 1, $removed->getName(), $removed->getId() );
}
public function testEvict() {
$cache = new ActorCache( 1 );
$actor1 = new UserIdentityValue( 10, 'Hello' );
$cache->add( 2, new UserIdentityValue( 12, 'Goodbye' ) );
$cache->add( 1, $actor1 );
$this->assertCacheContains( $cache, 1, $actor1 );
$this->assertCacheNotContains( $cache, 2, 'Goodbye', 12 );
}
public function testDoesNotCacheAnonUserId() {
$cache = new ActorCache( 5 );
$actor = new UserIdentityValue( 0, '127.0.0.1' );
$cache->add( 1, $actor );
$this->assertNull( $cache->getActor( ActorCache::KEY_USER_ID, 0 ) );
$this->assertNull( $cache->getActorId( ActorCache::KEY_USER_ID, 0 ) );
$this->assertSame( $actor, $cache->getActor( ActorCache::KEY_USER_NAME, '127.0.0.1' ) );
$this->assertSame( 1, $cache->getActorId( ActorCache::KEY_USER_NAME, '127.0.0.1' ) );
$this->assertSame( $actor, $cache->getActor( ActorCache::KEY_ACTOR_ID, 1 ) );
$this->assertSame( 1, $cache->getActorId( ActorCache::KEY_ACTOR_ID, 1 ) );
}
}