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
82 lines
2.1 KiB
PHP
82 lines
2.1 KiB
PHP
<?php
|
|
|
|
use MediaWiki\Permissions\Authority;
|
|
|
|
/**
|
|
* Base class for testing special pages.
|
|
*
|
|
* @since 1.26
|
|
*
|
|
* @license GPL-2.0-or-later
|
|
* @author Jeroen De Dauw < jeroendedauw@gmail.com >
|
|
* @author Daniel Kinzler
|
|
* @author Addshore
|
|
* @author Thiemo Kreuz
|
|
*/
|
|
abstract class SpecialPageTestBase extends MediaWikiIntegrationTestCase {
|
|
|
|
private $obLevel;
|
|
|
|
protected function setUp(): void {
|
|
parent::setUp();
|
|
|
|
$this->obLevel = ob_get_level();
|
|
}
|
|
|
|
protected function tearDown(): void {
|
|
$obLevel = ob_get_level();
|
|
|
|
while ( ob_get_level() > $this->obLevel ) {
|
|
ob_end_clean();
|
|
}
|
|
|
|
try {
|
|
if ( $obLevel !== $this->obLevel ) {
|
|
$this->fail(
|
|
"Test changed output buffer level: was {$this->obLevel} before test, but $obLevel after test."
|
|
);
|
|
}
|
|
} finally {
|
|
parent::tearDown();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a new instance of the special page under test.
|
|
*
|
|
* @return SpecialPage
|
|
*/
|
|
abstract protected function newSpecialPage();
|
|
|
|
/**
|
|
* @param string $subPage The subpage parameter to call the page with
|
|
* @param WebRequest|null $request Web request that may contain URL parameters, etc
|
|
* @param Language|string|null $language The language which should be used in the context
|
|
* @param Authority|null $performer The user which should be used in the context of this special page
|
|
* @param bool $fullHtml if true, the entirety of the generated HTML will be returned, this
|
|
* includes the opening <!DOCTYPE> declaration and closing </html> tag. If false, only value
|
|
* of OutputPage::getHTML() will be returned except if the page is redirect or where OutputPage
|
|
* is completely disabled.
|
|
*
|
|
* @throws Exception
|
|
* @return array [ string, WebResponse ] A two-elements array containing the HTML output
|
|
* generated by the special page as well as the response object.
|
|
*/
|
|
protected function executeSpecialPage(
|
|
$subPage = '',
|
|
WebRequest $request = null,
|
|
$language = null,
|
|
Authority $performer = null,
|
|
$fullHtml = false
|
|
) {
|
|
return ( new SpecialPageExecutor() )->executeSpecialPage(
|
|
$this->newSpecialPage(),
|
|
$subPage,
|
|
$request,
|
|
$language,
|
|
$performer,
|
|
$fullHtml
|
|
);
|
|
}
|
|
|
|
}
|