Phuedx has uploaded a new change for review.
https://gerrit.wikimedia.org/r/189958
Change subject: Always run the mobileview API image tranform tests
......................................................................
Always run the mobileview API image tranform tests
... but if PHPUnit is pre-4.0.0, then skip 'em.
Change-Id: I9ad7c3fb91c70ba6a9a10830b5271459140d8dfe
---
M tests/phpunit/api/ApiMobileViewTest.php
1 file changed, 52 insertions(+), 20 deletions(-)
git pull ssh://gerrit.wikimedia.org:29418/mediawiki/extensions/MobileFrontend
refs/changes/58/189958/1
diff --git a/tests/phpunit/api/ApiMobileViewTest.php
b/tests/phpunit/api/ApiMobileViewTest.php
index 210800e..96b1ce2 100644
--- a/tests/phpunit/api/ApiMobileViewTest.php
+++ b/tests/phpunit/api/ApiMobileViewTest.php
@@ -69,6 +69,7 @@
* @group MobileFrontend
*/
class ApiMobileViewTest extends MediaWikiTestCase {
+
/**
* @dataProvider provideSections
*/
@@ -109,21 +110,55 @@
);
}
+ public function setUp() {
+ parent::setUp();
+
+ $this->setMwGlobals( 'wgAPIModules', array( 'mobileview' =>
'MockApiMobileView' ) );
+ }
+
+ private function getMobileViewApi( $input ) {
+ $request = new FauxRequest( $input );
+ $context = new RequestContext();
+ $context->setRequest( $request );
+
+ if ( !defined( 'PAGE_IMAGES_INSTALLED' ) ) {
+ define( 'PAGE_IMAGES_INSTALLED', true );
+ }
+
+ return new MockApiMobileView( new ApiMain( $context ),
'mobileview' );
+ }
+
+ private function executeMobileViewApi( $api, $expected ) {
+ $api->execute();
+ $result = $api->getResultData();
+ $this->assertTrue(
+ isset( $result['mobileview'] ),
+ 'API output should be encloded in mobileview element'
+ );
+ $this->assertArrayEquals( $expected, $result['mobileview'],
false, true );
+ }
+
/**
* @dataProvider provideView
*/
public function testView( array $input, array $expected ) {
- $this->setMwGlobals( 'wgAPIModules', array( 'mobileview' =>
'MockApiMobileView' ) );
+ $api = $this->getMobileViewApi( $input );
+ $this->executeMobileViewApi( $api, $expected );
+ }
- $request = new FauxRequest( $input );
- $context = new RequestContext();
- $context->setRequest( $request );
- if ( !defined( 'PAGE_IMAGES_INSTALLED' ) ) {
- define( 'PAGE_IMAGES_INSTALLED', true );
+ /**
+ * @dataProvider provideViewWithTransforms
+ */
+ public function testViewWithTransforms( array $input, array $expected )
{
+ if ( version_compare(
+ PHPUnit_Runner_Version::id(),
+ '4.0.0',
+ '<'
+ ) ) {
+ $this->markTestSkipped( 'testViewWithTransforms
requires PHPUnit 4.0.0 or greater.' );
}
- $api = new MockApiMobileView( new ApiMain( $context ),
'mobileview' );
- /* FIXME: commented out because WMF CI uses a stone age version
of PHPUnit
+ $api = $this->getMobileViewApi( $input );
$api->mockFile = $this->getMock( 'MockFSFile',
array( 'getWidth', 'getHeight', 'getTitle', 'transform'
),
array(), '', false
@@ -134,15 +169,8 @@
->will( $this->returnValue( Title::newFromText(
'File:Foo.jpg' ) ) );
$api->mockFile->method( 'transform' )
->will( $this->returnCallback( array( $this,
'mockTransform' ) ) );
- */
- $api->execute();
- $result = $api->getResultData();
- $this->assertTrue(
- isset( $result['mobileview'] ),
- 'API output should be encloded in mobileview element'
- );
- $this->assertArrayEquals( $expected, $result['mobileview'],
false, true );
+ $this->executeMobileViewApi( $api, $expected );
}
public function mockTransform( array $params ) {
@@ -244,9 +272,14 @@
'pageprops' => array( 'notoc' => '' ),
),
),
- // Page image tests. Note that the dimensions are
values passed to transform(),
- // not actual thumbnail dimensions.
- /* FIXME: commented out because WMF CI uses a stone age
version of PHPUnit
+ );
+ }
+
+ public function provideViewWithTransforms() {
+
+ // Note that the dimensions are values passed to #transform,
not actual
+ // thumbnail dimensions.
+ return array(
array(
array(
'page' => 'Foo',
@@ -310,7 +343,6 @@
)
),
),
- */
);
}
--
To view, visit https://gerrit.wikimedia.org/r/189958
To unsubscribe, visit https://gerrit.wikimedia.org/r/settings
Gerrit-MessageType: newchange
Gerrit-Change-Id: I9ad7c3fb91c70ba6a9a10830b5271459140d8dfe
Gerrit-PatchSet: 1
Gerrit-Project: mediawiki/extensions/MobileFrontend
Gerrit-Branch: master
Gerrit-Owner: Phuedx <[email protected]>
_______________________________________________
MediaWiki-commits mailing list
[email protected]
https://lists.wikimedia.org/mailman/listinfo/mediawiki-commits