wiki.techinc.nl/tests/phpunit/unit/includes/page/PageCommandFactoryTest.php
Daimona Eaytoy 249306e112 Add perm checks to UndeletePage and make it a real service
Add entry in MediaWikiServices, add wiring code, inject all dependencies.

Also add an alternative entry point with permission checks, like for
DeletePage.

The new service is no longer @unstable, and the relevant methods in
PageArchive were deprecated.

Bug: T290021
Change-Id: I452a98679f5bfea3f7367aacd5c930acffd32102
2021-10-04 20:25:49 +00:00

123 lines
3.1 KiB
PHP

<?php
namespace MediaWiki\Tests\Unit\Page;
use ContentModelChange;
use HashConfig;
use MediaWiki\Page\DeletePage;
use MediaWiki\Page\PageCommandFactory;
use MediaWiki\Page\PageIdentity;
use MediaWiki\Page\PageIdentityValue;
use MediaWiki\Page\ProperPageIdentity;
use MediaWiki\Page\RollbackPage;
use MediaWiki\Page\UndeletePage;
use MediaWiki\Permissions\Authority;
use MediaWiki\Tests\Unit\MockServiceDependenciesTrait;
use MediaWiki\User\UserIdentity;
use MediaWikiUnitTestCase;
use MergeHistory;
use MovePage;
use Title;
use WikiPage;
/**
* @covers \MediaWiki\Page\PageCommandFactory
* @author DannyS712
*/
class PageCommandFactoryTest extends MediaWikiUnitTestCase {
use MockServiceDependenciesTrait;
private function getFactory(): PageCommandFactory {
// Create a PageCommandFactory with all of the services needed
$config = new HashConfig( [
// RollbackPage
'UseRCPatrol' => true,
'DisableAnonTalk' => false,
// MovePage
'CategoryCollation' => 'uppercase',
'MaximumMovedPages' => 100,
// DeletePage
'DeleteRevisionsBatchSize' => 10,
'ActorTableSchemaMigrationStage' => SCHEMA_COMPAT_NEW,
'DeleteRevisionsLimit' => 10,
] );
// Helper method from MockServiceDependenciesTrait
return $this->newServiceInstance(
PageCommandFactory::class,
[
'config' => $config,
]
);
}
public function testContentModelChange() {
$contentModelChange = $this->getFactory()->newContentModelChange(
$this->createMock( Authority::class ),
$this->createMock( WikiPage::class ),
CONTENT_MODEL_TEXT
);
$this->assertInstanceOf(
ContentModelChange::class,
$contentModelChange,
'Creating ContentModelChange works'
);
}
public function testDeletePage() {
$page = $this->createMock( ProperPageIdentity::class );
$page->method( 'canExist' )->willReturn( true );
$this->assertInstanceOf(
DeletePage::class,
$this->getFactory()->newDeletePage( $page, $this->createMock( Authority::class ) )
);
}
public function testMergeHistory() {
$mergeHistory = $this->getFactory()->newMergeHistory(
PageIdentityValue::localIdentity( 1, NS_MAIN, 'Source' ),
PageIdentityValue::localIdentity( 2, NS_MAIN, 'Dest' ),
null // $timestamp
);
$this->assertInstanceOf(
MergeHistory::class,
$mergeHistory,
'Creating MergeHistory works'
);
}
public function testMovePage() {
$movePage = $this->getFactory()->newMovePage(
$this->createNoOpMock( Title::class ),
$this->createNoOpMock( Title::class )
);
$this->assertInstanceOf(
MovePage::class,
$movePage,
'Creating MovePage works'
);
}
public function testRollbackPage() {
$rollbackPage = $this->getFactory()->newRollbackPage(
$this->createMock( PageIdentity::class ),
$this->createMock( Authority::class ),
$this->createMock( UserIdentity::class )
);
$this->assertInstanceOf(
RollbackPage::class,
$rollbackPage,
'Creating RollbackPage works'
);
}
public function testUndeletePage() {
$undeletePage = $this->getFactory()->newUndeletePage(
$this->createMock( ProperPageIdentity::class ),
$this->createMock( Authority::class )
);
$this->assertInstanceOf( UndeletePage::class, $undeletePage );
}
}