wiki.techinc.nl/tests/phpunit/unit/includes/user/UserNamePrefixSearchTest.php
James D. Forrester 1d0b7ae1e2 Namespace User under \MediaWiki\User
Bug: T166010
Change-Id: I7257302b485588af31384d4f7fc8e30551f161f1
2023-09-19 19:18:16 +00:00

154 lines
3.8 KiB
PHP

<?php
namespace MediaWiki\Tests\User;
use InvalidArgumentException;
use MediaWiki\Tests\Unit\DummyServicesTrait;
use MediaWiki\User\User;
use MediaWiki\User\UserNamePrefixSearch;
use MediaWiki\User\UserNameUtils;
use MediaWikiUnitTestCase;
use Wikimedia\Rdbms\DBConnRef;
use Wikimedia\Rdbms\IConnectionProvider;
use Wikimedia\Rdbms\SelectQueryBuilder;
/**
* @covers \MediaWiki\User\UserNamePrefixSearch
* @author DannyS712
*/
class UserNamePrefixSearchTest extends MediaWikiUnitTestCase {
use DummyServicesTrait;
/**
* @dataProvider provideTestSearch
* @param int $audienceType 1='public', 2=user without `hideuser` rights, 3=user with `hideuser` rights
* @param string $prefix
* @param int $limit
* @param int $offset
* @param array $result
*/
public function testSearch( int $audienceType, $prefix, int $limit, int $offset, array $result ) {
$userNameUtils = $this->getDummyUserNameUtils();
if ( $audienceType === 1 ) {
// 'public' audience
$audience = UserNamePrefixSearch::AUDIENCE_PUBLIC;
$excludeHidden = true;
} else {
if ( $audienceType === 2 ) {
// no hideuser rights
$hasHideuser = false;
$excludeHidden = true;
} else {
// 3 - has hideuser rights
$hasHideuser = true;
$excludeHidden = false;
}
// specific to a user identity
$audience = $this->createMock( User::class );
$audience->method( 'isAllowed' )
->with( 'hideuser' )
->willReturn( $hasHideuser );
}
$database = $this->createMock( DBConnRef::class );
$database->expects( $this->once() )
->method( 'anyString' )
->willReturn( 'anyStringGoesHere' );
$database->expects( $this->once() )
->method( 'buildLike' )
->with( $prefix, 'anyStringGoesHere' )
->willReturn( 'LIKE ' . $prefix . 'anyStringGoesHere' );
// Query parameters
$tables = [ 'user' ];
$conds = [ 'user_name LIKE ' . $prefix . 'anyStringGoesHere' ];
$joinConds = [];
if ( $excludeHidden ) {
$tables['ipblocks'] = 'ipblocks';
$conds['ipb_deleted'] = [ 0, null ];
$joinConds['ipblocks'] = [ 'LEFT JOIN', 'user_id=ipb_user' ];
}
$options = [
'LIMIT' => $limit,
'ORDER BY' => [ 'user_name' ],
'OFFSET' => $offset
];
$database->expects( $this->once() )
->method( 'selectFieldValues' )
->with(
$tables,
'user_name',
$conds,
'MediaWiki\User\UserNamePrefixSearch::search',
$options,
$joinConds
)
->willReturn( $result );
$database->method( 'newSelectQueryBuilder' )->willReturnCallback( static fn() => new SelectQueryBuilder( $database ) );
$dbProvider = $this->createMock( IConnectionProvider::class );
$dbProvider->expects( $this->once() )
->method( 'getReplicaDatabase' )
->willReturn( $database );
$userNamePrefixSearch = new UserNamePrefixSearch(
$dbProvider,
$userNameUtils
);
$res = $userNamePrefixSearch->search(
$audience,
$prefix,
$limit,
$offset
);
$this->assertSame( $result, $res );
}
public static function provideTestSearch() {
// [ $audienceType, $prefix, $limit, $offset, $result ]
return [
'public' => [
1,
'',
10,
0,
[ 'public result goes here' ]
],
'user without hideuser rights' => [
2,
'Prefix',
10,
5,
[ 'public result goes here, since user cannot see anything hidden' ]
],
'user with hideuser rights' => [
3,
'AnotherPrefix',
15,
2,
[
'result that is public',
'also a result that is private'
]
],
];
}
public function testSearchInvalidAudience() {
$userNamePrefixSearch = new UserNamePrefixSearch(
$this->createMock( IConnectionProvider::class ),
$this->createMock( UserNameUtils::class )
);
$this->expectException( InvalidArgumentException::class );
$this->expectExceptionMessage( '$audience must be AUDIENCE_PUBLIC or an Authority object' );
$userNamePrefixSearch->search(
'ThisIsTheInvalidAudience',
'',
1,
0
);
}
}