Merge "Provide command to adjust phpunit.xml for code coverage"

This commit is contained in:
jenkins-bot 2019-09-09 19:25:32 +00:00 committed by Gerrit Code Review
commit 64e7e7d760
3 changed files with 65 additions and 2 deletions

View file

@ -298,6 +298,7 @@ $wgAutoloadLocalClasses = [
'ComposerJson' => __DIR__ . '/includes/libs/composer/ComposerJson.php',
'ComposerLock' => __DIR__ . '/includes/libs/composer/ComposerLock.php',
'ComposerPackageModifier' => __DIR__ . '/includes/composer/ComposerPackageModifier.php',
'ComposerPhpunitXmlCoverageEdit' => __DIR__ . '/includes/composer/ComposerPhpunitXmlCoverageEdit.php',
'ComposerVendorHtaccessCreator' => __DIR__ . '/includes/composer/ComposerVendorHtaccessCreator.php',
'ComposerVersionNormalizer' => __DIR__ . '/includes/composer/ComposerVersionNormalizer.php',
'CompressOld' => __DIR__ . '/maintenance/storage/compressOld.php',

View file

@ -97,7 +97,8 @@
"autoload": {
"psr-0": {
"ComposerHookHandler": "includes/composer",
"ComposerVendorHtaccessCreator": "includes/composer"
"ComposerVendorHtaccessCreator": "includes/composer",
"ComposerPhpunitXmlCoverageEdit":"includes/composer"
}
},
"autoload-dev": {
@ -121,7 +122,8 @@
"phpunit": "phpunit",
"phpunit:unit": "phpunit --colors=always --testsuite=core:unit,extensions:unit,skins:unit",
"phpunit:integration": "phpunit --colors=always --testsuite=core:integration,extensions:integration,skins:integration",
"phpunit:coverage": "phpunit --testsuite=core:unit --exclude-group Dump,Broken"
"phpunit:coverage": "phpunit --testsuite=core:unit --exclude-group Dump,Broken",
"phpunit:coverage-edit": "ComposerPhpunitXmlCoverageEdit::onEvent"
},
"config": {
"optimize-autoloader": true,

View file

@ -0,0 +1,60 @@
<?php
/**
* 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.
*
*/
/**
* Edit phpunit.xml to speed up code coverage generation.
*
* Usage: composer phpunit:coverage-edit -- extensions/ExtensionName
*
* This class runs *outside* of the normal MediaWiki
* environment and cannot depend upon any MediaWiki
* code.
*/
class ComposerPhpunitXmlCoverageEdit {
public static function onEvent( $event ) {
$IP = dirname( dirname( __DIR__ ) );
// TODO: Support passing arbitrary directories for core (or extensions/skins).
$args = $event->getArguments();
if ( count( $args ) !== 1 ) {
throw new InvalidArgumentException( 'Pass extensions/$extensionName as an argument, ' .
'e.g. "composer phpunit:coverage-edit -- extensions/BoilerPlate"' );
}
$project = current( $args );
$phpunitXml = \PHPUnit\Util\Xml::loadFile( $IP . '/phpunit.xml.dist' );
$whitelist = iterator_to_array( $phpunitXml->getElementsByTagName( 'whitelist' ) );
/** @var DOMNode $childNode */
foreach ( $whitelist as $childNode ) {
$childNode->parentNode->removeChild( $childNode );
}
$whitelistElement = $phpunitXml->createElement( 'whitelist' );
$whitelistElement->setAttribute( 'addUncoveredFilesFromWhitelist', 'false' );
// TODO: Use AutoloadClasses from extension.json to load the relevant directories
foreach ( [ 'includes', 'src', 'maintenance' ] as $dir ) {
$dirElement = $phpunitXml->createElement( 'directory', $project . '/' . $dir );
$dirElement->setAttribute( 'suffix', '.php' );
$whitelistElement->appendChild( $dirElement );
}
$phpunitXml->getElementsByTagName( 'filter' )->item( 0 )
->appendChild( $whitelistElement );
$phpunitXml->formatOutput = true;
$phpunitXml->save( $IP . '/phpunit.xml' );
}
}