2021-11-09 18:56:17 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace MediaWiki\Tests\Structure;
|
|
|
|
|
|
2022-04-27 15:42:24 +00:00
|
|
|
use MediaWiki\MainConfigNames;
|
2021-11-09 18:56:17 +00:00
|
|
|
use MediaWiki\MediaWikiServices;
|
2022-10-28 10:04:25 +00:00
|
|
|
use MediaWiki\Request\FauxRequest;
|
2022-05-06 09:09:56 +00:00
|
|
|
use MediaWiki\ResourceLoader\Context;
|
|
|
|
|
use MediaWiki\ResourceLoader\DerivativeContext;
|
|
|
|
|
use MediaWiki\ResourceLoader\Module;
|
2021-11-09 18:56:17 +00:00
|
|
|
use MediaWikiIntegrationTestCase;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Compare bundle sizes from each skin/extension bundlesize.config.json with ResourceLoader output.
|
|
|
|
|
*
|
|
|
|
|
* Extensions and skins can subclass this and override getTestCases with just their own bundlesize
|
|
|
|
|
* file. This allows one to run that test suite by its own, for faster CLI feedback.
|
|
|
|
|
*/
|
|
|
|
|
abstract class BundleSizeTest extends MediaWikiIntegrationTestCase {
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @coversNothing
|
|
|
|
|
*/
|
|
|
|
|
public function testBundleSize() {
|
|
|
|
|
$bundleSizeConfig = json_decode( file_get_contents( $this->getBundleSizeConfig() ), true );
|
|
|
|
|
foreach ( $bundleSizeConfig as $testCase ) {
|
|
|
|
|
$maxSize = $testCase['maxSize'];
|
|
|
|
|
$projectName = $testCase['projectName'] ?? '';
|
|
|
|
|
$moduleName = $testCase['resourceModule'];
|
|
|
|
|
if ( is_string( $maxSize ) ) {
|
|
|
|
|
if ( strpos( $maxSize, 'KB' ) !== false || strpos( $maxSize, 'kB' ) !== false ) {
|
|
|
|
|
$maxSize = (float)str_replace( [ 'KB', 'kB', ' KB', ' kB' ], '', $maxSize );
|
|
|
|
|
$maxSize = $maxSize * 1024;
|
|
|
|
|
} elseif ( strpos( $maxSize, 'B' ) !== false ) {
|
|
|
|
|
$maxSize = (float)str_replace( [ ' B', 'B' ], '', $maxSize );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$resourceLoader = MediaWikiServices::getInstance()->getResourceLoader();
|
|
|
|
|
$request = new FauxRequest(
|
|
|
|
|
[
|
|
|
|
|
'lang' => 'en',
|
|
|
|
|
'modules' => $moduleName,
|
2022-04-09 12:04:36 +00:00
|
|
|
'skin' => $this->getSkinName(),
|
2021-11-09 18:56:17 +00:00
|
|
|
]
|
|
|
|
|
);
|
|
|
|
|
|
2022-05-06 09:09:56 +00:00
|
|
|
$context = new Context( $resourceLoader, $request );
|
2021-11-09 18:56:17 +00:00
|
|
|
$module = $resourceLoader->getModule( $moduleName );
|
2022-05-06 09:09:56 +00:00
|
|
|
$contentContext = new DerivativeContext( $context );
|
2021-11-09 18:56:17 +00:00
|
|
|
$contentContext->setOnly(
|
2022-05-06 09:09:56 +00:00
|
|
|
$module->getType() === Module::LOAD_STYLES
|
|
|
|
|
? Module::TYPE_STYLES
|
|
|
|
|
: Module::TYPE_COMBINED
|
2021-11-09 18:56:17 +00:00
|
|
|
);
|
|
|
|
|
$content = $resourceLoader->makeModuleResponse( $context, [ $moduleName => $module ] );
|
|
|
|
|
$contentTransferSize = strlen( gzencode( $content, 9 ) );
|
|
|
|
|
$message = $projectName ?
|
|
|
|
|
"$projectName: $moduleName is less than $maxSize" :
|
|
|
|
|
"$moduleName is less than $maxSize";
|
|
|
|
|
$this->assertLessThan( $maxSize, $contentTransferSize, $message );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @return string Path to bundlesize.config.json
|
|
|
|
|
*/
|
|
|
|
|
abstract public function getBundleSizeConfig(): string;
|
|
|
|
|
|
2022-04-09 12:04:36 +00:00
|
|
|
/**
|
|
|
|
|
* @return string Skin name
|
|
|
|
|
*/
|
|
|
|
|
public function getSkinName(): string {
|
2022-04-27 15:42:24 +00:00
|
|
|
return MediaWikiServices::getInstance()->getMainConfig()->get( MainConfigNames::DefaultSkin );
|
2022-04-09 12:04:36 +00:00
|
|
|
}
|
|
|
|
|
|
2021-11-09 18:56:17 +00:00
|
|
|
}
|