namespace MediaWiki\Tests\Permissions;
use Action;
-use FauxRequest;
-use MediaWiki\Session\SessionId;
-use MediaWiki\Session\TestUtils;
use MediaWikiLangTestCase;
use RequestContext;
-use stdClass;
use Title;
use User;
use MediaWiki\Block\DatabaseBlock;
use MediaWiki\Block\SystemBlock;
use MediaWiki\MediaWikiServices;
use MediaWiki\Permissions\PermissionManager;
-use Wikimedia\TestingAccessWrapper;
/**
* @group Database
'wgNamespaceProtection' => [
NS_MEDIAWIKI => 'editinterface',
],
- 'wgRevokePermissions' => [
- 'formertesters' => [
- 'runtest' => true
- ]
- ],
- 'wgAvailableRights' => [
- 'test',
- 'runtest',
- 'writetest',
- 'nukeworld',
- 'modifytest',
- 'editmyoptions'
- ]
] );
-
- $this->setGroupPermissions( 'unittesters', 'test', true );
- $this->setGroupPermissions( 'unittesters', 'runtest', true );
- $this->setGroupPermissions( 'unittesters', 'writetest', false );
- $this->setGroupPermissions( 'unittesters', 'nukeworld', false );
-
- $this->setGroupPermissions( 'testwriters', 'test', true );
- $this->setGroupPermissions( 'testwriters', 'writetest', true );
- $this->setGroupPermissions( 'testwriters', 'modifytest', true );
-
- $this->setGroupPermissions( '*', 'editmyoptions', true );
-
// Without this testUserBlock will use a non-English context on non-English MediaWiki
// installations (because of how Title::checkUserBlock is implemented) and fail.
RequestContext::resetMain();
$this->user = $this->userUser;
}
+ $this->permissionManager = MediaWikiServices::getInstance()->getPermissionManager();
+
$this->overrideMwServices();
}
- public function tearDown() {
- parent::tearDown();
- $this->restoreMwServices();
+ protected function setUserPerm( $perm ) {
+ // Setting member variables is evil!!!
+
+ if ( is_array( $perm ) ) {
+ $this->user->mRights = $perm;
+ } else {
+ $this->user->mRights = [ $perm ];
+ }
}
protected function setTitle( $ns, $title = "Main_Page" ) {
} else {
$this->user = $this->altUser;
}
- $this->overrideMwServices();
}
/**
$this->setUser( 'anon' );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "createtalk" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "createtalk" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [], $res );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "createpage" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "createpage" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [ [ "nocreatetext" ] ], $res );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [ [ 'nocreatetext' ] ], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, "createpage" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "createpage" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, "createtalk" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "createtalk" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [ [ 'nocreatetext' ] ], $res );
$this->setUser( $this->userName );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "createtalk" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "createtalk" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [], $res );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "createpage" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "createpage" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [ [ 'nocreate-loggedin' ] ], $res );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [ [ 'nocreate-loggedin' ] ], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, "createpage" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "createpage" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, "createtalk" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "createtalk" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [ [ 'nocreate-loggedin' ] ], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, "" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "" );
+ $res = $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title );
$this->assertEquals( [ [ 'nocreate-loggedin' ] ], $res );
$this->setUser( 'anon' );
$this->setTitle( NS_USER, $this->userName . '' );
- $this->overrideUserPermissions( $this->user, "" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'cant-move-user-page' ], [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '/subpage' );
- $this->overrideUserPermissions( $this->user, "" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '' );
- $this->overrideUserPermissions( $this->user, "move-rootuserpages" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "move-rootuserpages" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '/subpage' );
- $this->overrideUserPermissions( $this->user, "move-rootuserpages" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "move-rootuserpages" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '' );
- $this->overrideUserPermissions( $this->user, "" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'cant-move-user-page' ], [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '/subpage' );
- $this->overrideUserPermissions( $this->user, "" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '' );
- $this->overrideUserPermissions( $this->user, "move-rootuserpages" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "move-rootuserpages" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '/subpage' );
- $this->overrideUserPermissions( $this->user, "move-rootuserpages" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "move-rootuserpages" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setUser( $this->userName );
$this->setTitle( NS_FILE, "img.png" );
- $this->overrideUserPermissions( $this->user, "" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenotallowedfile' ], [ 'movenotallowed' ] ], $res );
$this->setTitle( NS_FILE, "img.png" );
- $this->overrideUserPermissions( $this->user, "movefile" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "movefile" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenotallowed' ] ], $res );
$this->setUser( 'anon' );
$this->setTitle( NS_FILE, "img.png" );
- $this->overrideUserPermissions( $this->user, "" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenotallowedfile' ], [ 'movenologintext' ] ], $res );
$this->setTitle( NS_FILE, "img.png" );
- $this->overrideUserPermissions( $this->user, "movefile" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "movefile" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setUser( $this->userName );
- // $this->setUserPerm( "move" );
- $this->runGroupPermissions( 'move', 'move', [ [ 'movenotallowedfile' ] ] );
+ $this->setUserPerm( "move" );
+ $this->runGroupPermissions( 'move', [ [ 'movenotallowedfile' ] ] );
- // $this->setUserPerm( "" );
+ $this->setUserPerm( "" );
$this->runGroupPermissions(
- '',
'move',
[ [ 'movenotallowedfile' ], [ 'movenotallowed' ] ]
);
$this->setUser( 'anon' );
- //$this->setUserPerm( "move" );
- $this->runGroupPermissions( 'move', 'move', [ [ 'movenotallowedfile' ] ] );
+ $this->setUserPerm( "move" );
+ $this->runGroupPermissions( 'move', [ [ 'movenotallowedfile' ] ] );
- // $this->setUserPerm( "" );
+ $this->setUserPerm( "" );
$this->runGroupPermissions(
- '',
'move',
[ [ 'movenotallowedfile' ], [ 'movenotallowed' ] ],
[ [ 'movenotallowedfile' ], [ 'movenologintext' ] ]
$this->setTitle( NS_MAIN );
$this->setUser( 'anon' );
- // $this->setUserPerm( "move" );
- $this->runGroupPermissions( 'move', 'move', [] );
+ $this->setUserPerm( "move" );
+ $this->runGroupPermissions( 'move', [] );
- // $this->setUserPerm( "" );
- $this->runGroupPermissions( '', 'move', [ [ 'movenotallowed' ] ],
+ $this->setUserPerm( "" );
+ $this->runGroupPermissions( 'move', [ [ 'movenotallowed' ] ],
[ [ 'movenologintext' ] ] );
$this->setUser( $this->userName );
- // $this->setUserPerm( "" );
- $this->runGroupPermissions( '', 'move', [ [ 'movenotallowed' ] ] );
+ $this->setUserPerm( "" );
+ $this->runGroupPermissions( 'move', [ [ 'movenotallowed' ] ] );
- //$this->setUserPerm( "move" );
- $this->runGroupPermissions( 'move', 'move', [] );
+ $this->setUserPerm( "move" );
+ $this->runGroupPermissions( 'move', [] );
$this->setUser( 'anon' );
- $this->overrideUserPermissions( $this->user, 'move' );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( 'move' );
+ $res = $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title );
$this->assertEquals( [], $res );
- $this->overrideUserPermissions( $this->user, '' );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( '' );
+ $res = $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title );
$this->assertEquals( [ [ 'movenotallowed' ] ], $res );
}
$this->setTitle( NS_USER );
$this->setUser( $this->userName );
- $this->overrideUserPermissions( $this->user, [ "move", "move-rootuserpages" ] );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( [ "move", "move-rootuserpages" ] );
+ $res = $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title );
$this->assertEquals( [], $res );
- $this->overrideUserPermissions( $this->user, "move" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "move" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title );
$this->assertEquals( [ [ 'cant-move-to-user-page' ] ], $res );
$this->setUser( 'anon' );
- $this->overrideUserPermissions( $this->user, [ "move", "move-rootuserpages" ] );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( [ "move", "move-rootuserpages" ] );
+ $res = $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title );
$this->assertEquals( [], $res );
$this->setTitle( NS_USER, "User/subpage" );
- $this->overrideUserPermissions( $this->user, [ "move", "move-rootuserpages" ] );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( [ "move", "move-rootuserpages" ] );
+ $res = $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title );
$this->assertEquals( [], $res );
- $this->overrideUserPermissions( $this->user, "move" );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( "move" );
+ $res = $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title );
$this->assertEquals( [], $res );
];
foreach ( [ "edit", "protect", "" ] as $action ) {
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( null );
$this->assertEquals( $check[$action][0],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title, true ) );
$this->assertEquals( $check[$action][0],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title, 'full' ) );
$this->assertEquals( $check[$action][0],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title, 'secure' ) );
global $wgGroupPermissions;
$old = $wgGroupPermissions;
$wgGroupPermissions = [];
- $this->overrideMwServices();
$this->assertEquals( $check[$action][1],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title, true ) );
$this->assertEquals( $check[$action][1],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title, 'full' ) );
$this->assertEquals( $check[$action][1],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title, 'secure' ) );
$wgGroupPermissions = $old;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $action );
+ $this->setUserPerm( $action );
$this->assertEquals( $check[$action][2],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title, true ) );
$this->assertEquals( $check[$action][2],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title, 'full' ) );
$this->assertEquals( $check[$action][2],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title, 'secure' ) );
- $this->overrideUserPermissions( $this->user, $action );
+ $this->setUserPerm( $action );
$this->assertEquals( $check[$action][3],
- MediaWikiServices::getInstance()->getPermissionManager()
- ->userCan( $action, $this->user, $this->title, true ) );
+ $this->permissionManager->userCan( $action, $this->user, $this->title, true ) );
$this->assertEquals( $check[$action][3],
- MediaWikiServices::getInstance()->getPermissionManager()
- ->userCan( $action, $this->user, $this->title,
+ $this->permissionManager->userCan( $action, $this->user, $this->title,
PermissionManager::RIGOR_QUICK ) );
# count( User::getGroupsWithPermissions( $action ) ) < 1
}
}
- protected function runGroupPermissions( $perm, $action, $result, $result2 = null ) {
+ protected function runGroupPermissions( $action, $result, $result2 = null ) {
global $wgGroupPermissions;
if ( $result2 === null ) {
$wgGroupPermissions['autoconfirmed']['move'] = false;
$wgGroupPermissions['user']['move'] = false;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $perm );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $res = $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title );
$this->assertEquals( $result, $res );
$wgGroupPermissions['autoconfirmed']['move'] = true;
$wgGroupPermissions['user']['move'] = false;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $perm );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $res = $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title );
$this->assertEquals( $result2, $res );
$wgGroupPermissions['autoconfirmed']['move'] = true;
$wgGroupPermissions['user']['move'] = true;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $perm );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $res = $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title );
$this->assertEquals( $result2, $res );
$wgGroupPermissions['autoconfirmed']['move'] = false;
$wgGroupPermissions['user']['move'] = true;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $perm );
- $res = MediaWikiServices::getInstance()->getPermissionManager()
+ $res = $this->permissionManager
->getPermissionErrors( $action, $this->user, $this->title );
$this->assertEquals( $result2, $res );
}
$this->setTitle( NS_SPECIAL );
$this->assertEquals( [ [ 'badaccess-group0' ], [ 'ns-specialprotected' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title ) );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, 'bogus' );
+ $this->setUserPerm( 'bogus' );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title ) );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, '' );
+ $this->setUserPerm( '' );
$this->assertEquals( [ [ 'badaccess-group0' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title ) );
$wgNamespaceProtection[NS_USER] = [ 'bogus' ];
$this->setTitle( NS_USER );
- $this->overrideUserPermissions( $this->user, '' );
+ $this->setUserPerm( '' );
$this->assertEquals( [ [ 'badaccess-group0' ],
[ 'namespaceprotected', 'User', 'bogus' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title ) );
$this->setTitle( NS_MEDIAWIKI );
- $this->overrideUserPermissions( $this->user, 'bogus' );
+ $this->setUserPerm( 'bogus' );
$this->assertEquals( [ [ 'protectedinterface', 'bogus' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title ) );
$this->setTitle( NS_MEDIAWIKI );
- $this->overrideUserPermissions( $this->user, 'bogus' );
+ $this->setUserPerm( 'bogus' );
$this->assertEquals( [ [ 'protectedinterface', 'bogus' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title ) );
$wgNamespaceProtection = null;
- $this->overrideUserPermissions( $this->user, 'bogus' );
+ $this->setUserPerm( 'bogus' );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title ) );
$this->assertEquals( true,
- MediaWikiServices::getInstance()->getPermissionManager()
- ->userCan( 'bogus', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'bogus', $this->user, $this->title ) );
- $this->overrideUserPermissions( $this->user, '' );
+ $this->setUserPerm( '' );
$this->assertEquals( [ [ 'badaccess-group0' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title ) );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()
- ->userCan( 'bogus', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'bogus', $this->user, $this->title ) );
}
/**
$resultUserJs,
$resultPatrol
) {
- $this->overrideUserPermissions( $this->user );
- $result = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( '' );
+ $result = $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title );
$this->assertEquals( $resultNone, $result );
- $this->overrideUserPermissions( $this->user, 'editmyusercss' );
- $result = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( 'editmyusercss' );
+ $result = $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title );
$this->assertEquals( $resultMyCss, $result );
- $this->overrideUserPermissions( $this->user, 'editmyuserjson' );
- $result = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( 'editmyuserjson' );
+ $result = $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title );
$this->assertEquals( $resultMyJson, $result );
- $this->overrideUserPermissions( $this->user, 'editmyuserjs' );
- $result = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( 'editmyuserjs' );
+ $result = $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title );
$this->assertEquals( $resultMyJs, $result );
- $this->overrideUserPermissions( $this->user, 'editusercss' );
- $result = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( 'editusercss' );
+ $result = $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title );
$this->assertEquals( $resultUserCss, $result );
- $this->overrideUserPermissions( $this->user, 'edituserjson' );
- $result = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( 'edituserjson' );
+ $result = $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title );
$this->assertEquals( $resultUserJson, $result );
- $this->overrideUserPermissions( $this->user, 'edituserjs' );
- $result = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( 'edituserjs' );
+ $result = $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title );
$this->assertEquals( $resultUserJs, $result );
- $this->overrideUserPermissions( $this->user );
- $result = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( '' );
+ $result = $this->permissionManager
->getPermissionErrors( 'patrol', $this->user, $this->title );
$this->assertEquals( reset( $resultPatrol[0] ), reset( $result[0] ) );
- $this->overrideUserPermissions( $this->user, [ 'edituserjs', 'edituserjson', 'editusercss' ] );
- $result = MediaWikiServices::getInstance()->getPermissionManager()
+ $this->setUserPerm( [ 'edituserjs', 'edituserjson', 'editusercss' ] );
+ $result = $this->permissionManager
->getPermissionErrors( 'bogus', $this->user, $this->title );
$this->assertEquals( [ [ 'badaccess-group0' ] ], $result );
}
$this->setTitle( NS_MAIN );
$this->title->mRestrictionsLoaded = true;
- $this->overrideUserPermissions( $this->user, "edit" );
+ $this->setUserPerm( "edit" );
$this->title->mRestrictions = [ "bogus" => [ 'bogus', "sysop", "protect", "" ] ];
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
- ->getPermissionErrors( 'edit', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'edit',
+ $this->user, $this->title ) );
$this->assertEquals( true,
- MediaWikiServices::getInstance()->getPermissionManager()
- ->userCan( 'edit', $this->user, $this->title, PermissionManager::RIGOR_QUICK ) );
+ $this->permissionManager->userCan( 'edit', $this->user, $this->title,
+ PermissionManager::RIGOR_QUICK ) );
$this->title->mRestrictions = [ "edit" => [ 'bogus', "sysop", "protect", "" ],
"bogus" => [ 'bogus', "sysop", "protect", "" ] ];
[ 'protectedpagetext', 'bogus', 'bogus' ],
[ 'protectedpagetext', 'editprotected', 'bogus' ],
[ 'protectedpagetext', 'protect', 'bogus' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'bogus', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'bogus',
+ $this->user, $this->title ) );
$this->assertEquals( [ [ 'protectedpagetext', 'bogus', 'edit' ],
[ 'protectedpagetext', 'editprotected', 'edit' ],
[ 'protectedpagetext', 'protect', 'edit' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'edit', $this->user, $this->title ) );
- $this->overrideUserPermissions( $this->user );
+ $this->permissionManager->getPermissionErrors( 'edit',
+ $this->user, $this->title ) );
+ $this->setUserPerm( "" );
$this->assertEquals( [ [ 'badaccess-group0' ],
[ 'protectedpagetext', 'bogus', 'bogus' ],
[ 'protectedpagetext', 'editprotected', 'bogus' ],
[ 'protectedpagetext', 'protect', 'bogus' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'bogus', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'bogus',
+ $this->user, $this->title ) );
$this->assertEquals( [ [ 'badaccess-groups', "*, [[$prefix:Users|Users]]", 2 ],
[ 'protectedpagetext', 'bogus', 'edit' ],
[ 'protectedpagetext', 'editprotected', 'edit' ],
[ 'protectedpagetext', 'protect', 'edit' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'edit', $this->user, $this->title ) );
- $this->overrideUserPermissions( $this->user, [ "edit", "editprotected" ] );
+ $this->permissionManager->getPermissionErrors( 'edit',
+ $this->user, $this->title ) );
+ $this->setUserPerm( [ "edit", "editprotected" ] );
$this->assertEquals( [ [ 'badaccess-group0' ],
[ 'protectedpagetext', 'bogus', 'bogus' ],
[ 'protectedpagetext', 'protect', 'bogus' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'bogus', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'bogus',
+ $this->user, $this->title ) );
$this->assertEquals( [
[ 'protectedpagetext', 'bogus', 'edit' ],
[ 'protectedpagetext', 'protect', 'edit' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'edit', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'edit',
+ $this->user, $this->title ) );
$this->title->mCascadeRestriction = true;
- $this->overrideUserPermissions( $this->user, "edit" );
+ $this->setUserPerm( "edit" );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()
- ->userCan( 'bogus', $this->user, $this->title, PermissionManager::RIGOR_QUICK ) );
+ $this->permissionManager->userCan( 'bogus', $this->user, $this->title,
+ PermissionManager::RIGOR_QUICK ) );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'edit', $this->user, $this->title, PermissionManager::RIGOR_QUICK ) );
+ $this->permissionManager->userCan( 'edit', $this->user, $this->title,
+ PermissionManager::RIGOR_QUICK ) );
$this->assertEquals( [ [ 'badaccess-group0' ],
[ 'protectedpagetext', 'bogus', 'bogus' ],
[ 'protectedpagetext', 'editprotected', 'bogus' ],
[ 'protectedpagetext', 'protect', 'bogus' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'bogus', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'bogus',
+ $this->user, $this->title ) );
$this->assertEquals( [ [ 'protectedpagetext', 'bogus', 'edit' ],
[ 'protectedpagetext', 'editprotected', 'edit' ],
[ 'protectedpagetext', 'protect', 'edit' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'edit', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'edit',
+ $this->user, $this->title ) );
- $this->overrideUserPermissions( $this->user, [ "edit", "editprotected" ] );
+ $this->setUserPerm( [ "edit", "editprotected" ] );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'bogus', $this->user, $this->title, PermissionManager::RIGOR_QUICK ) );
+ $this->permissionManager->userCan( 'bogus', $this->user, $this->title,
+ PermissionManager::RIGOR_QUICK ) );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'edit', $this->user, $this->title, PermissionManager::RIGOR_QUICK ) );
+ $this->permissionManager->userCan( 'edit', $this->user, $this->title,
+ PermissionManager::RIGOR_QUICK ) );
$this->assertEquals( [ [ 'badaccess-group0' ],
[ 'protectedpagetext', 'bogus', 'bogus' ],
[ 'protectedpagetext', 'protect', 'bogus' ],
[ 'protectedpagetext', 'protect', 'bogus' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'bogus', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'bogus',
+ $this->user, $this->title ) );
$this->assertEquals( [ [ 'protectedpagetext', 'bogus', 'edit' ],
[ 'protectedpagetext', 'protect', 'edit' ],
[ 'protectedpagetext', 'protect', 'edit' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'edit', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'edit',
+ $this->user, $this->title ) );
}
/**
*/
public function testCascadingSourcesRestrictions() {
$this->setTitle( NS_MAIN, "test page" );
- $this->overrideUserPermissions( $this->user, [ "edit", "bogus" ] );
+ $this->setUserPerm( [ "edit", "bogus" ] );
$this->title->mCascadeSources = [
Title::makeTitle( NS_MAIN, "Bogus" ),
];
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'bogus', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'bogus', $this->user, $this->title ) );
$this->assertEquals( [
[ "cascadeprotected", 2, "* [[:Bogus]]\n* [[:UnBogus]]\n", 'bogus' ],
[ "cascadeprotected", 2, "* [[:Bogus]]\n* [[:UnBogus]]\n", 'bogus' ],
[ "cascadeprotected", 2, "* [[:Bogus]]\n* [[:UnBogus]]\n", 'bogus' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'bogus', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'bogus', $this->user, $this->title ) );
$this->assertEquals( true,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'edit', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'edit', $this->user, $this->title ) );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'edit', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'edit', $this->user, $this->title ) );
}
/**
* @covers \MediaWiki\Permissions\PermissionManager::checkActionPermissions
*/
public function testActionPermissions() {
- $this->overrideUserPermissions( $this->user, [ "createpage" ] );
+ $this->setUserPerm( [ "createpage" ] );
$this->setTitle( NS_MAIN, "test page" );
$this->title->mTitleProtection['permission'] = '';
$this->title->mTitleProtection['user'] = $this->user->getId();
$this->title->mCascadeRestriction = false;
$this->assertEquals( [ [ 'titleprotected', 'Useruser', 'test' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title ) );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'create', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'create', $this->user, $this->title ) );
$this->title->mTitleProtection['permission'] = 'editprotected';
- $this->overrideUserPermissions( $this->user, [ 'createpage', 'protect' ] );
+ $this->setUserPerm( [ 'createpage', 'protect' ] );
$this->assertEquals( [ [ 'titleprotected', 'Useruser', 'test' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title ) );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'create', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'create', $this->user, $this->title ) );
- $this->overrideUserPermissions( $this->user, [ 'createpage', 'editprotected' ] );
+ $this->setUserPerm( [ 'createpage', 'editprotected' ] );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title ) );
$this->assertEquals( true,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'create', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'create', $this->user, $this->title ) );
- $this->overrideUserPermissions( $this->user, [ 'createpage' ] );
+ $this->setUserPerm( [ 'createpage' ] );
$this->assertEquals( [ [ 'titleprotected', 'Useruser', 'test' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'create', $this->user, $this->title ) );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'create', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'create', $this->user, $this->title ) );
$this->setTitle( NS_MEDIA, "test page" );
- $this->overrideUserPermissions( $this->user, [ "move" ] );
+ $this->setUserPerm( [ "move" ] );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'move', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'move', $this->user, $this->title ) );
$this->assertEquals( [ [ 'immobile-source-namespace', 'Media' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title ) );
$this->setTitle( NS_HELP, "test page" );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title ) );
$this->assertEquals( true,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'move', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'move', $this->user, $this->title ) );
$this->title->mInterwiki = "no";
$this->assertEquals( [ [ 'immobile-source-page' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move', $this->user, $this->title ) );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'move', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'move', $this->user, $this->title ) );
$this->setTitle( NS_MEDIA, "test page" );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'move-target', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'move-target', $this->user, $this->title ) );
$this->assertEquals( [ [ 'immobile-target-namespace', 'Media' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title ) );
$this->setTitle( NS_HELP, "test page" );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title ) );
$this->assertEquals( true,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'move-target', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'move-target', $this->user, $this->title ) );
$this->title->mInterwiki = "no";
$this->assertEquals( [ [ 'immobile-target-page' ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title ) );
$this->assertEquals( false,
- MediaWikiServices::getInstance()->getPermissionManager()->userCan(
- 'move-target', $this->user, $this->title ) );
+ $this->permissionManager->userCan( 'move-target', $this->user, $this->title ) );
}
/**
'wgBlockDisablesLogin' => false,
] );
- $this->overrideUserPermissions( $this->user, [
+ $this->overrideMwServices();
+ $this->permissionManager = MediaWikiServices::getInstance()->getPermissionManager();
+
+ $this->setUserPerm( [
'createpage',
'edit',
'move',
# $wgEmailConfirmToEdit only applies to 'edit' action
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'move-target', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'move-target',
+ $this->user, $this->title ) );
$this->assertContains( [ 'confirmedittext' ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'edit', $this->user, $this->title ) );
$this->setMwGlobals( 'wgEmailConfirmToEdit', false );
$this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, [
- 'createpage',
- 'edit',
- 'move',
- 'rollback',
- 'patrol',
- 'upload',
- 'purge'
- ] );
+ $this->permissionManager = MediaWikiServices::getInstance()->getPermissionManager();
$this->assertNotContains( [ 'confirmedittext' ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'edit', $this->user, $this->title ) );
# $wgEmailConfirmToEdit && !$user->isEmailConfirmed() && $action != 'createaccount'
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'move-target', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'move-target',
+ $this->user, $this->title ) );
global $wgLang;
$prev = time();
'[[User:Useruser|Useruser]]', 'no reason given', '127.0.0.1',
'Useruser', null, 'infinite', '127.0.8.1',
$wgLang->timeanddate( wfTimestamp( TS_MW, $prev ), true ) ] ],
- MediaWikiServices::getInstance()->getPermissionManager()->getPermissionErrors(
- 'move-target', $this->user, $this->title ) );
+ $this->permissionManager->getPermissionErrors( 'move-target',
+ $this->user, $this->title ) );
- $this->assertEquals( false, MediaWikiServices::getInstance()->getPermissionManager()
+ $this->assertEquals( false, $this->permissionManager
->userCan( 'move-target', $this->user, $this->title ) );
// quickUserCan should ignore user blocks
- $this->assertEquals( true, MediaWikiServices::getInstance()->getPermissionManager()
+ $this->assertEquals( true, $this->permissionManager
->userCan( 'move-target', $this->user, $this->title,
PermissionManager::RIGOR_QUICK ) );
'[[User:Useruser|Useruser]]', 'no reason given', '127.0.0.1',
'Useruser', null, '23:00, 31 December 1969', '127.0.8.1',
$wgLang->timeanddate( wfTimestamp( TS_MW, $now ), true ) ] ],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title ) );
# $action != 'read' && $action != 'createaccount' && $user->isBlockedFrom( $this )
# $user->blockedFor() == ''
$wgLang->timeanddate( wfTimestamp( TS_MW, $now ), true ) ] ];
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'edit', $this->user, $this->title ) );
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title ) );
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'rollback', $this->user, $this->title ) );
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'patrol', $this->user, $this->title ) );
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'upload', $this->user, $this->title ) );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'purge', $this->user, $this->title ) );
// partial block message test
] );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'edit', $this->user, $this->title ) );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title ) );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'rollback', $this->user, $this->title ) );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'patrol', $this->user, $this->title ) );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'upload', $this->user, $this->title ) );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'purge', $this->user, $this->title ) );
$this->user->mBlock->setRestrictions( [
$wgLang->timeanddate( wfTimestamp( TS_MW, $now ), true ) ] ];
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'edit', $this->user, $this->title ) );
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'move-target', $this->user, $this->title ) );
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'rollback', $this->user, $this->title ) );
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'patrol', $this->user, $this->title ) );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'upload', $this->user, $this->title ) );
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'purge', $this->user, $this->title ) );
// Test no block.
$this->user->mBlock = null;
$this->assertEquals( [],
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'edit', $this->user, $this->title ) );
}
$wgLang->timeanddate( wfTimestamp( TS_MW, $now ), true ) ] ];
$this->assertEquals( $errors,
- MediaWikiServices::getInstance()->getPermissionManager()
+ $this->permissionManager
->getPermissionErrors( 'tester', $this->user, $this->title ) );
}
//$this->assertSame( '', $user->blockedBy(), 'sanity check' );
//$this->assertSame( '', $user->blockedFor(), 'sanity check' );
//$this->assertFalse( (bool)$user->isHidden(), 'sanity check' );
- $this->assertFalse( MediaWikiServices::getInstance()->getPermissionManager()
+ $this->assertFalse( $this->permissionManager
->isBlockedFrom( $user, $ut ), 'sanity check' );
// Block the user
//$this->assertSame( $blocker->getName(), $user->blockedBy() );
//$this->assertSame( 'Because', $user->blockedFor() );
//$this->assertTrue( (bool)$user->isHidden() );
- $this->assertTrue( MediaWikiServices::getInstance()->getPermissionManager()
- ->isBlockedFrom( $user, $ut ) );
+ $this->assertTrue( $this->permissionManager->isBlockedFrom( $user, $ut ) );
// Unblock
$block->delete();
//$this->assertSame( '', $user->blockedBy() );
//$this->assertSame( '', $user->blockedFor() );
//$this->assertFalse( (bool)$user->isHidden() );
- $this->assertFalse( MediaWikiServices::getInstance()->getPermissionManager()
- ->isBlockedFrom( $user, $ut ) );
+ $this->assertFalse( $this->permissionManager->isBlockedFrom( $user, $ut ) );
}
/**
$block->insert();
try {
- $this->assertSame( $expect, MediaWikiServices::getInstance()->getPermissionManager()
- ->isBlockedFrom( $user, $title ) );
+ $this->assertSame( $expect, $this->permissionManager->isBlockedFrom( $user, $title ) );
} finally {
$block->delete();
}
];
}
- /**
- * @covers \MediaWiki\Permissions\PermissionManager::getUserPermissions
- */
- public function testGetUserPermissions() {
- $user = $this->getTestUser( [ 'unittesters' ] )->getUser();
- $rights = MediaWikiServices::getInstance()->getPermissionManager()
- ->getUserPermissions( $user );
- $this->assertContains( 'runtest', $rights );
- $this->assertNotContains( 'writetest', $rights );
- $this->assertNotContains( 'modifytest', $rights );
- $this->assertNotContains( 'nukeworld', $rights );
- }
-
- /**
- * @covers \MediaWiki\Permissions\PermissionManager::getUserPermissions
- */
- public function testGetUserPermissionsHooks() {
- $user = $this->getTestUser( [ 'unittesters', 'testwriters' ] )->getUser();
- $userWrapper = TestingAccessWrapper::newFromObject( $user );
-
- $rights = MediaWikiServices::getInstance()->getPermissionManager()
- ->getUserPermissions( $user );
- $this->assertContains( 'test', $rights, 'sanity check' );
- $this->assertContains( 'runtest', $rights, 'sanity check' );
- $this->assertContains( 'writetest', $rights, 'sanity check' );
- $this->assertNotContains( 'nukeworld', $rights, 'sanity check' );
-
- // Add a hook manipluating the rights
- $this->mergeMwGlobalArrayValue( 'wgHooks', [ 'UserGetRights' => [ function ( $user, &$rights ) {
- $rights[] = 'nukeworld';
- $rights = array_diff( $rights, [ 'writetest' ] );
- } ] ] );
-
- $this->overrideMwServices();
- $rights = MediaWikiServices::getInstance()->getPermissionManager()
- ->getUserPermissions( $user );
- $this->assertContains( 'test', $rights );
- $this->assertContains( 'runtest', $rights );
- $this->assertNotContains( 'writetest', $rights );
- $this->assertContains( 'nukeworld', $rights );
-
- // Add a Session that limits rights
- $mock = $this->getMockBuilder( stdClass::class )
- ->setMethods( [ 'getAllowedUserRights', 'deregisterSession', 'getSessionId' ] )
- ->getMock();
- $mock->method( 'getAllowedUserRights' )->willReturn( [ 'test', 'writetest' ] );
- $mock->method( 'getSessionId' )->willReturn(
- new SessionId( str_repeat( 'X', 32 ) )
- );
- $session = TestUtils::getDummySession( $mock );
- $mockRequest = $this->getMockBuilder( FauxRequest::class )
- ->setMethods( [ 'getSession' ] )
- ->getMock();
- $mockRequest->method( 'getSession' )->willReturn( $session );
- $userWrapper->mRequest = $mockRequest;
-
- $this->overrideMwServices();
- $rights = MediaWikiServices::getInstance()->getPermissionManager()
- ->getUserPermissions( $user );
- $this->assertContains( 'test', $rights );
- $this->assertNotContains( 'runtest', $rights );
- $this->assertNotContains( 'writetest', $rights );
- $this->assertNotContains( 'nukeworld', $rights );
- }
-
- /**
- * @covers \MediaWiki\Permissions\PermissionManager::getGroupPermissions
- */
- public function testGroupPermissions() {
- $rights = MediaWikiServices::getInstance()->getPermissionManager()
- ->getGroupPermissions( [ 'unittesters' ] );
- $this->assertContains( 'runtest', $rights );
- $this->assertNotContains( 'writetest', $rights );
- $this->assertNotContains( 'modifytest', $rights );
- $this->assertNotContains( 'nukeworld', $rights );
-
- $rights = MediaWikiServices::getInstance()->getPermissionManager()
- ->getGroupPermissions( [ 'unittesters', 'testwriters' ] );
- $this->assertContains( 'runtest', $rights );
- $this->assertContains( 'writetest', $rights );
- $this->assertContains( 'modifytest', $rights );
- $this->assertNotContains( 'nukeworld', $rights );
- }
-
- /**
- * @covers \MediaWiki\Permissions\PermissionManager::getGroupPermissions
- */
- public function testRevokePermissions() {
- $rights = MediaWikiServices::getInstance()->getPermissionManager()
- ->getGroupPermissions( [ 'unittesters', 'formertesters' ] );
- $this->assertNotContains( 'runtest', $rights );
- $this->assertNotContains( 'writetest', $rights );
- $this->assertNotContains( 'modifytest', $rights );
- $this->assertNotContains( 'nukeworld', $rights );
- }
-
- /**
- * @dataProvider provideGetGroupsWithPermission
- * @covers \MediaWiki\Permissions\PermissionManager::getGroupsWithPermission
- */
- public function testGetGroupsWithPermission( $expected, $right ) {
- $result = MediaWikiServices::getInstance()->getPermissionManager()
- ->getGroupsWithPermission( $right );
- sort( $result );
- sort( $expected );
-
- $this->assertEquals( $expected, $result, "Groups with permission $right" );
- }
-
- public static function provideGetGroupsWithPermission() {
- return [
- [
- [ 'unittesters', 'testwriters' ],
- 'test'
- ],
- [
- [ 'unittesters' ],
- 'runtest'
- ],
- [
- [ 'testwriters' ],
- 'writetest'
- ],
- [
- [ 'testwriters' ],
- 'modifytest'
- ],
- ];
- }
-
- /**
- * @covers \MediaWiki\Permissions\PermissionManager::userHasRight
- */
- public function testUserHasRight() {
- $result = MediaWikiServices::getInstance()->getPermissionManager()->userHasRight(
- $this->getTestUser( 'unittesters' )->getUser(),
- 'test'
- );
- $this->assertTrue( $result );
-
- $result = MediaWikiServices::getInstance()->getPermissionManager()->userHasRight(
- $this->getTestUser( 'formertesters' )->getUser(),
- 'runtest'
- );
- $this->assertFalse( $result );
-
- $result = MediaWikiServices::getInstance()->getPermissionManager()->userHasRight(
- $this->getTestUser( 'formertesters' )->getUser(),
- ''
- );
- $this->assertTrue( $result );
- }
-
- /**
- * @covers \MediaWiki\Permissions\PermissionManager::groupHasPermission
- */
- public function testGroupHasPermission() {
- $result = MediaWikiServices::getInstance()->getPermissionManager()->groupHasPermission(
- 'unittesters',
- 'test'
- );
- $this->assertTrue( $result );
-
- $result = MediaWikiServices::getInstance()->getPermissionManager()->groupHasPermission(
- 'formertesters',
- 'runtest'
- );
- $this->assertFalse( $result );
- }
-
- /**
- * @covers \MediaWiki\Permissions\PermissionManager::isEveryoneAllowed
- */
- public function testIsEveryoneAllowed() {
- $result = MediaWikiServices::getInstance()->getPermissionManager()
- ->isEveryoneAllowed( 'editmyoptions' );
- $this->assertTrue( $result );
-
- $result = MediaWikiServices::getInstance()->getPermissionManager()
- ->isEveryoneAllowed( 'test' );
- $this->assertFalse( $result );
- }
-
}
$this->overrideMwServices();
}
+ protected function setUserPerm( $perm ) {
+ // Setting member variables is evil!!!
+
+ if ( is_array( $perm ) ) {
+ $this->user->mRights = $perm;
+ } else {
+ $this->user->mRights = [ $perm ];
+ }
+ }
+
protected function setTitle( $ns, $title = "Main_Page" ) {
$this->title = Title::makeTitle( $ns, $title );
}
$this->setUser( 'anon' );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "createtalk" );
+ $this->setUserPerm( "createtalk" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [], $res );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "createpage" );
+ $this->setUserPerm( "createpage" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [ [ "nocreatetext" ] ], $res );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "" );
+ $this->setUserPerm( "" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [ [ 'nocreatetext' ] ], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, "createpage" );
+ $this->setUserPerm( "createpage" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, "createtalk" );
+ $this->setUserPerm( "createtalk" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [ [ 'nocreatetext' ] ], $res );
$this->setUser( $this->userName );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "createtalk" );
+ $this->setUserPerm( "createtalk" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [], $res );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user, "createpage" );
+ $this->setUserPerm( "createpage" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [ [ 'nocreate-loggedin' ] ], $res );
$this->setTitle( NS_TALK );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( "" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [ [ 'nocreate-loggedin' ] ], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, "createpage" );
+ $this->setUserPerm( "createpage" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, "createtalk" );
+ $this->setUserPerm( "createtalk" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [ [ 'nocreate-loggedin' ] ], $res );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( "" );
$res = $this->title->getUserPermissionsErrors( 'create', $this->user );
$this->assertEquals( [ [ 'nocreate-loggedin' ] ], $res );
$this->setUser( 'anon' );
$this->setTitle( NS_USER, $this->userName . '' );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( "" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'cant-move-user-page' ], [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '/subpage' );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( "" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '' );
- $this->overrideUserPermissions( $this->user, "move-rootuserpages" );
+ $this->setUserPerm( "move-rootuserpages" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '/subpage' );
- $this->overrideUserPermissions( $this->user, "move-rootuserpages" );
+ $this->setUserPerm( "move-rootuserpages" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '' );
- $this->overrideUserPermissions( $this->user, "" );
+ $this->setUserPerm( "" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'cant-move-user-page' ], [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '/subpage' );
- $this->overrideUserPermissions( $this->user, "" );
+ $this->setUserPerm( "" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '' );
- $this->overrideUserPermissions( $this->user, "move-rootuserpages" );
+ $this->setUserPerm( "move-rootuserpages" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setTitle( NS_USER, $this->userName . '/subpage' );
- $this->overrideUserPermissions( $this->user, "move-rootuserpages" );
+ $this->setUserPerm( "move-rootuserpages" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setUser( $this->userName );
$this->setTitle( NS_FILE, "img.png" );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( "" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenotallowedfile' ], [ 'movenotallowed' ] ], $res );
$this->setTitle( NS_FILE, "img.png" );
- $this->overrideUserPermissions( $this->user, "movefile" );
+ $this->setUserPerm( "movefile" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenotallowed' ] ], $res );
$this->setUser( 'anon' );
$this->setTitle( NS_FILE, "img.png" );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( "" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenotallowedfile' ], [ 'movenologintext' ] ], $res );
$this->setTitle( NS_FILE, "img.png" );
- $this->overrideUserPermissions( $this->user, "movefile" );
+ $this->setUserPerm( "movefile" );
$res = $this->title->getUserPermissionsErrors( 'move', $this->user );
$this->assertEquals( [ [ 'movenologintext' ] ], $res );
$this->setUser( $this->userName );
- $this->overrideUserPermissions( $this->user, "move" );
+ $this->setUserPerm( "move" );
$this->runGroupPermissions( 'move', [ [ 'movenotallowedfile' ] ] );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( "" );
$this->runGroupPermissions(
'move',
[ [ 'movenotallowedfile' ], [ 'movenotallowed' ] ]
);
$this->setUser( 'anon' );
- $this->overrideUserPermissions( $this->user, "move" );
+ $this->setUserPerm( "move" );
$this->runGroupPermissions( 'move', [ [ 'movenotallowedfile' ] ] );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( "" );
$this->runGroupPermissions(
'move',
[ [ 'movenotallowedfile' ], [ 'movenotallowed' ] ],
$this->setTitle( NS_MAIN );
$this->setUser( 'anon' );
- $this->overrideUserPermissions( $this->user, "move" );
+ $this->setUserPerm( "move" );
$this->runGroupPermissions( 'move', [] );
- $this->overrideUserPermissions( $this->user, "" );
+ $this->setUserPerm( "" );
$this->runGroupPermissions( 'move', [ [ 'movenotallowed' ] ],
[ [ 'movenologintext' ] ] );
$this->setUser( $this->userName );
- $this->overrideUserPermissions( $this->user, "" );
+ $this->setUserPerm( "" );
$this->runGroupPermissions( 'move', [ [ 'movenotallowed' ] ] );
- $this->overrideUserPermissions( $this->user, "move" );
+ $this->setUserPerm( "move" );
$this->runGroupPermissions( 'move', [] );
$this->setUser( 'anon' );
- $this->overrideUserPermissions( $this->user, 'move' );
+ $this->setUserPerm( 'move' );
$res = $this->title->getUserPermissionsErrors( 'move-target', $this->user );
$this->assertEquals( [], $res );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( '' );
$res = $this->title->getUserPermissionsErrors( 'move-target', $this->user );
$this->assertEquals( [ [ 'movenotallowed' ] ], $res );
}
$this->setTitle( NS_USER );
$this->setUser( $this->userName );
- $this->overrideUserPermissions( $this->user, [ "move", "move-rootuserpages" ] );
+ $this->setUserPerm( [ "move", "move-rootuserpages" ] );
$res = $this->title->getUserPermissionsErrors( 'move-target', $this->user );
$this->assertEquals( [], $res );
- $this->overrideUserPermissions( $this->user, "move" );
+ $this->setUserPerm( "move" );
$res = $this->title->getUserPermissionsErrors( 'move-target', $this->user );
$this->assertEquals( [ [ 'cant-move-to-user-page' ] ], $res );
$this->setUser( 'anon' );
- $this->overrideUserPermissions( $this->user, [ "move", "move-rootuserpages" ] );
+ $this->setUserPerm( [ "move", "move-rootuserpages" ] );
$res = $this->title->getUserPermissionsErrors( 'move-target', $this->user );
$this->assertEquals( [], $res );
$this->setTitle( NS_USER, "User/subpage" );
- $this->overrideUserPermissions( $this->user, [ "move", "move-rootuserpages" ] );
+ $this->setUserPerm( [ "move", "move-rootuserpages" ] );
$res = $this->title->getUserPermissionsErrors( 'move-target', $this->user );
$this->assertEquals( [], $res );
- $this->overrideUserPermissions( $this->user, "move" );
+ $this->setUserPerm( "move" );
$res = $this->title->getUserPermissionsErrors( 'move-target', $this->user );
$this->assertEquals( [], $res );
];
foreach ( [ "edit", "protect", "" ] as $action ) {
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( null );
$this->assertEquals( $check[$action][0],
$this->title->getUserPermissionsErrors( $action, $this->user, true ) );
$this->assertEquals( $check[$action][0],
$old = $wgGroupPermissions;
$wgGroupPermissions = [];
- $this->overrideMwServices();
-
$this->assertEquals( $check[$action][1],
$this->title->getUserPermissionsErrors( $action, $this->user, true ) );
$this->assertEquals( $check[$action][1],
$this->title->getUserPermissionsErrors( $action, $this->user, 'full' ) );
$this->assertEquals( $check[$action][1],
$this->title->getUserPermissionsErrors( $action, $this->user, 'secure' ) );
-
$wgGroupPermissions = $old;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $action );
+ $this->setUserPerm( $action );
$this->assertEquals( $check[$action][2],
$this->title->getUserPermissionsErrors( $action, $this->user, true ) );
$this->assertEquals( $check[$action][2],
$this->assertEquals( $check[$action][2],
$this->title->getUserPermissionsErrors( $action, $this->user, 'secure' ) );
- $this->overrideUserPermissions( $this->user, $action );
+ $this->setUserPerm( $action );
$this->assertEquals( $check[$action][3],
$this->title->userCan( $action, $this->user, true ) );
$this->assertEquals( $check[$action][3],
$result2 = $result;
}
- // XXX: there could be a better way to handle this, but since we need to
- // override PermissionManager service each time globals are changed
- // and in the same time we need to keep user permissions overrides from the outside
- // the best we can do inside this method is to save & restore faked user perms
-
- $userPermsOverrides = MediaWikiServices::getInstance()->getPermissionManager()
- ->getUserPermissions( $this->user );
-
$wgGroupPermissions['autoconfirmed']['move'] = false;
$wgGroupPermissions['user']['move'] = false;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $userPermsOverrides );
$res = $this->title->getUserPermissionsErrors( $action, $this->user );
$this->assertEquals( $result, $res );
$wgGroupPermissions['autoconfirmed']['move'] = true;
$wgGroupPermissions['user']['move'] = false;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $userPermsOverrides );
$res = $this->title->getUserPermissionsErrors( $action, $this->user );
$this->assertEquals( $result2, $res );
$wgGroupPermissions['autoconfirmed']['move'] = true;
$wgGroupPermissions['user']['move'] = true;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $userPermsOverrides );
$res = $this->title->getUserPermissionsErrors( $action, $this->user );
$this->assertEquals( $result2, $res );
$wgGroupPermissions['autoconfirmed']['move'] = false;
$wgGroupPermissions['user']['move'] = true;
- $this->overrideMwServices();
- $this->overrideUserPermissions( $this->user, $userPermsOverrides );
$res = $this->title->getUserPermissionsErrors( $action, $this->user );
$this->assertEquals( $result2, $res );
}
$this->title->getUserPermissionsErrors( 'bogus', $this->user ) );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user, 'bogus' );
+ $this->setUserPerm( 'bogus' );
$this->assertEquals( [],
$this->title->getUserPermissionsErrors( 'bogus', $this->user ) );
$this->setTitle( NS_MAIN );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( '' );
$this->assertEquals( [ [ 'badaccess-group0' ] ],
$this->title->getUserPermissionsErrors( 'bogus', $this->user ) );
$wgNamespaceProtection[NS_USER] = [ 'bogus' ];
$this->setTitle( NS_USER );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( '' );
$this->assertEquals( [ [ 'badaccess-group0' ],
[ 'namespaceprotected', 'User', 'bogus' ] ],
$this->title->getUserPermissionsErrors( 'bogus', $this->user ) );
$this->setTitle( NS_MEDIAWIKI );
- $this->overrideUserPermissions( $this->user, 'bogus' );
+ $this->setUserPerm( 'bogus' );
$this->assertEquals( [ [ 'protectedinterface', 'bogus' ] ],
$this->title->getUserPermissionsErrors( 'bogus', $this->user ) );
$this->setTitle( NS_MEDIAWIKI );
- $this->overrideUserPermissions( $this->user, 'bogus' );
+ $this->setUserPerm( 'bogus' );
$this->assertEquals( [ [ 'protectedinterface', 'bogus' ] ],
$this->title->getUserPermissionsErrors( 'bogus', $this->user ) );
$wgNamespaceProtection = null;
- $this->overrideUserPermissions( $this->user, 'bogus' );
+ $this->setUserPerm( 'bogus' );
$this->assertEquals( [],
$this->title->getUserPermissionsErrors( 'bogus', $this->user ) );
$this->assertEquals( true,
$this->title->userCan( 'bogus', $this->user ) );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( '' );
$this->assertEquals( [ [ 'badaccess-group0' ] ],
$this->title->getUserPermissionsErrors( 'bogus', $this->user ) );
$this->assertEquals( false,
$resultUserJs,
$resultPatrol
) {
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( '' );
$result = $this->title->getUserPermissionsErrors( 'bogus', $this->user );
$this->assertEquals( $resultNone, $result );
- $this->overrideUserPermissions( $this->user, 'editmyusercss' );
+ $this->setUserPerm( 'editmyusercss' );
$result = $this->title->getUserPermissionsErrors( 'bogus', $this->user );
$this->assertEquals( $resultMyCss, $result );
- $this->overrideUserPermissions( $this->user, 'editmyuserjson' );
+ $this->setUserPerm( 'editmyuserjson' );
$result = $this->title->getUserPermissionsErrors( 'bogus', $this->user );
$this->assertEquals( $resultMyJson, $result );
- $this->overrideUserPermissions( $this->user, 'editmyuserjs' );
+ $this->setUserPerm( 'editmyuserjs' );
$result = $this->title->getUserPermissionsErrors( 'bogus', $this->user );
$this->assertEquals( $resultMyJs, $result );
- $this->overrideUserPermissions( $this->user, 'editusercss' );
+ $this->setUserPerm( 'editusercss' );
$result = $this->title->getUserPermissionsErrors( 'bogus', $this->user );
$this->assertEquals( $resultUserCss, $result );
- $this->overrideUserPermissions( $this->user, 'edituserjson' );
+ $this->setUserPerm( 'edituserjson' );
$result = $this->title->getUserPermissionsErrors( 'bogus', $this->user );
$this->assertEquals( $resultUserJson, $result );
- $this->overrideUserPermissions( $this->user, 'edituserjs' );
+ $this->setUserPerm( 'edituserjs' );
$result = $this->title->getUserPermissionsErrors( 'bogus', $this->user );
$this->assertEquals( $resultUserJs, $result );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( '' );
$result = $this->title->getUserPermissionsErrors( 'patrol', $this->user );
$this->assertEquals( reset( $resultPatrol[0] ), reset( $result[0] ) );
- $this->overrideUserPermissions( $this->user, [ 'edituserjs', 'edituserjson', 'editusercss' ] );
+ $this->setUserPerm( [ 'edituserjs', 'edituserjson', 'editusercss' ] );
$result = $this->title->getUserPermissionsErrors( 'bogus', $this->user );
$this->assertEquals( [ [ 'badaccess-group0' ] ], $result );
}
$this->setTitle( NS_MAIN );
$this->title->mRestrictionsLoaded = true;
- $this->overrideUserPermissions( $this->user, "edit" );
+ $this->setUserPerm( "edit" );
$this->title->mRestrictions = [ "bogus" => [ 'bogus', "sysop", "protect", "" ] ];
$this->assertEquals( [],
[ 'protectedpagetext', 'protect', 'edit' ] ],
$this->title->getUserPermissionsErrors( 'edit',
$this->user ) );
- $this->overrideUserPermissions( $this->user );
+ $this->setUserPerm( "" );
$this->assertEquals( [ [ 'badaccess-group0' ],
[ 'protectedpagetext', 'bogus', 'bogus' ],
[ 'protectedpagetext', 'editprotected', 'bogus' ],
[ 'protectedpagetext', 'protect', 'edit' ] ],
$this->title->getUserPermissionsErrors( 'edit',
$this->user ) );
- $this->overrideUserPermissions( $this->user, [ "edit", "editprotected" ] );
+ $this->setUserPerm( [ "edit", "editprotected" ] );
$this->assertEquals( [ [ 'badaccess-group0' ],
[ 'protectedpagetext', 'bogus', 'bogus' ],
[ 'protectedpagetext', 'protect', 'bogus' ] ],
$this->user ) );
$this->title->mCascadeRestriction = true;
- $this->overrideUserPermissions( $this->user, "edit" );
+ $this->setUserPerm( "edit" );
$this->assertEquals( false,
$this->title->quickUserCan( 'bogus', $this->user ) );
$this->assertEquals( false,
$this->title->getUserPermissionsErrors( 'edit',
$this->user ) );
- $this->overrideUserPermissions( $this->user, [ "edit", "editprotected" ] );
+ $this->setUserPerm( [ "edit", "editprotected" ] );
$this->assertEquals( false,
$this->title->quickUserCan( 'bogus', $this->user ) );
$this->assertEquals( false,
*/
public function testCascadingSourcesRestrictions() {
$this->setTitle( NS_MAIN, "test page" );
- $this->overrideUserPermissions( $this->user, [ "edit", "bogus" ] );
+ $this->setUserPerm( [ "edit", "bogus" ] );
$this->title->mCascadeSources = [
Title::makeTitle( NS_MAIN, "Bogus" ),
* @covers \MediaWiki\Permissions\PermissionManager::checkActionPermissions
*/
public function testActionPermissions() {
- $this->overrideUserPermissions( $this->user, [ "createpage" ] );
+ $this->setUserPerm( [ "createpage" ] );
$this->setTitle( NS_MAIN, "test page" );
$this->title->mTitleProtection['permission'] = '';
$this->title->mTitleProtection['user'] = $this->user->getId();
$this->title->userCan( 'create', $this->user ) );
$this->title->mTitleProtection['permission'] = 'editprotected';
- $this->overrideUserPermissions( $this->user, [ 'createpage', 'protect' ] );
+ $this->setUserPerm( [ 'createpage', 'protect' ] );
$this->assertEquals( [ [ 'titleprotected', 'Useruser', 'test' ] ],
$this->title->getUserPermissionsErrors( 'create', $this->user ) );
$this->assertEquals( false,
$this->title->userCan( 'create', $this->user ) );
- $this->overrideUserPermissions( $this->user, [ 'createpage', 'editprotected' ] );
+ $this->setUserPerm( [ 'createpage', 'editprotected' ] );
$this->assertEquals( [],
$this->title->getUserPermissionsErrors( 'create', $this->user ) );
$this->assertEquals( true,
$this->title->userCan( 'create', $this->user ) );
- $this->overrideUserPermissions( $this->user, [ 'createpage' ] );
+ $this->setUserPerm( [ 'createpage' ] );
$this->assertEquals( [ [ 'titleprotected', 'Useruser', 'test' ] ],
$this->title->getUserPermissionsErrors( 'create', $this->user ) );
$this->assertEquals( false,
$this->title->userCan( 'create', $this->user ) );
$this->setTitle( NS_MEDIA, "test page" );
- $this->overrideUserPermissions( $this->user, [ "move" ] );
+ $this->setUserPerm( [ "move" ] );
$this->assertEquals( false,
$this->title->userCan( 'move', $this->user ) );
$this->assertEquals( [ [ 'immobile-source-namespace', 'Media' ] ],
] );
$this->overrideMwServices();
- $this->overrideUserPermissions(
- $this->user,
- [ 'createpage', 'edit', 'move', 'rollback', 'patrol', 'upload', 'purge' ]
- );
+ $this->setUserPerm( [ 'createpage', 'edit', 'move', 'rollback', 'patrol', 'upload', 'purge' ] );
$this->setTitle( NS_HELP, "test page" );
# $wgEmailConfirmToEdit only applies to 'edit' action
$this->setMwGlobals( 'wgEmailConfirmToEdit', false );
$this->overrideMwServices();
- $this->overrideUserPermissions(
- $this->user,
- [ 'createpage', 'edit', 'move', 'rollback', 'patrol', 'upload', 'purge' ]
- );
$this->assertNotContains( [ 'confirmedittext' ],
$this->title->getUserPermissionsErrors( 'edit', $this->user ) );