class PHPUnitMaintClass extends Maintenance {
- public static $additionalOptions = array(
- 'regex' => false,
+ public static $additionalOptions = [
'file' => false,
'use-filebackend' => false,
'use-bagostuff' => false,
'use-jobqueue' => false,
- 'keep-uploads' => false,
'use-normal-tables' => false,
'reuse-db' => false,
'wiki' => false,
- );
+ 'profiler' => false,
+ ];
public function __construct() {
parent::__construct();
$this->addOption(
- 'with-phpunitdir',
- 'Directory to include PHPUnit from, for example when using a git '
- . 'fetchout from upstream. Path will be prepended to PHP `include_path`.',
- false, # not required
- true # need arg
+ 'with-phpunitclass',
+ 'Class name of the PHPUnit entry point to use',
+ false,
+ true
);
$this->addOption(
'debug-tests',
false, # not required
false # no arg needed
);
- $this->addOption(
- 'regex',
- 'Only run parser tests that match the given regex.',
- false,
- true
- );
$this->addOption( 'file', 'File describing parser tests.', false, true );
$this->addOption( 'use-filebackend', 'Use filebackend', false, true );
$this->addOption( 'use-bagostuff', 'Use bagostuff', false, true );
$this->addOption( 'use-jobqueue', 'Use jobqueue', false, true );
- $this->addOption(
- 'keep-uploads',
- 'Re-use the same upload directory for each test, don\'t delete it.',
- false,
- false
- );
$this->addOption( 'use-normal-tables', 'Use normal DB tables.', false, false );
$this->addOption(
'reuse-db', 'Init DB only if tables are missing and keep after finish.',
public function finalSetup() {
parent::finalSetup();
- global $wgMainCacheType, $wgMessageCacheType, $wgParserCacheType, $wgMainWANCache;
- global $wgMainStash;
- global $wgLanguageConverterCacheType, $wgUseDatabaseMessages;
- global $wgLocaltimezone, $wgLocalisationCacheConf;
- global $wgDevelopmentWarnings;
- global $wgSessionProviders;
- global $wgJobTypeConf;
-
// Inject test autoloader
- require_once __DIR__ . '/../TestsAutoLoader.php';
-
- // wfWarn should cause tests to fail
- $wgDevelopmentWarnings = true;
+ self::requireTestsAutoloader();
- // Make sure all caches and stashes are either disabled or use
- // in-process cache only to prevent tests from using any preconfigured
- // cache meant for the local wiki from outside the test run.
- // See also MediaWikiTestCase::run() which mocks CACHE_DB and APC.
-
- // Disabled in DefaultSettings, override local settings
- $wgMainWANCache =
- $wgMainCacheType = CACHE_NONE;
- // Uses CACHE_ANYTHING in DefaultSettings, use hash instead of db
- $wgMessageCacheType =
- $wgParserCacheType =
- $wgSessionCacheType =
- $wgLanguageConverterCacheType = 'hash';
- // Uses db-replicated in DefaultSettings
- $wgMainStash = 'hash';
- // Use memory job queue
- $wgJobTypeConf = array(
- 'default' => array( 'class' => 'JobQueueMemory', 'order' => 'fifo' ),
- );
-
- $wgUseDatabaseMessages = false; # Set for future resets
-
- // Assume UTC for testing purposes
- $wgLocaltimezone = 'UTC';
-
- $wgLocalisationCacheConf['storeClass'] = 'LCStoreNull';
-
- // Generic MediaWiki\Session\SessionManager configuration for tests
- // We use CookieSessionProvider because things might be expecting
- // cookies to show up in a FauxRequest somewhere.
- $wgSessionProviders = array(
- array(
- 'class' => 'MediaWiki\\Session\\CookieSessionProvider',
- 'args' => array( array(
- 'priority' => 30,
- 'callUserSetCookiesHook' => true,
- ) ),
- ),
- );
-
- // Bug 44192 Do not attempt to send a real e-mail
- Hooks::clear( 'AlternateUserMailer' );
- Hooks::register(
- 'AlternateUserMailer',
- function () {
- return false;
- }
- );
- // xdebug's default of 100 is too low for MediaWiki
- ini_set( 'xdebug.max_nesting_level', 1000 );
-
- // Bug T116683 serialize_precision of 100
- // may break testing against floating point values
- // treated with PHP's serialize()
- ini_set( 'serialize_precision', 17 );
+ TestSetup::applyInitialConfig();
}
public function execute() {
if ( !in_array( '--configuration', $_SERVER['argv'] ) ) {
// Hack to eliminate the need to use the Makefile (which sucks ATM)
array_splice( $_SERVER['argv'], 1, 0,
- array( '--configuration', $IP . '/tests/phpunit/suite.xml' ) );
+ [ '--configuration', $IP . '/tests/phpunit/suite.xml' ] );
}
- # --with-phpunitdir let us override the default PHPUnit version
- # Can use with either or phpunit.phar in the directory or the
- # full PHPUnit code base.
- if ( $this->hasOption( 'with-phpunitdir' ) ) {
- $phpunitDir = $this->getOption( 'with-phpunitdir' );
+ $phpUnitClass = 'PHPUnit_TextUI_Command';
- # prepends provided PHPUnit directory or phar
- $this->output( "Will attempt loading PHPUnit from `$phpunitDir`\n" );
- set_include_path( $phpunitDir . PATH_SEPARATOR . get_include_path() );
+ if ( $this->hasOption( 'with-phpunitclass' ) ) {
+ $phpUnitClass = $this->getOption( 'with-phpunitclass' );
# Cleanup $args array so the option and its value do not
# pollute PHPUnit
- $key = array_search( '--with-phpunitdir', $_SERVER['argv'] );
+ $key = array_search( '--with-phpunitclass', $_SERVER['argv'] );
unset( $_SERVER['argv'][$key] ); // the option
unset( $_SERVER['argv'][$key + 1] ); // its value
$_SERVER['argv'] = array_values( $_SERVER['argv'] );
}
- if ( !wfIsWindows() ) {
- # If we are not running on windows then we can enable phpunit colors
- # Windows does not come anymore with ANSI.SYS loaded by default
- # PHPUnit uses the suite.xml parameters to enable/disable colors
- # which can be then forced to be enabled with --colors.
- # The below code injects a parameter just like if the user called
- # Probably fix bug 29226
- $key = array_search( '--colors', $_SERVER['argv'] );
- if ( $key === false ) {
- array_splice( $_SERVER['argv'], 1, 0, '--colors' );
- }
- }
-
- # Makes MediaWiki PHPUnit directory includable so the PHPUnit will
- # be able to resolve relative files inclusion such as suites/*
- # PHPUnit uses stream_resolve_include_path() internally
- # See bug 32022
- $key = array_search( '--include-path', $_SERVER['argv'] );
- if ( $key === false ) {
- array_splice( $_SERVER['argv'], 1, 0,
- __DIR__
- . PATH_SEPARATOR
- . get_include_path()
- );
- array_splice( $_SERVER['argv'], 1, 0, '--include-path' );
- }
-
$key = array_search( '--debug-tests', $_SERVER['argv'] );
if ( $key !== false && array_search( '--printer', $_SERVER['argv'] ) === false ) {
unset( $_SERVER['argv'][$key] );
}
}
+ if ( !class_exists( 'PHPUnit_Framework_TestCase' ) ) {
+ echo "PHPUnit not found. Please install it and other dev dependencies by
+ running `composer install` in MediaWiki root directory.\n";
+ exit( 1 );
+ }
+ if ( !class_exists( $phpUnitClass ) ) {
+ echo "PHPUnit entry point '" . $phpUnitClass . "' not found. Please make sure you installed
+ the containing component and check the spelling of the class name.\n";
+ exit( 1 );
+ }
+
+ echo defined( 'HHVM_VERSION' ) ?
+ 'Using HHVM ' . HHVM_VERSION . ' (' . PHP_VERSION . ")\n" :
+ 'Using PHP ' . PHP_VERSION . "\n";
+
+ // Prepare global services for unit tests.
+ MediaWikiTestCase::prepareServices( new GlobalVarConfig() );
+
+ $phpUnitClass::main();
}
public function getDbType() {
* - Split args such as "wiki=enwiki" into two separate arg elements "wiki" and "enwiki"
*/
private function forceFormatServerArgv() {
- $argv = array();
+ $argv = [];
foreach ( $_SERVER['argv'] as $key => $arg ) {
if ( $key === 0 ) {
$argv[0] = $arg;
$maintClass = 'PHPUnitMaintClass';
require RUN_MAINTENANCE_IF_MAIN;
-
-$ok = false;
-
-if ( class_exists( 'PHPUnit_TextUI_Command' ) ) {
- echo "PHPUnit already present\n";
- $ok = true;
-} else {
- foreach ( array(
- stream_resolve_include_path( 'phpunit.phar' ),
- stream_resolve_include_path( 'phpunit-old.phar' ),
- 'PHPUnit/Runner/Version.php',
- 'PHPUnit/Autoload.php'
- ) as $includePath ) {
-
- if ( $includePath === false ) {
- // stream_resolve_include_path can return false
- continue;
- }
-
- \MediaWiki\suppressWarnings();
- include_once $includePath;
- \MediaWiki\restoreWarnings();
- if ( class_exists( 'PHPUnit_TextUI_Command' ) ) {
- $ok = true;
- echo "Using PHPUnit from $includePath\n";
- break;
- }
- }
-}
-
-if ( !$ok ) {
- echo "Couldn't find a usable PHPUnit.\n";
- exit( 1 );
-}
-
-$puVersion = PHPUnit_Runner_Version::id();
-if ( $puVersion !== '@package_version@' && version_compare( $puVersion, '3.7.0', '<' ) ) {
- echo "PHPUnit 3.7.0 or later required; you have {$puVersion}.\n";
- exit( 1 );
-}
-
-echo defined( 'HHVM_VERSION' ) ?
- 'Using HHVM ' . HHVM_VERSION . ' (' . PHP_VERSION . ")\n" :
- 'Using PHP ' . PHP_VERSION . "\n";
-
-PHPUnit_TextUI_Command::main();