mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Gadgets
synced 2024-11-28 01:00:02 +00:00
83 lines
2.8 KiB
PHP
83 lines
2.8 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group Gadgets
|
|
*/
|
|
class GadgetsTest extends PHPUnit_Framework_TestCase {
|
|
|
|
private function create( $line ) {
|
|
$g = Gadget::newFromDefinition( $line );
|
|
// assertInstanceOf() is available since PHPUnit 3.5
|
|
$this->assertEquals( 'Gadget', get_class( $g ) );
|
|
return $g;
|
|
}
|
|
|
|
function testInvalidLines() {
|
|
$this->assertFalse( Gadget::newFromDefinition( '' ) );
|
|
$this->assertFalse( Gadget::newFromDefinition( '<foo|bar>' ) );
|
|
}
|
|
|
|
function testSimpleCases() {
|
|
$g = $this->create( '* foo bar| foo.css|foo.js|foo.bar' );
|
|
$this->assertEquals( 'foo_bar', $g->getName() );
|
|
$this->assertEquals( 'ext.gadget.foo_bar', $g->getModuleName() );
|
|
$this->assertEquals( array( 'Gadget-foo.js' ), $g->getScripts() );
|
|
$this->assertEquals( array( 'Gadget-foo.css' ), $g->getStyles() );
|
|
$this->assertEquals( array( 'Gadget-foo.js', 'Gadget-foo.css' ),
|
|
$g->getScriptsAndStyles() );
|
|
$this->assertEquals( array( 'Gadget-foo.js' ), $g->getLegacyScripts() );
|
|
$this->assertFalse( $g->supportsResourceLoader() );
|
|
$this->assertTrue( $g->hasModule() );
|
|
}
|
|
|
|
function testRLtag() {
|
|
$g = $this->create( '*foo [ResourceLoader]|foo.js|foo.css' );
|
|
$this->assertEquals( 'foo', $g->getName() );
|
|
$this->assertTrue( $g->supportsResourceLoader() );
|
|
$this->assertEquals(0, count( $g->getLegacyScripts() ) );
|
|
}
|
|
|
|
function testDependencies() {
|
|
$g = $this->create( '* foo[ResourceLoader|dependencies=jquery.ui]|bar.js' );
|
|
$this->assertEquals( array( 'Gadget-bar.js' ), $g->getScripts() );
|
|
$this->assertTrue( $g->supportsResourceLoader() );
|
|
$this->assertEquals( array( 'jquery.ui' ), $g->getDependencies() );
|
|
}
|
|
|
|
function testPreferences() {
|
|
global $wgUser;
|
|
|
|
// This test makes call to the parser which requires valids Outputpage
|
|
// and Title objects. Set them up there, they will be released at the
|
|
// end of the test.
|
|
global $wgOut, $wgTitle;
|
|
$old_wgOut = $wgOut;
|
|
$old_wgTitle = $wgTitle;
|
|
$wgTitle = Title::newFromText( 'Parser test for Gadgets extension' );
|
|
|
|
// Proceed with test setup:
|
|
$prefs = array();
|
|
$context = new RequestContext();
|
|
$wgOut = $context->getOutput();
|
|
$wgOut->setTitle( Title::newFromText( 'test' ) );
|
|
|
|
Gadget::loadStructuredList( '* foo | foo.js
|
|
==keep-section1==
|
|
* bar| bar.js
|
|
==remove-section==
|
|
* baz [rights=embezzle] |baz.js
|
|
==keep-section2==
|
|
* quux [rights=read] | quux.js' );
|
|
$this->assertTrue( GadgetHooks::getPreferences( $wgUser, $prefs ), 'GetPrefences hook should return true' );
|
|
|
|
$options = $prefs['gadgets']['options'];
|
|
$this->assertFalse( isset( $options['<gadget-section-remove-section>'] ), 'Must not show empty sections' );
|
|
$this->assertTrue( isset( $options['<gadget-section-keep-section1>'] ) );
|
|
$this->assertTrue( isset( $options['<gadget-section-keep-section2>'] ) );
|
|
|
|
// Restore globals
|
|
$wgOut = $old_wgOut;
|
|
$wgTitle = $old_wgTitle;
|
|
}
|
|
}
|