This overrides the version string stored in the database with --record.
When using git-svn, you can do
php maintenance/parserTests.php --quick --quiet --record \
--setversion=`git rev-parse HEAD`
to have comprehensible version info stored for the purposes of later
bisection. Previously just "1.16alpha" would be stored, which is
useless for tracking down the old revision -- you'd have to try guessing
based on date.
It might be useful for SpecialVersion::getVersion() to support git-svn,
but that's a more complicated and intrusive change for an admittedly
small minority, so I avoided it for now.
77 lines
2.7 KiB
PHP
77 lines
2.7 KiB
PHP
<?php
|
|
# Copyright (C) 2004 Brion Vibber <brion@pobox.com>
|
|
# http://www.mediawiki.org/
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along
|
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
# http://www.gnu.org/copyleft/gpl.html
|
|
|
|
/**
|
|
* @file
|
|
* @ingroup Maintenance
|
|
*/
|
|
|
|
/** */
|
|
require('parserTests.inc');
|
|
|
|
if( isset( $options['help'] ) ) {
|
|
echo <<<ENDS
|
|
MediaWiki $wgVersion parser test suite
|
|
Usage: php parserTests.php [options...]
|
|
|
|
Options:
|
|
--quick Suppress diff output of failed tests
|
|
--quiet Suppress notification of passed tests (shows only failed tests)
|
|
--show-output Show expected and actual output
|
|
--color[=yes|no] Override terminal detection and force color output on or off
|
|
use wgCommandLineDarkBg = true; if your term is dark
|
|
--regex Only run tests whose descriptions which match given regex
|
|
--file=<testfile> Run test cases from a custom file instead of parserTests.txt
|
|
--record Record tests in database
|
|
--compare Compare with recorded results, without updating the database.
|
|
--setversion When using --record, set the version string to use (useful
|
|
with git-svn so that you can get the exact revision)
|
|
--keep-uploads Re-use the same upload directory for each test, don't delete it
|
|
--fuzz Do a fuzz test instead of a normal test
|
|
--seed <n> Start the fuzz test from the specified seed
|
|
--help Show this help message
|
|
|
|
|
|
ENDS;
|
|
exit( 0 );
|
|
}
|
|
|
|
# There is a convention that the parser should never
|
|
# refer to $wgTitle directly, but instead use the title
|
|
# passed to it.
|
|
$wgTitle = Title::newFromText( 'Parser test script do not use' );
|
|
$tester = new ParserTest();
|
|
|
|
if( isset( $options['file'] ) ) {
|
|
$files = array( $options['file'] );
|
|
} else {
|
|
// Default parser tests and any set from extensions or local config
|
|
$files = $wgParserTestFiles;
|
|
}
|
|
|
|
# Print out software version to assist with locating regressions
|
|
$version = SpecialVersion::getVersion();
|
|
echo( "This is MediaWiki version {$version}.\n\n" );
|
|
|
|
if ( isset( $options['fuzz'] ) ) {
|
|
$tester->fuzzTest( $files );
|
|
} else {
|
|
$ok = $tester->runTestsFromFiles( $files );
|
|
exit ($ok ? 0 : 1);
|
|
}
|