Merge "DatabaseMssql: Don't duplicate body of makeList()"
[mediawiki.git] / tests / phpunit / includes / MovePageTest.php
blob9501e452ec9aa1c458368c2864257a6aba1de639
1 <?php
3 /**
4 * @group Database
5 */
6 class MovePageTest extends MediaWikiTestCase {
8 /**
9 * @dataProvider provideIsValidMove
10 * @covers MovePage::isValidMove
11 * @covers MovePage::isValidFileMove
13 public function testIsValidMove( $old, $new, $error ) {
14 $this->setMwGlobals( 'wgContentHandlerUseDB', false );
15 $mp = new MovePage(
16 Title::newFromText( $old ),
17 Title::newFromText( $new )
19 $status = $mp->isValidMove();
20 if ( $error === true ) {
21 $this->assertTrue( $status->isGood() );
22 } else {
23 $this->assertTrue( $status->hasMessage( $error ) );
27 /**
28 * This should be kept in sync with TitleTest::provideTestIsValidMoveOperation
30 public static function provideIsValidMove() {
31 return array(
32 // for MovePage::isValidMove
33 array( 'Test', 'Test', 'selfmove' ),
34 array( 'Special:FooBar', 'Test', 'immobile-source-namespace' ),
35 array( 'Test', 'Special:FooBar', 'immobile-target-namespace' ),
36 array( 'MediaWiki:Common.js', 'Help:Some wikitext page', 'bad-target-model' ),
37 array( 'Page', 'File:Test.jpg', 'nonfile-cannot-move-to-file' ),
38 // for MovePage::isValidFileMove
39 array( 'File:Test.jpg', 'Page', 'imagenocrossnamespace' ),
43 /**
44 * Integration test to catch regressions like T74870. Taken and modified
45 * from SemanticMediaWiki
47 public function testTitleMoveCompleteIntegrationTest() {
48 $oldTitle = Title::newFromText( 'Help:Some title' );
49 WikiPage::factory( $oldTitle )->doEditContent( new WikitextContent( 'foo' ), 'bar' );
50 $newTitle = Title::newFromText( 'Help:Some other title' );
51 $this->assertNull(
52 WikiPage::factory( $newTitle )->getRevision()
55 $this->assertTrue( $oldTitle->moveTo( $newTitle, false, 'test1', true ) );
56 $this->assertNotNull(
57 WikiPage::factory( $oldTitle )->getRevision()
59 $this->assertNotNull(
60 WikiPage::factory( $newTitle)->getRevision()