2011-05-31 20:30:12 +00:00
|
|
|
<?php
|
2013-05-17 00:16:59 +00:00
|
|
|
require_once __DIR__ . '/NewParserTest.php';
|
2011-05-31 20:30:12 +00:00
|
|
|
|
|
|
|
|
/**
|
2011-11-12 21:32:39 +00:00
|
|
|
* The UnitTest must be either a class that inherits from MediaWikiTestCase
|
2013-02-15 10:24:31 +00:00
|
|
|
* or a class that provides a public static suite() method which returns
|
2011-05-31 20:30:12 +00:00
|
|
|
* an PHPUnit_Framework_Test object
|
2013-02-15 10:24:31 +00:00
|
|
|
*
|
2011-05-31 20:30:12 +00:00
|
|
|
* @group Parser
|
|
|
|
|
* @group Database
|
|
|
|
|
*/
|
|
|
|
|
class MediaWikiParserTest {
|
|
|
|
|
|
2013-05-10 19:20:12 +00:00
|
|
|
/**
|
|
|
|
|
* @defgroup filtering_constants Filtering constants
|
|
|
|
|
*
|
|
|
|
|
* Limit inclusion of parser tests files coming from MediaWiki core
|
|
|
|
|
* @{
|
|
|
|
|
*/
|
2011-05-31 20:30:12 +00:00
|
|
|
|
2013-05-10 19:20:12 +00:00
|
|
|
/** Include files shipped with MediaWiki core */
|
|
|
|
|
const CORE_ONLY = 1;
|
|
|
|
|
/** Include non core files as set in $wgParserTestFiles */
|
|
|
|
|
const NO_CORE = 2;
|
|
|
|
|
/** Include anything set via $wgParserTestFiles */
|
|
|
|
|
const WITH_ALL = 3; # CORE_ONLY | NO_CORE
|
|
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get a PHPUnit test suite of parser tests. Optionally filtered with
|
|
|
|
|
* $flags.
|
|
|
|
|
*
|
|
|
|
|
* @par Examples:
|
|
|
|
|
* Get a suite of parser tests shipped by MediaWiki core:
|
|
|
|
|
* @code
|
|
|
|
|
* MediaWikiParserTest::suite( MediaWikiParserTest::CORE_ONLY );
|
|
|
|
|
* @endcode
|
|
|
|
|
* Get a suite of various parser tests, like extensions:
|
|
|
|
|
* @code
|
|
|
|
|
* MediaWikiParserTest::suite( MediaWikiParserTest::NO_CORE );
|
|
|
|
|
* @endcode
|
|
|
|
|
* Get any test defined via $wgParserTestFiles:
|
|
|
|
|
* @code
|
|
|
|
|
* MediaWikiParserTest::suite( MediaWikiParserTest::WITH_ALL );
|
|
|
|
|
* @endcode
|
|
|
|
|
*
|
|
|
|
|
* @param $flags bitwise flag to filter out the $wgParserTestFiles that
|
|
|
|
|
* will be included. Default: MediaWikiParserTest::CORE_ONLY
|
|
|
|
|
*
|
|
|
|
|
* @return PHPUnit_Framework_TestSuite
|
|
|
|
|
*/
|
|
|
|
|
public static function suite( $flags = self::CORE_ONLY ) {
|
|
|
|
|
if( is_string( $flags ) ) {
|
|
|
|
|
$flags = self::CORE_ONLY;
|
|
|
|
|
}
|
|
|
|
|
global $wgParserTestFiles, $IP;
|
|
|
|
|
|
|
|
|
|
$mwTestDir = $IP.'/tests/';
|
|
|
|
|
|
|
|
|
|
# Human friendly helpers
|
|
|
|
|
$wantsCore = ($flags & self::CORE_ONLY);
|
|
|
|
|
$wantsRest = ($flags & self::NO_CORE);
|
|
|
|
|
|
|
|
|
|
# Will hold the .txt parser test files we will include
|
|
|
|
|
$filesToTest = array();
|
|
|
|
|
|
|
|
|
|
# Filter out .txt files
|
|
|
|
|
foreach( $wgParserTestFiles as $parserTestFile ) {
|
|
|
|
|
$isCore = ( 0 === strpos( $parserTestFile, $mwTestDir ) );
|
2011-05-31 20:30:12 +00:00
|
|
|
|
2013-05-10 19:20:12 +00:00
|
|
|
if( $isCore && $wantsCore ) {
|
|
|
|
|
self::debug( "included core parser tests: $parserTestFile" );
|
|
|
|
|
$filesToTest[] = $parserTestFile;
|
|
|
|
|
} elseif( !$isCore && $wantsRest ) {
|
|
|
|
|
self::debug( "included non core parser tests: $parserTestFile" );
|
|
|
|
|
$filesToTest[] = $parserTestFile;
|
|
|
|
|
} else {
|
|
|
|
|
self::debug( "skipped parser tests: $parserTestFile" );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
self::debug( 'parser tests files: '
|
|
|
|
|
. implode(' ', $filesToTest) );
|
|
|
|
|
|
|
|
|
|
$suite = new PHPUnit_Framework_TestSuite;
|
|
|
|
|
foreach ( $filesToTest as $fileName ) {
|
2013-04-20 20:22:26 +00:00
|
|
|
$testsName = basename( $fileName, '.txt' );
|
|
|
|
|
$escapedFileName = strtr( $fileName, array( "'" => "\\'", '\\' => '\\\\' ) );
|
2011-09-18 03:32:43 +00:00
|
|
|
/* This used to be ucfirst( basename( dirname( $filename ) ) )
|
|
|
|
|
* and then was ucfirst( basename( $filename, '.txt' )
|
|
|
|
|
* but that didn't work with names like foo.tests.txt
|
|
|
|
|
*/
|
2013-04-20 20:22:26 +00:00
|
|
|
$parserTestClassName = str_replace( '.', '_', ucfirst( $testsName ) );
|
|
|
|
|
$parserTestClassDefinition = <<<EOT
|
|
|
|
|
/**
|
|
|
|
|
* @group Database
|
|
|
|
|
* @group Parser
|
2013-04-20 20:28:38 +00:00
|
|
|
* @group ParserTests
|
|
|
|
|
* @group ParserTests_$parserTestClassName
|
2013-04-20 20:22:26 +00:00
|
|
|
*/
|
|
|
|
|
class $parserTestClassName extends NewParserTest {
|
|
|
|
|
protected \$file = '$escapedFileName';
|
|
|
|
|
}
|
|
|
|
|
EOT;
|
2012-12-07 01:11:38 +00:00
|
|
|
|
2013-04-20 20:22:26 +00:00
|
|
|
eval( $parserTestClassDefinition );
|
2013-05-10 19:20:12 +00:00
|
|
|
self::debug( "Adding test class $parserTestClassName" );
|
|
|
|
|
$suite->addTestSuite( $parserTestClassName );
|
2011-05-31 20:30:12 +00:00
|
|
|
}
|
|
|
|
|
return $suite;
|
|
|
|
|
}
|
2013-05-10 19:20:12 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Write $msg under log group 'tests-parser'
|
|
|
|
|
* @param string $msg Message to log
|
|
|
|
|
*/
|
|
|
|
|
protected static function debug( $msg ) {
|
|
|
|
|
return wfDebugLog( 'tests-parser', wfGetCaller() . ' ' . $msg );
|
|
|
|
|
}
|
2011-05-31 20:30:12 +00:00
|
|
|
}
|