wiki.techinc.nl/includes/search/FauxSearchResultSet.php
Gergő Tisza c296cf69b4
Add faux SearchResult and SearchResultSet
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
2019-10-07 16:35:58 +02:00

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;
}
}