* Re-order method tests to match source class.
* Add @covers.
* Add tests to make coverage 100%.
Change-Id: I46bdb66bc08120a82d44208a39d2dd6b7de18de1
/**
* @group ResourceLoader
/**
* @group ResourceLoader
+ * @covers DerivativeResourceLoaderContext
*/
class DerivativeResourceLoaderContextTest extends PHPUnit_Framework_TestCase {
*/
class DerivativeResourceLoaderContextTest extends PHPUnit_Framework_TestCase {
- protected static function getResourceLoaderContext() {
- $resourceLoader = new ResourceLoader();
+ protected static function getContext() {
$request = new FauxRequest( [
'lang' => 'zh',
'modules' => 'test.context',
$request = new FauxRequest( [
'lang' => 'zh',
'modules' => 'test.context',
'skin' => 'fallback',
'target' => 'test',
] );
'skin' => 'fallback',
'target' => 'test',
] );
- return new ResourceLoaderContext( $resourceLoader, $request );
+ return new ResourceLoaderContext( new ResourceLoader(), $request );
- public function testGet() {
- $context = self::getResourceLoaderContext();
- $derived = new DerivativeResourceLoaderContext( $context );
+ public function testGetInherited() {
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
+ // Request parameters
+ $this->assertEquals( $derived->getDebug(), false );
$this->assertEquals( $derived->getLanguage(), 'zh' );
$this->assertEquals( $derived->getModules(), [ 'test.context' ] );
$this->assertEquals( $derived->getOnly(), 'scripts' );
$this->assertEquals( $derived->getSkin(), 'fallback' );
$this->assertEquals( $derived->getLanguage(), 'zh' );
$this->assertEquals( $derived->getModules(), [ 'test.context' ] );
$this->assertEquals( $derived->getOnly(), 'scripts' );
$this->assertEquals( $derived->getSkin(), 'fallback' );
+ $this->assertEquals( $derived->getUser(), null );
+
+ // Misc
+ $this->assertEquals( $derived->getDirection(), 'ltr' );
$this->assertEquals( $derived->getHash(), 'zh|fallback|||scripts|||||' );
}
$this->assertEquals( $derived->getHash(), 'zh|fallback|||scripts|||||' );
}
- public function testSetLanguage() {
- $context = self::getResourceLoaderContext();
+ public function testModules() {
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
+
+ $derived->setModules( [ 'test.override' ] );
+ $this->assertEquals( $derived->getModules(), [ 'test.override' ] );
+ }
+
+ public function testLanguage() {
+ $context = self::getContext();
$derived = new DerivativeResourceLoaderContext( $context );
$derived->setLanguage( 'nl' );
$this->assertEquals( $derived->getLanguage(), 'nl' );
$derived = new DerivativeResourceLoaderContext( $context );
$derived->setLanguage( 'nl' );
$this->assertEquals( $derived->getLanguage(), 'nl' );
+ }
+
+ public function testDirection() {
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
+
+ $derived->setLanguage( 'nl' );
+ $this->assertEquals( $derived->getDirection(), 'ltr' );
$derived->setLanguage( 'he' );
$this->assertEquals( $derived->getDirection(), 'rtl' );
$derived->setLanguage( 'he' );
$this->assertEquals( $derived->getDirection(), 'rtl' );
+
+ $derived->setDirection( 'ltr' );
+ $this->assertEquals( $derived->getDirection(), 'ltr' );
- public function testSetModules() {
- $context = self::getResourceLoaderContext();
- $derived = new DerivativeResourceLoaderContext( $context );
+ public function testSkin() {
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
- $derived->setModules( [ 'test.override' ] );
- $this->assertEquals( $derived->getModules(), [ 'test.override' ] );
+ $derived->setSkin( 'override' );
+ $this->assertEquals( $derived->getSkin(), 'override' );
- public function testSetOnly() {
- $context = self::getResourceLoaderContext();
- $derived = new DerivativeResourceLoaderContext( $context );
+ public function testUser() {
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
+
+ $derived->setUser( 'Example' );
+ $this->assertEquals( $derived->getUser(), 'Example' );
+ }
+
+ public function testDebug() {
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
+
+ $derived->setDebug( true );
+ $this->assertEquals( $derived->getDebug(), true );
+ }
+
+ public function testOnly() {
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
$derived->setOnly( 'styles' );
$this->assertEquals( $derived->getOnly(), 'styles' );
$derived->setOnly( 'styles' );
$this->assertEquals( $derived->getOnly(), 'styles' );
$this->assertEquals( $derived->getOnly(), null );
}
$this->assertEquals( $derived->getOnly(), null );
}
- public function testSetSkin() {
- $context = self::getResourceLoaderContext();
- $derived = new DerivativeResourceLoaderContext( $context );
+ public function testVersion() {
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
- $derived->setSkin( 'override' );
- $this->assertEquals( $derived->getSkin(), 'override' );
+ $derived->setVersion( 'hw1' );
+ $this->assertEquals( $derived->getVersion(), 'hw1' );
+ }
+
+ public function testRaw() {
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
+
+ $derived->setRaw( true );
+ $this->assertEquals( $derived->getRaw(), true );
}
public function testGetHash() {
}
public function testGetHash() {
- $context = self::getResourceLoaderContext();
- $derived = new DerivativeResourceLoaderContext( $context );
+ $derived = new DerivativeResourceLoaderContext( self::getContext() );
+
+ $this->assertEquals( $derived->getHash(), 'zh|fallback|||scripts|||||' );
$derived->setLanguage( 'nl' );
$derived->setLanguage( 'nl' );
+ $derived->setUser( 'Example' );
// Assert that subclass is able to clear parent class "hash" member
// Assert that subclass is able to clear parent class "hash" member
- $this->assertEquals( $derived->getHash(), 'nl|fallback|||scripts|||||' );
+ $this->assertEquals( $derived->getHash(), 'nl|fallback||Example|scripts|||||' );
+ public function testAccessors() {
+ $context = self::getContext();
+ $derived = new DerivativeResourceLoaderContext( $context );
+ $this->assertSame( $derived->getRequest(), $context->getRequest() );
+ $this->assertSame( $derived->getResourceLoader(), $context->getResourceLoader() );
+ }