Just methods where adding "static" to the declaration was enough, I didn't do anything with providers that used $this. Initially by search and replace. There were many mistakes which I found mostly by running the PHPStorm inspection which searches for $this usage in a static method. Later I used the PHPStorm "make static" action which avoids the more obvious mistakes. Bug: T332865 Change-Id: I47ed6692945607dfa5c139d42edbd934fa4f3a36
144 lines
4.2 KiB
PHP
144 lines
4.2 KiB
PHP
<?php
|
|
|
|
use MediaWiki\Revision\SlotRecord;
|
|
|
|
/**
|
|
* @group API
|
|
* @group Database
|
|
* @group medium
|
|
* @covers ApiQueryRevisions
|
|
*/
|
|
class ApiQueryRevisionsTest extends ApiTestCase {
|
|
|
|
/**
|
|
* @group medium
|
|
*/
|
|
public function testContentComesWithContentModelAndFormat() {
|
|
$pageName = 'Help:' . __METHOD__;
|
|
$page = $this->getExistingTestPage( $pageName );
|
|
$user = $this->getTestUser()->getUser();
|
|
$page->newPageUpdater( $user )
|
|
->setContent( SlotRecord::MAIN, new WikitextContent( 'Some text' ) )
|
|
->saveRevision( CommentStoreComment::newUnsavedComment( 'inserting content' ) );
|
|
|
|
$apiResult = $this->doApiRequest( [
|
|
'action' => 'query',
|
|
'prop' => 'revisions',
|
|
'titles' => $pageName,
|
|
'rvprop' => 'content',
|
|
'rvslots' => 'main',
|
|
] );
|
|
$this->assertArrayHasKey( 'query', $apiResult[0] );
|
|
$this->assertArrayHasKey( 'pages', $apiResult[0]['query'] );
|
|
foreach ( $apiResult[0]['query']['pages'] as $page ) {
|
|
$this->assertArrayHasKey( 'revisions', $page );
|
|
foreach ( $page['revisions'] as $revision ) {
|
|
$this->assertArrayHasKey( 'slots', $revision );
|
|
$this->assertArrayHasKey( 'main', $revision['slots'] );
|
|
$this->assertArrayHasKey( 'contentformat', $revision['slots']['main'],
|
|
'contentformat should be included when asking content so client knows how to interpret it'
|
|
);
|
|
$this->assertArrayHasKey( 'contentmodel', $revision['slots']['main'],
|
|
'contentmodel should be included when asking content so client knows how to interpret it'
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @group medium
|
|
*/
|
|
public function testResolvesPrevNextInDiffto() {
|
|
$pageName = 'Help:' . __METHOD__;
|
|
$page = $this->getExistingTestPage( $pageName );
|
|
$user = $this->getTestUser()->getUser();
|
|
|
|
$revRecord = $page->newPageUpdater( $user )
|
|
->setContent( SlotRecord::MAIN, new WikitextContent( 'Some text' ) )
|
|
->saveRevision( CommentStoreComment::newUnsavedComment( 'inserting more content' ) );
|
|
|
|
[ $rvDiffToPrev ] = $this->doApiRequest( [
|
|
'action' => 'query',
|
|
'prop' => 'revisions',
|
|
'titles' => $pageName,
|
|
'rvdiffto' => 'prev',
|
|
] );
|
|
|
|
$this->assertSame(
|
|
$revRecord->getId(),
|
|
$rvDiffToPrev['query']['pages'][$page->getId()]['revisions'][0]['revid']
|
|
);
|
|
$this->assertSame(
|
|
$revRecord->getId(),
|
|
$rvDiffToPrev['query']['pages'][$page->getId()]['revisions'][0]['diff']['to']
|
|
);
|
|
$this->assertSame(
|
|
$revRecord->getParentId(),
|
|
$rvDiffToPrev['query']['pages'][$page->getId()]['revisions'][0]['diff']['from']
|
|
);
|
|
|
|
[ $rvDiffToNext ] = $this->doApiRequest( [
|
|
'action' => 'query',
|
|
'prop' => 'revisions',
|
|
'titles' => $pageName,
|
|
'rvdiffto' => 'next',
|
|
'rvdir' => 'newer'
|
|
] );
|
|
|
|
$this->assertSame(
|
|
$revRecord->getParentId(),
|
|
$rvDiffToNext['query']['pages'][$page->getId()]['revisions'][0]['revid']
|
|
);
|
|
$this->assertSame(
|
|
$revRecord->getId(),
|
|
$rvDiffToNext['query']['pages'][$page->getId()]['revisions'][0]['diff']['to']
|
|
);
|
|
$this->assertSame(
|
|
$revRecord->getParentId(),
|
|
$rvDiffToNext['query']['pages'][$page->getId()]['revisions'][0]['diff']['from']
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideSectionNewTestCases
|
|
* @param string $pageContent
|
|
* @param string $expectedSectionContent
|
|
* @group medium
|
|
*/
|
|
public function testSectionNewReturnsEmptyContentForPageWithSection(
|
|
$pageContent,
|
|
$expectedSectionContent
|
|
) {
|
|
$pageName = 'Help:' . __METHOD__;
|
|
$page = $this->getExistingTestPage( $pageName );
|
|
$user = $this->getTestUser()->getUser();
|
|
$revRecord = $page->newPageUpdater( $user )
|
|
->setContent( SlotRecord::MAIN, new WikitextContent( $pageContent ) )
|
|
->saveRevision( CommentStoreComment::newUnsavedComment( 'inserting content' ) );
|
|
|
|
[ $response ] = $this->doApiRequest( [
|
|
'action' => 'query',
|
|
'prop' => 'revisions',
|
|
'revids' => $revRecord->getId(),
|
|
'rvprop' => 'content|ids',
|
|
'rvslots' => 'main',
|
|
'rvsection' => 'new'
|
|
] );
|
|
|
|
$this->assertSame(
|
|
$expectedSectionContent,
|
|
$response['query']['pages'][$page->getId()]['revisions'][0]['slots']['main']['content']
|
|
);
|
|
}
|
|
|
|
public static function provideSectionNewTestCases() {
|
|
yield 'page with existing section' => [
|
|
"==A section==\ntext",
|
|
''
|
|
];
|
|
yield 'page with no sections' => [
|
|
'This page has no sections',
|
|
'This page has no sections'
|
|
];
|
|
}
|
|
}
|