wiki.techinc.nl/tests/phpunit/includes/api/query/ApiQueryPrefixSearchTest.php
libraryupgrader 5357695270 build: Updating dependencies
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
2021-07-22 03:36:05 +00:00

59 lines
1.6 KiB
PHP

<?php
/**
* @group API
* @group medium
* @group Database
*
* @covers ApiQueryPrefixSearch
*/
class ApiQueryPrefixSearchTest extends ApiTestCase {
private const TEST_QUERY = 'unittest';
protected function setUp(): void {
parent::setUp();
$this->setMwGlobals( [
'wgSearchType' => MockCompletionSearchEngine::class,
] );
MockCompletionSearchEngine::clearMockResults();
$results = [];
foreach ( range( 0, 10 ) as $i ) {
$title = "Search_Result_$i";
$results[] = $title;
$this->editPage( $title, 'hi there' );
}
MockCompletionSearchEngine::addMockResults( self::TEST_QUERY, $results );
}
public function offsetContinueProvider() {
return [
'no offset' => [ 2, 2, 0, 2 ],
'with offset' => [ 7, 2, 5, 2 ],
'past end, no offset' => [ null, 11, 0, 20 ],
'past end, with offset' => [ null, 5, 6, 10 ],
];
}
/**
* @dataProvider offsetContinueProvider
*/
public function testOffsetContinue( $expectedOffset, $expectedResults, $offset, $limit ) {
$response = $this->doApiRequest( [
'action' => 'query',
'list' => 'prefixsearch',
'pssearch' => self::TEST_QUERY,
'psoffset' => $offset,
'pslimit' => $limit,
] );
$result = $response[0];
$this->assertArrayNotHasKey( 'warnings', $result );
$suggestions = $result['query']['prefixsearch'];
$this->assertCount( $expectedResults, $suggestions );
if ( $expectedOffset == null ) {
$this->assertArrayNotHasKey( 'continue', $result );
} else {
$this->assertArrayHasKey( 'continue', $result );
$this->assertEquals( $expectedOffset, $result['continue']['psoffset'] );
}
}
}