// through this entry point or not.
define( 'MW_PHPUNIT_TEST', true );
+$wgPhpUnitClass = 'PHPUnit_TextUI_Command';
+
// Start up MediaWiki in command-line mode
require_once dirname( dirname( __DIR__ ) ) . "/maintenance/Maintenance.php";
class PHPUnitMaintClass extends Maintenance {
- public static $additionalOptions = array(
+ public static $additionalOptions = [
'regex' => false,
'file' => false,
'use-filebackend' => false,
'use-normal-tables' => false,
'reuse-db' => false,
'wiki' => 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',
// Uses db-replicated in DefaultSettings
$wgMainStash = 'hash';
// Use memory job queue
- $wgJobTypeConf = array(
- 'default' => array( 'class' => 'JobQueueMemory', 'order' => 'fifo' ),
- );
+ $wgJobTypeConf = [
+ 'default' => [ 'class' => 'JobQueueMemory', 'order' => 'fifo' ],
+ ];
$wgUseDatabaseMessages = false; # Set for future resets
// 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(
+ $wgSessionProviders = [
+ [
'class' => 'MediaWiki\\Session\\CookieSessionProvider',
- 'args' => array( array(
+ 'args' => [ [
'priority' => 30,
'callUserSetCookiesHook' => true,
- ) ),
- ),
- );
+ ] ],
+ ],
+ ];
// Bug 44192 Do not attempt to send a real e-mail
Hooks::clear( 'AlternateUserMailer' );
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' );
-
- # 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' ) ) {
+ global $wgPhpUnitClass;
+ $wgPhpUnitClass = $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] );
* - 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";
+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 );
}
-
-$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";
+if ( !class_exists( $wgPhpUnitClass ) ) {
+ echo "PHPUnit entry point '" . $wgPhpUnitClass . "' not found. Please make sure you installed
+the containing component and check the spelling of the class name.\n";
exit( 1 );
}
'Using HHVM ' . HHVM_VERSION . ' (' . PHP_VERSION . ")\n" :
'Using PHP ' . PHP_VERSION . "\n";
-PHPUnit_TextUI_Command::main();
+$wgPhpUnitClass::main();