The use case is code that uses search internally, but wants to allow a development setup where search is proxied via some public API and the actual querying is performed on a production server, instead of having to set up all the search services + staging content locally. Also fix a small logic error in SearchResultSet::shrink. Change-Id: I83931c1a19c1cb747380e17a4aff3b1fadd5fcf3
41 lines
1.1 KiB
PHP
41 lines
1.1 KiB
PHP
<?php
|
|
|
|
/**
|
|
* A manually constructed search result set.
|
|
* Mainly meant for supporting developer setups where the search operation might be
|
|
* mocked or proxied.
|
|
*/
|
|
class FauxSearchResultSet extends SearchResultSet {
|
|
|
|
/**
|
|
* @var int|null
|
|
* @see getTotalHits
|
|
*/
|
|
private $totalHits;
|
|
|
|
/**
|
|
* @param array<Title|SearchResult> $results Search results
|
|
* @param int|null $totalHits See getTotalHits()
|
|
*/
|
|
public function __construct( array $results, $totalHits = null ) {
|
|
$totalHits = max( count( $results ), $totalHits );
|
|
$hasMoreResults = count( $results ) < $totalHits;
|
|
parent::__construct( false, $hasMoreResults );
|
|
$this->results = array_map( function ( $result ) {
|
|
if ( $result instanceof SearchResult ) {
|
|
return $result;
|
|
} elseif ( $result instanceof Title ) {
|
|
return new FauxSearchResult( $result );
|
|
} else {
|
|
throw new InvalidArgumentException( '$results must contain Title or SearchResult' );
|
|
}
|
|
}, $results );
|
|
$this->totalHits = $totalHits;
|
|
}
|
|
|
|
/** @inheritDoc */
|
|
public function getTotalHits() {
|
|
return $this->totalHits;
|
|
}
|
|
|
|
}
|