3 abstract class WikiPageDbTestBase
extends MediaWikiLangTestCase
{
5 private $pagesToDelete;
7 public function __construct( $name = null, array $data = [], $dataName = '' ) {
8 parent
::__construct( $name, $data, $dataName );
10 $this->tablesUsed
= array_merge(
31 protected function setUp() {
33 $this->setMwGlobals( 'wgContentHandlerUseDB', $this->getContentHandlerUseDB() );
34 $this->pagesToDelete
= [];
37 protected function tearDown() {
38 foreach ( $this->pagesToDelete
as $p ) {
39 /* @var $p WikiPage */
43 $p->doDeleteArticle( "testing done." );
45 } catch ( MWException
$ex ) {
52 abstract protected function getContentHandlerUseDB();
55 * @param Title|string $title
56 * @param string|null $model
59 private function newPage( $title, $model = null ) {
60 if ( is_string( $title ) ) {
61 $ns = $this->getDefaultWikitextNS();
62 $title = Title
::newFromText( $title, $ns );
65 $p = new WikiPage( $title );
67 $this->pagesToDelete
[] = $p;
73 * @param string|Title|WikiPage $page
79 protected function createPage( $page, $text, $model = null ) {
80 if ( is_string( $page ) ||
$page instanceof Title
) {
81 $page = $this->newPage( $page, $model );
84 $content = ContentHandler
::makeContent( $text, $page->getTitle(), $model );
85 $page->doEditContent( $content, "testing", EDIT_NEW
);
91 * @covers WikiPage::doEditContent
92 * @covers WikiPage::doModify
93 * @covers WikiPage::doCreate
94 * @covers WikiPage::doEditUpdates
96 public function testDoEditContent() {
97 $page = $this->newPage( __METHOD__
);
98 $title = $page->getTitle();
100 $content = ContentHandler
::makeContent(
101 "[[Lorem ipsum]] dolor sit amet, consetetur sadipscing elitr, sed diam "
102 . " nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat.",
104 CONTENT_MODEL_WIKITEXT
107 $page->doEditContent( $content, "[[testing]] 1" );
109 $this->assertTrue( $title->getArticleID() > 0, "Title object should have new page id" );
110 $this->assertTrue( $page->getId() > 0, "WikiPage should have new page id" );
111 $this->assertTrue( $title->exists(), "Title object should indicate that the page now exists" );
112 $this->assertTrue( $page->exists(), "WikiPage object should indicate that the page now exists" );
114 $id = $page->getId();
116 # ------------------------
117 $dbr = wfGetDB( DB_REPLICA
);
118 $res = $dbr->select( 'pagelinks', '*', [ 'pl_from' => $id ] );
119 $n = $res->numRows();
122 $this->assertEquals( 1, $n, 'pagelinks should contain one link from the page' );
124 # ------------------------
125 $page = new WikiPage( $title );
127 $retrieved = $page->getContent();
128 $this->assertTrue( $content->equals( $retrieved ), 'retrieved content doesn\'t equal original' );
130 # ------------------------
131 $content = ContentHandler
::makeContent(
132 "At vero eos et accusam et justo duo [[dolores]] et ea rebum. "
133 . "Stet clita kasd [[gubergren]], no sea takimata sanctus est.",
135 CONTENT_MODEL_WIKITEXT
138 $page->doEditContent( $content, "testing 2" );
140 # ------------------------
141 $page = new WikiPage( $title );
143 $retrieved = $page->getContent();
144 $this->assertTrue( $content->equals( $retrieved ), 'retrieved content doesn\'t equal original' );
146 # ------------------------
147 $dbr = wfGetDB( DB_REPLICA
);
148 $res = $dbr->select( 'pagelinks', '*', [ 'pl_from' => $id ] );
149 $n = $res->numRows();
152 $this->assertEquals( 2, $n, 'pagelinks should contain two links from the page' );
156 * @covers WikiPage::doDeleteArticle
157 * @covers WikiPage::doDeleteArticleReal
159 public function testDoDeleteArticle() {
160 $page = $this->createPage(
162 "[[original text]] foo",
163 CONTENT_MODEL_WIKITEXT
165 $id = $page->getId();
167 $page->doDeleteArticle( "testing deletion" );
170 $page->getTitle()->getArticleID() > 0,
171 "Title object should now have page id 0"
173 $this->assertFalse( $page->getId() > 0, "WikiPage should now have page id 0" );
176 "WikiPage::exists should return false after page was deleted"
180 "WikiPage::getContent should return null after page was deleted"
183 $t = Title
::newFromText( $page->getTitle()->getPrefixedText() );
186 "Title::exists should return false after page was deleted"
190 JobQueueGroup
::destroySingletons();
192 $jobs->loadParamsAndArgs( null, [ 'quiet' => true ], null );
195 # ------------------------
196 $dbr = wfGetDB( DB_REPLICA
);
197 $res = $dbr->select( 'pagelinks', '*', [ 'pl_from' => $id ] );
198 $n = $res->numRows();
201 $this->assertEquals( 0, $n, 'pagelinks should contain no more links from the page' );
205 * @covers WikiPage::doDeleteUpdates
207 public function testDoDeleteUpdates() {
208 $page = $this->createPage(
210 "[[original text]] foo",
211 CONTENT_MODEL_WIKITEXT
213 $id = $page->getId();
215 // Similar to MovePage logic
216 wfGetDB( DB_MASTER
)->delete( 'page', [ 'page_id' => $id ], __METHOD__
);
217 $page->doDeleteUpdates( $id );
220 JobQueueGroup
::destroySingletons();
222 $jobs->loadParamsAndArgs( null, [ 'quiet' => true ], null );
225 # ------------------------
226 $dbr = wfGetDB( DB_REPLICA
);
227 $res = $dbr->select( 'pagelinks', '*', [ 'pl_from' => $id ] );
228 $n = $res->numRows();
231 $this->assertEquals( 0, $n, 'pagelinks should contain no more links from the page' );
235 * @covers WikiPage::getRevision
237 public function testGetRevision() {
238 $page = $this->newPage( __METHOD__
);
240 $rev = $page->getRevision();
241 $this->assertNull( $rev );
244 $this->createPage( $page, "some text", CONTENT_MODEL_WIKITEXT
);
246 $rev = $page->getRevision();
248 $this->assertEquals( $page->getLatest(), $rev->getId() );
249 $this->assertEquals( "some text", $rev->getContent()->getNativeData() );
253 * @covers WikiPage::getContent
255 public function testGetContent() {
256 $page = $this->newPage( __METHOD__
);
258 $content = $page->getContent();
259 $this->assertNull( $content );
262 $this->createPage( $page, "some text", CONTENT_MODEL_WIKITEXT
);
264 $content = $page->getContent();
265 $this->assertEquals( "some text", $content->getNativeData() );
269 * @covers WikiPage::exists
271 public function testExists() {
272 $page = $this->newPage( __METHOD__
);
273 $this->assertFalse( $page->exists() );
276 $this->createPage( $page, "some text", CONTENT_MODEL_WIKITEXT
);
277 $this->assertTrue( $page->exists() );
279 $page = new WikiPage( $page->getTitle() );
280 $this->assertTrue( $page->exists() );
283 $page->doDeleteArticle( "done testing" );
284 $this->assertFalse( $page->exists() );
286 $page = new WikiPage( $page->getTitle() );
287 $this->assertFalse( $page->exists() );
290 public function provideHasViewableContent() {
292 [ 'WikiPageTest_testHasViewableContent', false, true ],
293 [ 'Special:WikiPageTest_testHasViewableContent', false ],
294 [ 'MediaWiki:WikiPageTest_testHasViewableContent', false ],
295 [ 'Special:Userlogin', true ],
296 [ 'MediaWiki:help', true ],
301 * @dataProvider provideHasViewableContent
302 * @covers WikiPage::hasViewableContent
304 public function testHasViewableContent( $title, $viewable, $create = false ) {
305 $page = $this->newPage( $title );
306 $this->assertEquals( $viewable, $page->hasViewableContent() );
309 $this->createPage( $page, "some text", CONTENT_MODEL_WIKITEXT
);
310 $this->assertTrue( $page->hasViewableContent() );
312 $page = new WikiPage( $page->getTitle() );
313 $this->assertTrue( $page->hasViewableContent() );
317 public function provideGetRedirectTarget() {
319 [ 'WikiPageTest_testGetRedirectTarget_1', CONTENT_MODEL_WIKITEXT
, "hello world", null ],
321 'WikiPageTest_testGetRedirectTarget_2',
322 CONTENT_MODEL_WIKITEXT
,
323 "#REDIRECT [[hello world]]",
330 * @dataProvider provideGetRedirectTarget
331 * @covers WikiPage::getRedirectTarget
333 public function testGetRedirectTarget( $title, $model, $text, $target ) {
334 $this->setMwGlobals( [
335 'wgCapitalLinks' => true,
338 $page = $this->createPage( $title, $text, $model );
340 # sanity check, because this test seems to fail for no reason for some people.
341 $c = $page->getContent();
342 $this->assertEquals( 'WikitextContent', get_class( $c ) );
344 # now, test the actual redirect
345 $t = $page->getRedirectTarget();
346 $this->assertEquals( $target, is_null( $t ) ?
null : $t->getPrefixedText() );
350 * @dataProvider provideGetRedirectTarget
351 * @covers WikiPage::isRedirect
353 public function testIsRedirect( $title, $model, $text, $target ) {
354 $page = $this->createPage( $title, $text, $model );
355 $this->assertEquals( !is_null( $target ), $page->isRedirect() );
358 public function provideIsCountable() {
362 [ 'WikiPageTest_testIsCountable',
363 CONTENT_MODEL_WIKITEXT
,
368 [ 'WikiPageTest_testIsCountable',
369 CONTENT_MODEL_WIKITEXT
,
376 [ 'WikiPageTest_testIsCountable',
377 CONTENT_MODEL_WIKITEXT
,
382 [ 'WikiPageTest_testIsCountable',
383 CONTENT_MODEL_WIKITEXT
,
390 [ 'WikiPageTest_testIsCountable',
391 CONTENT_MODEL_WIKITEXT
,
396 [ 'WikiPageTest_testIsCountable',
397 CONTENT_MODEL_WIKITEXT
,
404 [ 'WikiPageTest_testIsCountable',
405 CONTENT_MODEL_WIKITEXT
,
410 [ 'WikiPageTest_testIsCountable',
411 CONTENT_MODEL_WIKITEXT
,
416 [ 'WikiPageTest_testIsCountable',
417 CONTENT_MODEL_WIKITEXT
,
423 // not a content namespace
424 [ 'Talk:WikiPageTest_testIsCountable',
425 CONTENT_MODEL_WIKITEXT
,
430 [ 'Talk:WikiPageTest_testIsCountable',
431 CONTENT_MODEL_WIKITEXT
,
436 [ 'Talk:WikiPageTest_testIsCountable',
437 CONTENT_MODEL_WIKITEXT
,
443 // not a content namespace, different model
444 [ 'MediaWiki:WikiPageTest_testIsCountable.js',
450 [ 'MediaWiki:WikiPageTest_testIsCountable.js',
456 [ 'MediaWiki:WikiPageTest_testIsCountable.js',
466 * @dataProvider provideIsCountable
467 * @covers WikiPage::isCountable
469 public function testIsCountable( $title, $model, $text, $mode, $expected ) {
470 global $wgContentHandlerUseDB;
472 $this->setMwGlobals( 'wgArticleCountMethod', $mode );
474 $title = Title
::newFromText( $title );
476 if ( !$wgContentHandlerUseDB
478 && ContentHandler
::getDefaultModelFor( $title ) != $model
480 $this->markTestSkipped( "Can not use non-default content model $model for "
481 . $title->getPrefixedDBkey() . " with \$wgContentHandlerUseDB disabled." );
484 $page = $this->createPage( $title, $text, $model );
486 $editInfo = $page->prepareContentForEdit( $page->getContent() );
488 $v = $page->isCountable();
489 $w = $page->isCountable( $editInfo );
494 "isCountable( null ) returned unexpected value " . var_export( $v, true )
495 . " instead of " . var_export( $expected, true )
496 . " in mode `$mode` for text \"$text\""
502 "isCountable( \$editInfo ) returned unexpected value " . var_export( $v, true )
503 . " instead of " . var_export( $expected, true )
504 . " in mode `$mode` for text \"$text\""
508 public function provideGetParserOutput() {
511 CONTENT_MODEL_WIKITEXT
,
513 "<div class=\"mw-parser-output\"><p>hello <i>world</i></p></div>"
520 * @dataProvider provideGetParserOutput
521 * @covers WikiPage::getParserOutput
523 public function testGetParserOutput( $model, $text, $expectedHtml ) {
524 $page = $this->createPage( __METHOD__
, $text, $model );
526 $opt = $page->makeParserOptions( 'canonical' );
527 $po = $page->getParserOutput( $opt );
528 $text = $po->getText();
530 $text = trim( preg_replace( '/<!--.*?-->/sm', '', $text ) ); # strip injected comments
531 $text = preg_replace( '!\s*(</p>|</div>)!sm', '\1', $text ); # don't let tidy confuse us
533 $this->assertEquals( $expectedHtml, $text );
539 * @covers WikiPage::getParserOutput
541 public function testGetParserOutput_nonexisting() {
542 $page = new WikiPage( Title
::newFromText( __METHOD__
) );
544 $opt = new ParserOptions();
545 $po = $page->getParserOutput( $opt );
547 $this->assertFalse( $po, "getParserOutput() shall return false for non-existing pages." );
551 * @covers WikiPage::getParserOutput
553 public function testGetParserOutput_badrev() {
554 $page = $this->createPage( __METHOD__
, 'dummy', CONTENT_MODEL_WIKITEXT
);
556 $opt = new ParserOptions();
557 $po = $page->getParserOutput( $opt, $page->getLatest() +
1234 );
559 // @todo would be neat to also test deleted revision
561 $this->assertFalse( $po, "getParserOutput() shall return false for non-existing revisions." );
564 public static $sections =
578 public function dataReplaceSection() {
579 // NOTE: assume the Help namespace to contain wikitext
581 [ 'Help:WikiPageTest_testReplaceSection',
582 CONTENT_MODEL_WIKITEXT
,
587 trim( preg_replace( '/^Intro/sm', 'No more', self
::$sections ) )
589 [ 'Help:WikiPageTest_testReplaceSection',
590 CONTENT_MODEL_WIKITEXT
,
597 [ 'Help:WikiPageTest_testReplaceSection',
598 CONTENT_MODEL_WIKITEXT
,
601 "== TEST ==\nmore fun",
603 trim( preg_replace( '/^== test ==.*== foo ==/sm',
604 "== TEST ==\nmore fun\n\n== foo ==",
607 [ 'Help:WikiPageTest_testReplaceSection',
608 CONTENT_MODEL_WIKITEXT
,
613 trim( self
::$sections )
615 [ 'Help:WikiPageTest_testReplaceSection',
616 CONTENT_MODEL_WIKITEXT
,
621 trim( self
::$sections ) . "\n\n== New ==\n\nNo more"
627 * @dataProvider dataReplaceSection
628 * @covers WikiPage::replaceSectionContent
630 public function testReplaceSectionContent( $title, $model, $text, $section,
631 $with, $sectionTitle, $expected
633 $page = $this->createPage( $title, $text, $model );
635 $content = ContentHandler
::makeContent( $with, $page->getTitle(), $page->getContentModel() );
636 $c = $page->replaceSectionContent( $section, $content, $sectionTitle );
638 $this->assertEquals( $expected, is_null( $c ) ?
null : trim( $c->getNativeData() ) );
642 * @dataProvider dataReplaceSection
643 * @covers WikiPage::replaceSectionAtRev
645 public function testReplaceSectionAtRev( $title, $model, $text, $section,
646 $with, $sectionTitle, $expected
648 $page = $this->createPage( $title, $text, $model );
649 $baseRevId = $page->getLatest();
651 $content = ContentHandler
::makeContent( $with, $page->getTitle(), $page->getContentModel() );
652 $c = $page->replaceSectionAtRev( $section, $content, $sectionTitle, $baseRevId );
654 $this->assertEquals( $expected, is_null( $c ) ?
null : trim( $c->getNativeData() ) );
658 * @covers WikiPage::getOldestRevision
660 public function testGetOldestRevision() {
661 $page = $this->newPage( __METHOD__
);
662 $page->doEditContent(
663 new WikitextContent( 'one' ),
667 $rev1 = $page->getRevision();
669 $page = new WikiPage( $page->getTitle() );
670 $page->doEditContent(
671 new WikitextContent( 'two' ),
676 $page = new WikiPage( $page->getTitle() );
677 $page->doEditContent(
678 new WikitextContent( 'three' ),
684 $this->assertNotEquals(
686 $page->getRevision()->getId(),
687 '$page->getRevision()->getId()'
693 $page->getOldestRevision()->getId(),
694 '$page->getOldestRevision()->getId()'
699 * @todo FIXME: this is a better rollback test than the one below, but it
700 * keeps failing in jenkins for some reason.
702 public function broken_testDoRollback() {
703 $admin = $this->getTestSysop()->getUser();
706 $page = $this->newPage( __METHOD__
);
707 $page->doEditContent( ContentHandler
::makeContent( $text, $page->getTitle() ),
708 "section one", EDIT_NEW
, false, $admin );
710 $user1 = $this->getTestUser()->getUser();
712 $page = new WikiPage( $page->getTitle() );
713 $page->doEditContent( ContentHandler
::makeContent( $text, $page->getTitle() ),
714 "adding section two", 0, false, $user1 );
716 $user2 = $this->getTestUser()->getUser();
717 $text .= "\n\nthree";
718 $page = new WikiPage( $page->getTitle() );
719 $page->doEditContent( ContentHandler
::makeContent( $text, $page->getTitle() ),
720 "adding section three", 0, false, $user2 );
722 # we are having issues with doRollback spuriously failing. Apparently
723 # the last revision somehow goes missing or not committed under some
724 # circumstances. So, make sure the last revision has the right user name.
725 $dbr = wfGetDB( DB_REPLICA
);
726 $this->assertEquals( 3, Revision
::countByPageId( $dbr, $page->getId() ) );
728 $page = new WikiPage( $page->getTitle() );
729 $rev3 = $page->getRevision();
730 $this->assertEquals( '127.0.2.13', $rev3->getUserText() );
732 $rev2 = $rev3->getPrevious();
733 $this->assertEquals( '127.0.1.11', $rev2->getUserText() );
735 $rev1 = $rev2->getPrevious();
736 $this->assertEquals( 'Admin', $rev1->getUserText() );
738 # now, try the actual rollback
739 $token = $admin->getEditToken(
740 [ $page->getTitle()->getPrefixedText(), $user2->getName() ],
743 $errors = $page->doRollback(
753 $this->fail( "Rollback failed:\n" . print_r( $errors, true )
754 . ";\n" . print_r( $details, true ) );
757 $page = new WikiPage( $page->getTitle() );
758 $this->assertEquals( $rev2->getSha1(), $page->getRevision()->getSha1(),
759 "rollback did not revert to the correct revision" );
760 $this->assertEquals( "one\n\ntwo", $page->getContent()->getNativeData() );
764 * @todo FIXME: the above rollback test is better, but it keeps failing in jenkins for some reason.
765 * @covers WikiPage::doRollback
766 * @covers WikiPage::commitRollback
768 public function testDoRollback() {
769 $admin = $this->getTestSysop()->getUser();
772 $page = $this->newPage( __METHOD__
);
773 $page->doEditContent(
774 ContentHandler
::makeContent( $text, $page->getTitle(), CONTENT_MODEL_WIKITEXT
),
780 $rev1 = $page->getRevision();
782 $user1 = $this->getTestUser()->getUser();
784 $page = new WikiPage( $page->getTitle() );
785 $page->doEditContent(
786 ContentHandler
::makeContent( $text, $page->getTitle(), CONTENT_MODEL_WIKITEXT
),
787 "adding section two",
793 # now, try the rollback
794 $token = $admin->getEditToken( 'rollback' );
795 $errors = $page->doRollback(
805 $this->fail( "Rollback failed:\n" . print_r( $errors, true )
806 . ";\n" . print_r( $details, true ) );
809 $page = new WikiPage( $page->getTitle() );
810 $this->assertEquals( $rev1->getSha1(), $page->getRevision()->getSha1(),
811 "rollback did not revert to the correct revision" );
812 $this->assertEquals( "one", $page->getContent()->getNativeData() );
816 * @covers WikiPage::doRollback
817 * @covers WikiPage::commitRollback
819 public function testDoRollbackFailureSameContent() {
820 $admin = $this->getTestSysop()->getUser();
823 $page = $this->newPage( __METHOD__
);
824 $page->doEditContent(
825 ContentHandler
::makeContent( $text, $page->getTitle(), CONTENT_MODEL_WIKITEXT
),
831 $rev1 = $page->getRevision();
833 $user1 = $this->getTestUser( [ 'sysop' ] )->getUser();
835 $page = new WikiPage( $page->getTitle() );
836 $page->doEditContent(
837 ContentHandler
::makeContent( $text, $page->getTitle(), CONTENT_MODEL_WIKITEXT
),
838 "adding section two",
844 # now, do a the rollback from the same user was doing the edit before
846 $token = $user1->getEditToken( 'rollback' );
847 $errors = $page->doRollback(
849 "testing revert same user",
856 $this->assertEquals( [], $errors, "Rollback failed same user" );
858 # now, try the rollback
860 $token = $admin->getEditToken( 'rollback' );
861 $errors = $page->doRollback(
880 "Rollback not failed"
883 $page = new WikiPage( $page->getTitle() );
884 $this->assertEquals( $rev1->getSha1(), $page->getRevision()->getSha1(),
885 "rollback did not revert to the correct revision" );
886 $this->assertEquals( "one", $page->getContent()->getNativeData() );
890 * Tests tagging for edits that do rollback action
891 * @covers WikiPage::doRollback
893 public function testDoRollbackTagging() {
894 if ( !in_array( 'mw-rollback', ChangeTags
::getSoftwareTags() ) ) {
895 $this->markTestSkipped( 'Rollback tag deactivated, skipped the test.' );
899 $admin->setName( 'Administrator' );
900 $admin->addToDatabase();
902 $text = 'First line';
903 $page = $this->newPage( 'WikiPageTest_testDoRollbackTagging' );
904 $page->doEditContent(
905 ContentHandler
::makeContent( $text, $page->getTitle(), CONTENT_MODEL_WIKITEXT
),
912 $secondUser = new User();
913 $secondUser->setName( '92.65.217.32' );
914 $text .= '\n\nSecond line';
915 $page = new WikiPage( $page->getTitle() );
916 $page->doEditContent(
917 ContentHandler
::makeContent( $text, $page->getTitle(), CONTENT_MODEL_WIKITEXT
),
918 'Adding second line',
924 // Now, try the rollback
925 $admin->addGroup( 'sysop' ); // Make the test user a sysop
926 $token = $admin->getEditToken( 'rollback' );
927 $errors = $page->doRollback(
928 $secondUser->getName(),
936 // If doRollback completed without errors
937 if ( $errors === [] ) {
938 $tags = $resultDetails[ 'tags' ];
939 $this->assertContains( 'mw-rollback', $tags );
943 public function provideGetAutoDeleteReason() {
953 [ "first edit", null ],
955 "/first edit.*only contributor/",
961 [ "first edit", null ],
962 [ "second edit", null ],
964 "/second edit.*only contributor/",
970 [ "first edit", "127.0.2.22" ],
971 [ "second edit", "127.0.3.33" ],
981 . "Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam "
982 . " nonumy eirmod tempor invidunt ut labore et dolore magna "
983 . "aliquyam erat, sed diam voluptua. At vero eos et accusam "
984 . "et justo duo dolores et ea rebum. Stet clita kasd gubergren, "
985 . "no sea takimata sanctus est Lorem ipsum dolor sit amet.'",
989 '/first edit:.*\.\.\."/',
995 [ "first edit", "127.0.2.22" ],
996 [ "", "127.0.3.33" ],
998 "/before blanking.*first edit/",
1006 * @dataProvider provideGetAutoDeleteReason
1007 * @covers WikiPage::getAutoDeleteReason
1009 public function testGetAutoDeleteReason( $edits, $expectedResult, $expectedHistory ) {
1012 // NOTE: assume Help namespace to contain wikitext
1013 $page = $this->newPage( "Help:WikiPageTest_testGetAutoDeleteReason" );
1017 foreach ( $edits as $edit ) {
1020 if ( !empty( $edit[1] ) ) {
1021 $user->setName( $edit[1] );
1026 $content = ContentHandler
::makeContent( $edit[0], $page->getTitle(), $page->getContentModel() );
1028 $page->doEditContent( $content, "test edit $c", $c < 2 ? EDIT_NEW
: 0, false, $user );
1033 $reason = $page->getAutoDeleteReason( $hasHistory );
1035 if ( is_bool( $expectedResult ) ||
is_null( $expectedResult ) ) {
1036 $this->assertEquals( $expectedResult, $reason );
1038 $this->assertTrue( (bool)preg_match( $expectedResult, $reason ),
1039 "Autosummary didn't match expected pattern $expectedResult: $reason" );
1042 $this->assertEquals( $expectedHistory, $hasHistory,
1043 "expected \$hasHistory to be " . var_export( $expectedHistory, true ) );
1045 $page->doDeleteArticle( "done" );
1048 public function providePreSaveTransform() {
1050 [ 'hello this is ~~~',
1051 "hello this is [[Special:Contributions/127.0.0.1|127.0.0.1]]",
1053 [ 'hello \'\'this\'\' is <nowiki>~~~</nowiki>',
1054 'hello \'\'this\'\' is <nowiki>~~~</nowiki>',
1060 * @covers WikiPage::factory
1062 public function testWikiPageFactory() {
1063 $title = Title
::makeTitle( NS_FILE
, 'Someimage.png' );
1064 $page = WikiPage
::factory( $title );
1065 $this->assertEquals( 'WikiFilePage', get_class( $page ) );
1067 $title = Title
::makeTitle( NS_CATEGORY
, 'SomeCategory' );
1068 $page = WikiPage
::factory( $title );
1069 $this->assertEquals( 'WikiCategoryPage', get_class( $page ) );
1071 $title = Title
::makeTitle( NS_MAIN
, 'SomePage' );
1072 $page = WikiPage
::factory( $title );
1073 $this->assertEquals( 'WikiPage', get_class( $page ) );
1077 * @dataProvider provideCommentMigrationOnDeletion
1079 * @param int $writeStage
1080 * @param int $readStage
1082 public function testCommentMigrationOnDeletion( $writeStage, $readStage ) {
1083 $this->setMwGlobals( 'wgCommentTableSchemaMigrationStage', $writeStage );
1084 $dbr = wfGetDB( DB_REPLICA
);
1086 $page = $this->createPage(
1089 CONTENT_MODEL_WIKITEXT
1091 $revid = $page->getLatest();
1092 if ( $writeStage > MIGRATION_OLD
) {
1093 $comment_id = $dbr->selectField(
1094 'revision_comment_temp',
1095 'revcomment_comment_id',
1096 [ 'revcomment_rev' => $revid ],
1101 $this->setMwGlobals( 'wgCommentTableSchemaMigrationStage', $readStage );
1103 $page->doDeleteArticle( "testing deletion" );
1105 if ( $readStage > MIGRATION_OLD
) {
1106 // Didn't leave behind any 'revision_comment_temp' rows
1107 $n = $dbr->selectField(
1108 'revision_comment_temp', 'COUNT(*)', [ 'revcomment_rev' => $revid ], __METHOD__
1110 $this->assertEquals( 0, $n, 'no entry in revision_comment_temp after deletion' );
1112 // Copied or upgraded the comment_id, as applicable
1113 $ar_comment_id = $dbr->selectField(
1116 [ 'ar_rev_id' => $revid ],
1119 if ( $writeStage > MIGRATION_OLD
) {
1120 $this->assertSame( $comment_id, $ar_comment_id );
1122 $this->assertNotEquals( 0, $ar_comment_id );
1126 // Copied rev_comment, if applicable
1127 if ( $readStage <= MIGRATION_WRITE_BOTH
&& $writeStage <= MIGRATION_WRITE_BOTH
) {
1128 $ar_comment = $dbr->selectField(
1131 [ 'ar_rev_id' => $revid ],
1134 $this->assertSame( 'testing', $ar_comment );
1138 public function provideCommentMigrationOnDeletion() {
1140 [ MIGRATION_OLD
, MIGRATION_OLD
],
1141 [ MIGRATION_OLD
, MIGRATION_WRITE_BOTH
],
1142 [ MIGRATION_OLD
, MIGRATION_WRITE_NEW
],
1143 [ MIGRATION_WRITE_BOTH
, MIGRATION_OLD
],
1144 [ MIGRATION_WRITE_BOTH
, MIGRATION_WRITE_BOTH
],
1145 [ MIGRATION_WRITE_BOTH
, MIGRATION_WRITE_NEW
],
1146 [ MIGRATION_WRITE_BOTH
, MIGRATION_NEW
],
1147 [ MIGRATION_WRITE_NEW
, MIGRATION_WRITE_BOTH
],
1148 [ MIGRATION_WRITE_NEW
, MIGRATION_WRITE_NEW
],
1149 [ MIGRATION_WRITE_NEW
, MIGRATION_NEW
],
1150 [ MIGRATION_NEW
, MIGRATION_WRITE_BOTH
],
1151 [ MIGRATION_NEW
, MIGRATION_WRITE_NEW
],
1152 [ MIGRATION_NEW
, MIGRATION_NEW
],