Since the match can be case-insensitive (apparently), this meant
ExtensionsTestSuite.php ("extensions") wasn't being validated either.
Bug: T127238
Change-Id: I679de924ebeb45150004783ce404fac92af026a7
45 lines
1.2 KiB
PHP
45 lines
1.2 KiB
PHP
<?php
|
|
/**
|
|
* This test suite runs unit tests registered by extensions.
|
|
* See https://www.mediawiki.org/wiki/Manual:Hooks/UnitTestsList for details of
|
|
* how to register your tests.
|
|
*/
|
|
|
|
class ExtensionsTestSuite extends PHPUnit_Framework_TestSuite {
|
|
public function __construct() {
|
|
parent::__construct();
|
|
$paths = [];
|
|
// Extensions can return a list of files or directories
|
|
Hooks::run( 'UnitTestsList', [ &$paths ] );
|
|
foreach ( $paths as $path ) {
|
|
if ( is_dir( $path ) ) {
|
|
// If the path is a directory, search for test cases.
|
|
// @since 1.24
|
|
$suffixes = [ 'Test.php' ];
|
|
$fileIterator = new File_Iterator_Facade();
|
|
$matchingFiles = $fileIterator->getFilesAsArray( $path, $suffixes );
|
|
$this->addTestFiles( $matchingFiles );
|
|
} else {
|
|
// Add a single test case or suite class
|
|
$this->addTestFile( $path );
|
|
}
|
|
}
|
|
if ( !$paths ) {
|
|
$this->addTest( new DummyExtensionsTest( 'testNothing' ) );
|
|
}
|
|
}
|
|
|
|
public static function suite() {
|
|
return new self;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Needed to avoid warnings like 'No tests found in class "ExtensionsTestSuite".'
|
|
* when no extensions with tests are used.
|
|
*/
|
|
class DummyExtensionsTest extends MediaWikiTestCase {
|
|
public function testNothing() {
|
|
$this->assertTrue( true );
|
|
}
|
|
}
|