From d3e26d290679cd0eb0862c4ebac4898e5da41a91 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Thiemo=20M=C3=A4ttig?= Date: Thu, 17 Jul 2014 09:36:54 +0200 Subject: [PATCH] Add more test cases to ActionTest 1. The 'dummy' test case already tested ucfirst(), but strtolower() was not tested. The new 'DUMMY' tests fixes that. 2. Add a new test where the requested action is false. 3. Refactored the dummy builder a bit to make it easier to reuse. Change-Id: Id7d9adac064b307b04bf6accb83ffd7f217a857c --- tests/phpunit/includes/actions/ActionTest.php | 36 +++++++++++-------- 1 file changed, 21 insertions(+), 15 deletions(-) diff --git a/tests/phpunit/includes/actions/ActionTest.php b/tests/phpunit/includes/actions/ActionTest.php index 0c67db7a96..1297af3326 100644 --- a/tests/phpunit/includes/actions/ActionTest.php +++ b/tests/phpunit/includes/actions/ActionTest.php @@ -13,22 +13,27 @@ class ActionTest extends MediaWikiTestCase { protected function setUp() { parent::setUp(); + $context = $this->getContext(); $this->setMwGlobals( 'wgActions', array( 'null' => null, 'dummy' => true, 'string' => 'NamedDummyAction', 'declared' => 'NonExistingClassName', 'callable' => array( $this, 'dummyActionCallback' ), - 'object' => new InstantiatedDummyAction( $this->getPage(), $this->getContext() ), + 'object' => new InstantiatedDummyAction( $context->getWikiPage(), $context ), ) ); } - private function getPage() { - return WikiPage::factory( Title::makeTitle( 0, 'Title' ) ); - } + private function getContext( $requestedAction = null ) { + $request = new FauxRequest( array( 'action' => $requestedAction ) ); + + $page = WikiPage::factory( Title::makeTitle( 0, 'Title' ) ); + + $context = new DerivativeContext( RequestContext::getMain() ); + $context->setRequest( $request ); + $context->setWikiPage( $page ); - private function getContext() { - return new DerivativeContext( RequestContext::getMain() ); + return $context; } public function actionProvider() { @@ -39,6 +44,7 @@ class ActionTest extends MediaWikiTestCase { array( 'object', 'InstantiatedDummyAction' ), // Capitalization is ignored + array( 'DUMMY', 'DummyAction' ), array( 'STRING', 'NamedDummyAction' ), // Null and non-existing values @@ -46,6 +52,7 @@ class ActionTest extends MediaWikiTestCase { array( 'undeclared', null ), array( '', null ), array( null, null ), + array( false, null ), ); } @@ -57,7 +64,7 @@ class ActionTest extends MediaWikiTestCase { public function testActionExists( $requestedAction, $expected ) { $exists = Action::exists( $requestedAction ); - $this->assertEquals( isset( $expected ), $exists ); + $this->assertSame( $expected !== null, $exists ); } public function testActionExists_doesNotRequireInstantiation() { @@ -73,13 +80,10 @@ class ActionTest extends MediaWikiTestCase { * @param string|null $expected */ public function testGetActionName( $requestedAction, $expected ) { - $context = $this->getContext(); - $context->setWikiPage( $this->getPage() ); - $context->setRequest( new FauxRequest( array( 'action' => $requestedAction ) ) ); - + $context = $this->getContext( $requestedAction ); $actionName = Action::getActionName( $context ); - $this->assertEquals( isset( $expected ) ? $expected : 'nosuchaction', $actionName ); + $this->assertEquals( $expected ?: 'nosuchaction', $actionName ); } /** @@ -88,13 +92,15 @@ class ActionTest extends MediaWikiTestCase { * @param string|null $expected */ public function testActionFactory( $requestedAction, $expected ) { - $action = Action::factory( $requestedAction, $this->getPage(), $this->getContext() ); + $context = $this->getContext(); + $action = Action::factory( $requestedAction, $context->getWikiPage(), $context ); - $this->assertType( isset( $expected ) ? $expected : 'null', $action ); + $this->assertType( $expected ?: 'null', $action ); } public function dummyActionCallback() { - return new CalledDummyAction( $this->getPage(), $this->getContext() ); + $context = $this->getContext(); + return new CalledDummyAction( $context->getWikiPage(), $context ); } } -- 2.20.1