wiki.techinc.nl/tests/phpunit/includes/TemplateCategoriesTest.php
Vedmaka dd6b94024c Re-apply: Factors out permissions check from User into PermissionManager service
Was reverted by I549810a4cd2e424cc4a438887d2f24614a24cc00 due to
T224607.

Original change by  Vedmaka Wakalaka was
Ia0d840b772ea5f20c9594ce151cc57adc270e48b.

Original commit message:

The following methods should are factored out of the User class into PermissionManager,
leaving only deprecated stubs:

- User::isAllowed -> PermissionManager::userHasRight
- User::getRights -> PermissionManager::getUserPermissions
- User::groupHasPermission -> PermissionManager::groupHasPermission
- User::getGroupPermissions -> PermissionManager::getGroupPermissions
 -User::getGroupsWithPermission -> PermissionManager::getGroupsWithPermission
- User::groupHasPermission -> PermissionManager::groupHasPermission
- User::isEveryoneAllowed -> PermissionManager::isEveryoneAllowed
- User::getAllRights -> PermissionManager::getAllPermissions

Depends-On: I7909e9bd6bbfbd708c0a00b861a9b22a38c6665d

Bug: T218558
Bug: T223294
Change-Id: I8899240378f636ea70f447616710516c0a3c5c31
2019-06-28 13:19:38 -07:00

98 lines
2.5 KiB
PHP

<?php
require __DIR__ . "/../../../maintenance/runJobs.php";
/**
* @group Database
*/
class TemplateCategoriesTest extends MediaWikiLangTestCase {
/**
* Broken per T165099.
*
* @group Broken
* @covers Title::getParentCategories
*/
public function testTemplateCategories() {
$user = new User();
$this->overrideUserPermissions( $user, [ 'createpage', 'edit', 'purge', 'delete' ] );
$title = Title::newFromText( "Categorized from template" );
$page = WikiPage::factory( $title );
$page->doEditContent(
new WikitextContent( '{{Categorising template}}' ),
'Create a page with a template',
0,
false,
$user
);
$this->assertEquals(
[],
$title->getParentCategories(),
'Verify that the category doesn\'t contain the page before the template is created'
);
// Create template
$template = WikiPage::factory( Title::newFromText( 'Template:Categorising template' ) );
$template->doEditContent(
new WikitextContent( '[[Category:Solved bugs]]' ),
'Add a category through a template',
0,
false,
$user
);
// Run the job queue
JobQueueGroup::destroySingletons();
$jobs = new RunJobs;
$jobs->loadParamsAndArgs( null, [ 'quiet' => true ], null );
$jobs->execute();
// Make sure page is in the category
$this->assertEquals(
[ 'Category:Solved_bugs' => $title->getPrefixedText() ],
$title->getParentCategories(),
'Verify that the page is in the category after the template is created'
);
// Edit the template
$template->doEditContent(
new WikitextContent( '[[Category:Solved bugs 2]]' ),
'Change the category added by the template',
0,
false,
$user
);
// Run the job queue
JobQueueGroup::destroySingletons();
$jobs = new RunJobs;
$jobs->loadParamsAndArgs( null, [ 'quiet' => true ], null );
$jobs->execute();
// Make sure page is in the right category
$this->assertEquals(
[ 'Category:Solved_bugs_2' => $title->getPrefixedText() ],
$title->getParentCategories(),
'Verify that the page is in the right category after the template is edited'
);
// Now delete the template
$error = '';
$template->doDeleteArticleReal( 'Delete the template', false, 0, true, $error, $user );
// Run the job queue
JobQueueGroup::destroySingletons();
$jobs = new RunJobs;
$jobs->loadParamsAndArgs( null, [ 'quiet' => true ], null );
$jobs->execute();
// Make sure the page is no longer in the category
$this->assertEquals(
[],
$title->getParentCategories(),
'Verify that the page is no longer in the category after template deletion'
);
}
}