wiki.techinc.nl/tests/phpunit/includes/resourceloader/ResourceLoaderStartupModuleTest.php
Timo Tijhof c0c221bfe4 resourceloader: Refactor empty value trimming for mw.loader.register
We already did this, but it was rather convoluted with lots of
if/elseif sequences checking all the possible values.

Remove this logic from ResourceLoaderStartUpModule. Simplying it
simply create the array and pass it to ResourceLoader::makeLoaderRegisterScript.

In makeLoaderRegisterScript, we apply a filter to the array(s) that
trim empty values.

While at it:
* As with other registration properties' default values (like for dependencies,
  group, and skip) also use 'null' for the default value of 'source'.
  The mediawiki.js client was already compatible with this, and the server omitted
  it if it was the last value in the list. But in all other cases it explicitly
  outputs "local". Use null instead of simplicity sake. This also gains us a
  few characters in the output, and a relatively larger win after gzip since
  there's lots more re-using of "null".
* Remove stray casting of $version to int. This only happened in case of
  registering a single module (which don't do anywhere), and is redundant.

Change-Id: I1f321e7b8bd3b5cffc550b51169957a3da9b971d
2014-12-09 00:47:14 +00:00

388 lines
8.8 KiB
PHP

<?php
class ResourceLoaderStartupModuleTest extends ResourceLoaderTestCase {
public static function provideGetModuleRegistrations() {
return array(
array( array(
'msg' => 'Empty registry',
'modules' => array(),
'out' => '
mw.loader.addSource( {
"local": "/w/load.php"
} );mw.loader.register( [] );'
) ),
array( array(
'msg' => 'Basic registry',
'modules' => array(
'test.blank' => new ResourceLoaderTestModule(),
),
'out' => '
mw.loader.addSource( {
"local": "/w/load.php"
} );mw.loader.register( [
[
"test.blank",
1388534400
]
] );',
) ),
array( array(
'msg' => 'Group signature',
'modules' => array(
'test.blank' => new ResourceLoaderTestModule(),
'test.group.foo' => new ResourceLoaderTestModule( array( 'group' => 'x-foo' ) ),
'test.group.bar' => new ResourceLoaderTestModule( array( 'group' => 'x-bar' ) ),
),
'out' => '
mw.loader.addSource( {
"local": "/w/load.php"
} );mw.loader.register( [
[
"test.blank",
1388534400
],
[
"test.group.foo",
1388534400,
[],
"x-foo"
],
[
"test.group.bar",
1388534400,
[],
"x-bar"
]
] );'
) ),
array( array(
'msg' => 'Different target (non-test should not be registered)',
'modules' => array(
'test.blank' => new ResourceLoaderTestModule(),
'test.target.foo' => new ResourceLoaderTestModule( array( 'targets' => array( 'x-foo' ) ) ),
),
'out' => '
mw.loader.addSource( {
"local": "/w/load.php"
} );mw.loader.register( [
[
"test.blank",
1388534400
]
] );'
) ),
array( array(
'msg' => 'Foreign source',
'sources' => array(
'example' => array(
'loadScript' => 'http://example.org/w/load.php',
'apiScript' => 'http://example.org/w/api.php',
),
),
'modules' => array(
'test.blank' => new ResourceLoaderTestModule( array( 'source' => 'example' ) ),
),
'out' => '
mw.loader.addSource( {
"local": "/w/load.php",
"example": "http://example.org/w/load.php"
} );mw.loader.register( [
[
"test.blank",
1388534400,
[],
null,
"example"
]
] );'
) ),
array( array(
'msg' => 'Conditional dependency function',
'modules' => array(
'test.x.core' => new ResourceLoaderTestModule(),
'test.x.polyfill' => new ResourceLoaderTestModule( array(
'skipFunction' => 'return true;'
) ),
'test.y.polyfill' => new ResourceLoaderTestModule( array(
'skipFunction' =>
'return !!(' .
' window.JSON &&' .
' JSON.parse &&' .
' JSON.stringify' .
');'
) ),
'test.z.foo' => new ResourceLoaderTestModule( array(
'dependencies' => array(
'test.x.core',
'test.x.polyfill',
'test.y.polyfill',
),
) ),
),
'out' => '
mw.loader.addSource( {
"local": "/w/load.php"
} );mw.loader.register( [
[
"test.x.core",
1388534400
],
[
"test.x.polyfill",
1388534400,
[],
null,
null,
"return true;"
],
[
"test.y.polyfill",
1388534400,
[],
null,
null,
"return !!( window.JSON \u0026\u0026 JSON.parse \u0026\u0026 JSON.stringify);"
],
[
"test.z.foo",
1388534400,
[
0,
1,
2
]
]
] );',
) ),
array( array(
// This may seem like an edge case, but a plain MediaWiki core install
// with a few extensions installed is likely far more complex than this
// even, not to mention an install like Wikipedia.
// TODO: Make this even more realistic.
'msg' => 'Advanced (everything combined)',
'sources' => array(
'example' => array(
'loadScript' => 'http://example.org/w/load.php',
'apiScript' => 'http://example.org/w/api.php',
),
),
'modules' => array(
'test.blank' => new ResourceLoaderTestModule(),
'test.x.core' => new ResourceLoaderTestModule(),
'test.x.util' => new ResourceLoaderTestModule( array(
'dependencies' => array(
'test.x.core',
),
) ),
'test.x.foo' => new ResourceLoaderTestModule( array(
'dependencies' => array(
'test.x.core',
),
) ),
'test.x.bar' => new ResourceLoaderTestModule( array(
'dependencies' => array(
'test.x.core',
'test.x.util',
),
) ),
'test.x.quux' => new ResourceLoaderTestModule( array(
'dependencies' => array(
'test.x.foo',
'test.x.bar',
'test.x.util',
'test.x.unknown',
),
) ),
'test.group.foo.1' => new ResourceLoaderTestModule( array(
'group' => 'x-foo',
) ),
'test.group.foo.2' => new ResourceLoaderTestModule( array(
'group' => 'x-foo',
) ),
'test.group.bar.1' => new ResourceLoaderTestModule( array(
'group' => 'x-bar',
) ),
'test.group.bar.2' => new ResourceLoaderTestModule( array(
'group' => 'x-bar',
'source' => 'example',
) ),
'test.target.foo' => new ResourceLoaderTestModule( array(
'targets' => array( 'x-foo' ),
) ),
'test.target.bar' => new ResourceLoaderTestModule( array(
'source' => 'example',
'targets' => array( 'x-foo' ),
) ),
),
'out' => '
mw.loader.addSource( {
"local": "/w/load.php",
"example": "http://example.org/w/load.php"
} );mw.loader.register( [
[
"test.blank",
1388534400
],
[
"test.x.core",
1388534400
],
[
"test.x.util",
1388534400,
[
1
]
],
[
"test.x.foo",
1388534400,
[
1
]
],
[
"test.x.bar",
1388534400,
[
2
]
],
[
"test.x.quux",
1388534400,
[
3,
4,
"test.x.unknown"
]
],
[
"test.group.foo.1",
1388534400,
[],
"x-foo"
],
[
"test.group.foo.2",
1388534400,
[],
"x-foo"
],
[
"test.group.bar.1",
1388534400,
[],
"x-bar"
],
[
"test.group.bar.2",
1388534400,
[],
"x-bar",
"example"
]
] );'
) ),
);
}
/**
* @dataProvider provideGetModuleRegistrations
* @covers ResourceLoaderStartupModule::compileUnresolvedDependencies
* @covers ResourceLoaderStartUpModule::getModuleRegistrations
* @covers ResourceLoader::makeLoaderSourcesScript
* @covers ResourceLoader::makeLoaderRegisterScript
*/
public function testGetModuleRegistrations( $case ) {
if ( isset( $case['sources'] ) ) {
$this->setMwGlobals( 'wgResourceLoaderSources', $case['sources'] );
}
$context = self::getResourceLoaderContext();
$rl = $context->getResourceLoader();
$rl->register( $case['modules'] );
$module = new ResourceLoaderStartUpModule();
$this->assertEquals(
ltrim( $case['out'], "\n" ),
$module->getModuleRegistrations( $context ),
$case['msg']
);
}
public static function provideRegistrations() {
return array(
array( array(
'test.blank' => new ResourceLoaderTestModule(),
'test.min' => new ResourceLoaderTestModule( array(
'skipFunction' =>
'return !!(' .
' window.JSON &&' .
' JSON.parse &&' .
' JSON.stringify' .
');',
'dependencies' => array(
'test.blank',
),
) ),
) )
);
}
/**
* @dataProvider provideRegistrations
*/
public function testRegistrationsMinified( $modules ) {
$this->setMwGlobals( 'wgResourceLoaderDebug', false );
$context = self::getResourceLoaderContext();
$rl = $context->getResourceLoader();
$rl->register( $modules );
$module = new ResourceLoaderStartUpModule();
$this->assertEquals(
'mw.loader.addSource({"local":"/w/load.php"});'
. 'mw.loader.register(['
. '["test.blank",1388534400],'
. '["test.min",1388534400,[0],null,null,'
. '"return!!(window.JSON\u0026\u0026JSON.parse\u0026\u0026JSON.stringify);"'
. ']]);',
$module->getModuleRegistrations( $context ),
'Minified output'
);
}
/**
* @dataProvider provideRegistrations
*/
public function testRegistrationsUnminified( $modules ) {
$context = self::getResourceLoaderContext();
$rl = $context->getResourceLoader();
$rl->register( $modules );
$module = new ResourceLoaderStartUpModule();
$this->assertEquals(
'mw.loader.addSource( {
"local": "/w/load.php"
} );mw.loader.register( [
[
"test.blank",
1388534400
],
[
"test.min",
1388534400,
[
0
],
null,
null,
"return !!( window.JSON \u0026\u0026 JSON.parse \u0026\u0026 JSON.stringify);"
]
] );',
$module->getModuleRegistrations( $context ),
'Unminified output'
);
}
}