moveSubpages wasn't officially deprecated at all before this release, but there were no callers in codesearch outside core, so it should be safe to hard-deprecate. Bug: T208775 Change-Id: Icea9f1dc45d8bd8c96cc159d631f18c394aab4b7
174 lines
5.2 KiB
PHP
174 lines
5.2 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group Database
|
|
*/
|
|
class MovePageTest extends MediaWikiTestCase {
|
|
|
|
public function setUp() {
|
|
parent::setUp();
|
|
$this->tablesUsed[] = 'page';
|
|
$this->tablesUsed[] = 'revision';
|
|
$this->tablesUsed[] = 'comment';
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideIsValidMove
|
|
* @covers MovePage::isValidMove
|
|
* @covers MovePage::isValidFileMove
|
|
*/
|
|
public function testIsValidMove( $old, $new, $error ) {
|
|
$this->setMwGlobals( 'wgContentHandlerUseDB', false );
|
|
$mp = new MovePage(
|
|
Title::newFromText( $old ),
|
|
Title::newFromText( $new )
|
|
);
|
|
$status = $mp->isValidMove();
|
|
if ( $error === true ) {
|
|
$this->assertTrue( $status->isGood() );
|
|
} else {
|
|
$this->assertTrue( $status->hasMessage( $error ) );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* This should be kept in sync with TitleTest::provideTestIsValidMoveOperation
|
|
*/
|
|
public static function provideIsValidMove() {
|
|
return [
|
|
// for MovePage::isValidMove
|
|
[ 'Test', 'Test', 'selfmove' ],
|
|
[ 'Special:FooBar', 'Test', 'immobile-source-namespace' ],
|
|
[ 'Test', 'Special:FooBar', 'immobile-target-namespace' ],
|
|
[ 'MediaWiki:Common.js', 'Help:Some wikitext page', 'bad-target-model' ],
|
|
[ 'Page', 'File:Test.jpg', 'nonfile-cannot-move-to-file' ],
|
|
// for MovePage::isValidFileMove
|
|
[ 'File:Test.jpg', 'Page', 'imagenocrossnamespace' ],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Test for the move operation being aborted via the TitleMove hook
|
|
* @covers MovePage::move
|
|
*/
|
|
public function testMoveAbortedByTitleMoveHook() {
|
|
$error = 'Preventing move operation with TitleMove hook.';
|
|
$this->setTemporaryHook( 'TitleMove',
|
|
function ( $old, $new, $user, $reason, $status ) use ( $error ) {
|
|
$status->fatal( $error );
|
|
}
|
|
);
|
|
|
|
$oldTitle = Title::newFromText( 'Some old title' );
|
|
WikiPage::factory( $oldTitle )->doEditContent( new WikitextContent( 'foo' ), 'bar' );
|
|
$newTitle = Title::newFromText( 'A brand new title' );
|
|
$mp = new MovePage( $oldTitle, $newTitle );
|
|
$user = User::newFromName( 'TitleMove tester' );
|
|
$status = $mp->move( $user, 'Reason', true );
|
|
$this->assertTrue( $status->hasMessage( $error ) );
|
|
}
|
|
|
|
/**
|
|
* Test moving subpages from one page to another
|
|
* @covers MovePage::moveSubpages
|
|
*/
|
|
public function testMoveSubpages() {
|
|
$name = ucfirst( __FUNCTION__ );
|
|
|
|
$subPages = [ "Talk:$name/1", "Talk:$name/2" ];
|
|
$ids = [];
|
|
$pages = [
|
|
$name,
|
|
"Talk:$name",
|
|
"$name 2",
|
|
"Talk:$name 2",
|
|
];
|
|
foreach ( array_merge( $pages, $subPages ) as $page ) {
|
|
$ids[$page] = $this->createPage( $page );
|
|
}
|
|
|
|
$oldTitle = Title::newFromText( "Talk:$name" );
|
|
$newTitle = Title::newFromText( "Talk:$name 2" );
|
|
$mp = new MovePage( $oldTitle, $newTitle );
|
|
$status = $mp->moveSubpages( $this->getTestUser()->getUser(), 'Reason', true );
|
|
|
|
$this->assertTrue( $status->isGood(),
|
|
"Moving subpages from Talk:{$name} to Talk:{$name} 2 was not completely successful." );
|
|
foreach ( $subPages as $page ) {
|
|
$this->assertMoved( $page, str_replace( $name, "$name 2", $page ), $ids[$page] );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Test moving subpages from one page to another
|
|
* @covers MovePage::moveSubpagesIfAllowed
|
|
*/
|
|
public function testMoveSubpagesIfAllowed() {
|
|
$name = ucfirst( __FUNCTION__ );
|
|
|
|
$subPages = [ "Talk:$name/1", "Talk:$name/2" ];
|
|
$ids = [];
|
|
$pages = [
|
|
$name,
|
|
"Talk:$name",
|
|
"$name 2",
|
|
"Talk:$name 2",
|
|
];
|
|
foreach ( array_merge( $pages, $subPages ) as $page ) {
|
|
$ids[$page] = $this->createPage( $page );
|
|
}
|
|
|
|
$oldTitle = Title::newFromText( "Talk:$name" );
|
|
$newTitle = Title::newFromText( "Talk:$name 2" );
|
|
$mp = new MovePage( $oldTitle, $newTitle );
|
|
$status = $mp->moveSubpagesIfAllowed( $this->getTestUser()->getUser(), 'Reason', true );
|
|
|
|
$this->assertTrue( $status->isGood(),
|
|
"Moving subpages from Talk:{$name} to Talk:{$name} 2 was not completely successful." );
|
|
foreach ( $subPages as $page ) {
|
|
$this->assertMoved( $page, str_replace( $name, "$name 2", $page ), $ids[$page] );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Shortcut function to create a page and return its id.
|
|
*
|
|
* @param string $name Page to create
|
|
* @return int ID of created page
|
|
*/
|
|
protected function createPage( $name ) {
|
|
return $this->editPage( $name, 'Content' )->value['revision']->getPage();
|
|
}
|
|
|
|
/**
|
|
* @param string $from Prefixed name of source
|
|
* @param string $to Prefixed name of destination
|
|
* @param string $id Page id of the page to move
|
|
* @param array|string|null $opts Options: 'noredirect' to expect no redirect
|
|
*/
|
|
protected function assertMoved( $from, $to, $id, $opts = null ) {
|
|
$opts = (array)$opts;
|
|
|
|
Title::clearCaches();
|
|
$fromTitle = Title::newFromText( $from );
|
|
$toTitle = Title::newFromText( $to );
|
|
|
|
$this->assertTrue( $toTitle->exists(),
|
|
"Destination {$toTitle->getPrefixedText()} does not exist" );
|
|
|
|
if ( in_array( 'noredirect', $opts ) ) {
|
|
$this->assertFalse( $fromTitle->exists(),
|
|
"Source {$fromTitle->getPrefixedText()} exists" );
|
|
} else {
|
|
$this->assertTrue( $fromTitle->exists(),
|
|
"Source {$fromTitle->getPrefixedText()} does not exist" );
|
|
$this->assertTrue( $fromTitle->isRedirect(),
|
|
"Source {$fromTitle->getPrefixedText()} is not a redirect" );
|
|
|
|
$target = Revision::newFromTitle( $fromTitle )->getContent()->getRedirectTarget();
|
|
$this->assertSame( $toTitle->getPrefixedText(), $target->getPrefixedText() );
|
|
}
|
|
|
|
$this->assertSame( $id, $toTitle->getArticleID() );
|
|
}
|
|
}
|