composer: * mediawiki/mediawiki-codesniffer: 36.0.0 → 37.0.0 The following sniffs now pass and were enabled: * Generic.ControlStructures.InlineControlStructure * MediaWiki.PHPUnit.AssertCount.NotUsed npm: * svgo: 2.3.0 → 2.3.1 * https://npmjs.com/advisories/1754 (CVE-2021-33587) Change-Id: I2a9bbee2fecbf7259876d335f565ece4b3622426
65 lines
2.1 KiB
PHP
65 lines
2.1 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group API
|
|
* @group Database
|
|
* @group medium
|
|
* @covers ApiQueryAllRevisions
|
|
*/
|
|
class ApiQueryAllRevisionsTest extends ApiTestCase {
|
|
|
|
protected function setUp(): void {
|
|
parent::setUp();
|
|
$this->tablesUsed[] = 'revision';
|
|
}
|
|
|
|
/**
|
|
* @group medium
|
|
*/
|
|
public function testContentComesWithContentModelAndFormat() {
|
|
$pageName = 'Help:' . __METHOD__;
|
|
$title = Title::newFromText( $pageName );
|
|
$page = WikiPage::factory( $title );
|
|
|
|
$page->doUserEditContent(
|
|
ContentHandler::makeContent( 'Some text', $page->getTitle() ),
|
|
$this->getTestSysop()->getUser(),
|
|
'inserting content'
|
|
);
|
|
$page->doUserEditContent(
|
|
ContentHandler::makeContent( 'Some other text', $page->getTitle() ),
|
|
$this->getTestSysop()->getUser(),
|
|
'adding revision'
|
|
);
|
|
|
|
$apiResult = $this->doApiRequest( [
|
|
'action' => 'query',
|
|
'list' => 'allrevisions',
|
|
'arvprop' => 'content',
|
|
'arvslots' => 'main',
|
|
'arvdir' => 'older',
|
|
] );
|
|
|
|
$this->assertArrayHasKey( 'query', $apiResult[0] );
|
|
$this->assertArrayHasKey( 'allrevisions', $apiResult[0]['query'] );
|
|
$this->assertArrayHasKey( 0, $apiResult[0]['query']['allrevisions'] );
|
|
$this->assertArrayHasKey( 'title', $apiResult[0]['query']['allrevisions'][0] );
|
|
$this->assertSame( $pageName, $apiResult[0]['query']['allrevisions'][0]['title'] );
|
|
$this->assertArrayHasKey( 'revisions', $apiResult[0]['query']['allrevisions'][0] );
|
|
$this->assertCount( 2, $apiResult[0]['query']['allrevisions'][0]['revisions'] );
|
|
|
|
foreach ( $apiResult[0]['query']['allrevisions'] 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'
|
|
);
|
|
}
|
|
}
|
|
}
|
|
}
|