Add more test cases to ActionTest
authorThiemo Mättig <thiemo.maettig@wikimedia.de>
Thu, 17 Jul 2014 07:36:54 +0000 (09:36 +0200)
committerThiemo Mättig <thiemo.maettig@wikimedia.de>
Tue, 22 Jul 2014 10:37:05 +0000 (12:37 +0200)
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

index 0c67db7..1297af3 100644 (file)
@@ -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 );
        }
 
 }