Replaces calls directly to PermissionManager with calls to the Authority object available from Context or the GroupPermissionLookup service. This patch does not address use of PermissionManager for blocks. Deprecations: - ApiBase::checkUserRightsAny deprecated passing optional User parameter - ApiBase::checkTitleUserPermissions deprecated passing LinkTarget as first parameter, takes PageIdentity instead Bug: T271462 Bug: T271854 Change-Id: I5d7cac1c28a37e074750c46cda03283980a07fca
74 lines
2.4 KiB
PHP
74 lines
2.4 KiB
PHP
<?php
|
|
|
|
use MediaWiki\Block\DatabaseBlock;
|
|
use Wikimedia\TestingAccessWrapper;
|
|
use Wikimedia\Timestamp\ConvertibleTimestamp;
|
|
|
|
/**
|
|
* @covers ApiQueryBlockInfoTrait
|
|
*/
|
|
class ApiQueryBlockInfoTraitTest extends MediaWikiIntegrationTestCase {
|
|
|
|
public function testUsesApiBlockInfoTrait() {
|
|
$this->assertTrue( method_exists( ApiQueryBlockInfoTrait::class, 'getBlockDetails' ),
|
|
'ApiQueryBlockInfoTrait::getBlockDetails exists' );
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideAddBlockInfoToQuery
|
|
*/
|
|
public function testAddBlockInfoToQuery( $args, $expect ) {
|
|
// Fake timestamp to show up in the queries
|
|
$reset = ConvertibleTimestamp::setFakeTime( '20190101000000' );
|
|
|
|
$data = [];
|
|
|
|
$mock = $this->getMockForTrait( ApiQueryBlockInfoTrait::class );
|
|
$mock->method( 'getDB' )->willReturn( wfGetDB( DB_REPLICA ) );
|
|
$mock->method( 'getAuthority' )
|
|
->willReturn( $this->getMutableTestUser()->getUser() );
|
|
$mock->method( 'addTables' )->willReturnCallback( static function ( $v ) use ( &$data ) {
|
|
$data['tables'] = array_merge( $data['tables'] ?? [], (array)$v );
|
|
} );
|
|
$mock->method( 'addFields' )->willReturnCallback( static function ( $v ) use ( &$data ) {
|
|
$data['fields'] = array_merge( $data['fields'] ?? [], (array)$v );
|
|
} );
|
|
$mock->method( 'addWhere' )->willReturnCallback( static function ( $v ) use ( &$data ) {
|
|
$data['where'] = array_merge( $data['where'] ?? [], (array)$v );
|
|
} );
|
|
$mock->method( 'addJoinConds' )->willReturnCallback( static function ( $v ) use ( &$data ) {
|
|
$data['joins'] = array_merge( $data['joins'] ?? [], (array)$v );
|
|
} );
|
|
|
|
TestingAccessWrapper::newFromObject( $mock )->addBlockInfoToQuery( ...$args );
|
|
$this->assertEquals( $expect, $data );
|
|
}
|
|
|
|
public function provideAddBlockInfoToQuery() {
|
|
$queryInfo = DatabaseBlock::getQueryInfo();
|
|
|
|
$db = wfGetDB( DB_REPLICA );
|
|
$ts = $db->addQuotes( $db->timestamp( '20190101000000' ) );
|
|
|
|
return [
|
|
[ [ false ], [
|
|
'tables' => [ 'blk' => [ 'ipblocks' ] ],
|
|
'fields' => [ 'ipb_deleted' ],
|
|
'where' => [ 'ipb_deleted = 0 OR ipb_deleted IS NULL' ],
|
|
'joins' => [
|
|
'blk' => [ 'LEFT JOIN', [ 'ipb_user=user_id', "ipb_expiry > $ts" ] ]
|
|
],
|
|
] ],
|
|
|
|
[ [ true ], [
|
|
'tables' => [ 'blk' => $queryInfo['tables'] ],
|
|
'fields' => $queryInfo['fields'],
|
|
'where' => [ 'ipb_deleted = 0 OR ipb_deleted IS NULL' ],
|
|
'joins' => $queryInfo['joins'] + [
|
|
'blk' => [ 'LEFT JOIN', [ 'ipb_user=user_id', "ipb_expiry > $ts" ] ]
|
|
],
|
|
] ],
|
|
];
|
|
}
|
|
|
|
}
|