Formatting

This commit is contained in:
Dan Hensby 2018-09-26 23:43:56 +01:00
parent 5a3cc9503b
commit b0e0566c93
No known key found for this signature in database
GPG Key ID: 3906B235643EF10B
3 changed files with 43 additions and 36 deletions

View File

@ -16,7 +16,6 @@ use SilverStripe\Control\Tests\ControllerTest\TestController;
use SilverStripe\Control\Tests\ControllerTest\UnsecuredController; use SilverStripe\Control\Tests\ControllerTest\UnsecuredController;
use SilverStripe\Dev\FunctionalTest; use SilverStripe\Dev\FunctionalTest;
use SilverStripe\Security\Member; use SilverStripe\Security\Member;
use SilverStripe\Security\Security;
use SilverStripe\View\SSViewer; use SilverStripe\View\SSViewer;
class ControllerTest extends FunctionalTest class ControllerTest extends FunctionalTest
@ -50,7 +49,7 @@ class ControllerTest extends FunctionalTest
$themeDir = substr(__DIR__, strlen(FRAMEWORK_DIR)) . '/ControllerTest/'; $themeDir = substr(__DIR__, strlen(FRAMEWORK_DIR)) . '/ControllerTest/';
$themes = [ $themes = [
"silverstripe/framework:{$themeDir}", "silverstripe/framework:{$themeDir}",
SSViewer::DEFAULT_THEME SSViewer::DEFAULT_THEME,
]; ];
SSViewer::set_themes($themes); SSViewer::set_themes($themes);
} }

View File

@ -3,16 +3,16 @@
namespace SilverStripe\Control\Tests; namespace SilverStripe\Control\Tests;
use SilverStripe\Admin\LeftAndMain; use SilverStripe\Admin\LeftAndMain;
use SilverStripe\ErrorPage\ErrorPageControllerExtension;
use SilverStripe\Control\Controller; use SilverStripe\Control\Controller;
use SilverStripe\Control\Director;
use SilverStripe\Control\RequestHandler;
use SilverStripe\Control\Tests\RequestHandlingTest\AllowedController; use SilverStripe\Control\Tests\RequestHandlingTest\AllowedController;
use SilverStripe\Control\Tests\RequestHandlingTest\ControllerFormWithAllowedActions; use SilverStripe\Control\Tests\RequestHandlingTest\ControllerFormWithAllowedActions;
use SilverStripe\Control\Tests\RequestHandlingTest\FieldController; use SilverStripe\Control\Tests\RequestHandlingTest\FieldController;
use SilverStripe\Control\Tests\RequestHandlingTest\FormActionController; use SilverStripe\Control\Tests\RequestHandlingTest\FormActionController;
use SilverStripe\Control\Tests\RequestHandlingTest\TestController; use SilverStripe\Control\Tests\RequestHandlingTest\TestController;
use SilverStripe\Dev\FunctionalTest; use SilverStripe\Dev\FunctionalTest;
use SilverStripe\Control\RequestHandler; use SilverStripe\ErrorPage\ErrorPageControllerExtension;
use SilverStripe\Control\Director;
use SilverStripe\Forms\Form; use SilverStripe\Forms\Form;
use SilverStripe\Security\SecurityToken; use SilverStripe\Security\SecurityToken;
@ -24,25 +24,25 @@ class RequestHandlingTest extends FunctionalTest
{ {
protected static $fixture_file = null; protected static $fixture_file = null;
protected static $illegal_extensions = array( protected static $illegal_extensions = [
// Suppress CMS error page handling // Suppress CMS error page handling
Controller::class => array( Controller::class => [
ErrorPageControllerExtension::class, ErrorPageControllerExtension::class,
), ],
Form::class => array( Form::class => [
ErrorPageControllerExtension::class, ErrorPageControllerExtension::class,
), ],
LeftAndMain::class => array( LeftAndMain::class => [
ErrorPageControllerExtension::class, ErrorPageControllerExtension::class,
), ],
); ];
protected static $extra_controllers = [ protected static $extra_controllers = [
TestController::class, TestController::class,
AllowedController::class, AllowedController::class,
ControllerFormWithAllowedActions::class, ControllerFormWithAllowedActions::class,
FieldController::class, FieldController::class,
FormActionController::class FormActionController::class,
]; ];
public function getExtraRoutes() public function getExtraRoutes()
@ -99,13 +99,16 @@ class RequestHandlingTest extends FunctionalTest
/* In addition, these values are availalbe in $controller->urlParams. This is mainly for backward /* In addition, these values are availalbe in $controller->urlParams. This is mainly for backward
* compatability. */ * compatability. */
$response = Director::test("testGoodBase1/legacymethod/3/4"); $response = Director::test("testGoodBase1/legacymethod/3/4");
$this->assertEquals("\$this->urlParams can be used, for backward compatibility: 3, 4", $response->getBody()); $this->assertEquals(
"\$this->urlParams can be used, for backward compatibility: 3, 4",
$response->getBody()
);
} }
public function testPostRequests() public function testPostRequests()
{ {
/* The HTTP Request handler can trigger special behaviour for GET and POST. */ /* The HTTP Request handler can trigger special behaviour for GET and POST. */
$response = Director::test("testGoodBase1/TestForm", array("MyField" => 3), null, "POST"); $response = Director::test("testGoodBase1/TestForm", ["MyField" => 3], null, "POST");
$this->assertEquals("Form posted", $response->getBody()); $this->assertEquals("Form posted", $response->getBody());
$response = Director::test("testGoodBase1/TestForm"); $response = Director::test("testGoodBase1/TestForm");
@ -120,7 +123,7 @@ class RequestHandlingTest extends FunctionalTest
$this->assertEquals("MyField requested", $response->getBody()); $this->assertEquals("MyField requested", $response->getBody());
/* We can also make a POST request on a form field, which could be used for in-place editing, for example. */ /* We can also make a POST request on a form field, which could be used for in-place editing, for example. */
$response = Director::test("testGoodBase1/TestForm/fields/MyField", array("MyField" => 5)); $response = Director::test("testGoodBase1/TestForm/fields/MyField", ["MyField" => 5]);
$this->assertEquals("MyField posted, update to 5", $response->getBody()); $this->assertEquals("MyField posted, update to 5", $response->getBody());
} }
@ -128,7 +131,7 @@ class RequestHandlingTest extends FunctionalTest
{ {
$this->withBaseFolder( $this->withBaseFolder(
'/silverstripe', '/silverstripe',
function ($test) { function () {
$this->assertEquals( $this->assertEquals(
'MyField requested', 'MyField requested',
Director::test('/silverstripe/testGoodBase1/TestForm/fields/MyField')->getBody() Director::test('/silverstripe/testGoodBase1/TestForm/fields/MyField')->getBody()
@ -136,7 +139,10 @@ class RequestHandlingTest extends FunctionalTest
$this->assertEquals( $this->assertEquals(
'MyField posted, update to 5', 'MyField posted, update to 5',
Director::test('/silverstripe/testGoodBase1/TestForm/fields/MyField', array('MyField' => 5))->getBody() Director::test(
'/silverstripe/testGoodBase1/TestForm/fields/MyField',
['MyField' => 5]
)->getBody()
); );
} }
); );
@ -148,7 +154,7 @@ class RequestHandlingTest extends FunctionalTest
$response = Director::test("testBadBase/method/1/2"); $response = Director::test("testBadBase/method/1/2");
$this->assertNotEquals("This is a method on the controller: 1, 2", $response->getBody()); $this->assertNotEquals("This is a method on the controller: 1, 2", $response->getBody());
$response = Director::test("testBadBase/TestForm", array("MyField" => 3), null, "POST"); $response = Director::test("testBadBase/TestForm", ["MyField" => 3], null, "POST");
$this->assertNotEquals("Form posted", $response->getBody()); $this->assertNotEquals("Form posted", $response->getBody());
$response = Director::test("testBadBase/TestForm/fields/MyField"); $response = Director::test("testBadBase/TestForm/fields/MyField");
@ -254,7 +260,7 @@ class RequestHandlingTest extends FunctionalTest
$tokenEls = $this->cssParser()->getBySelector('#Form_Form_SecurityID'); $tokenEls = $this->cssParser()->getBySelector('#Form_Form_SecurityID');
$securityId = (string)$tokenEls[0]['value']; $securityId = (string)$tokenEls[0]['value'];
$data = array('action_formaction' => 1); $data = ['action_formaction' => 1];
$response = $this->post('FormActionController/Form', $data); $response = $this->post('FormActionController/Form', $data);
$this->assertEquals( $this->assertEquals(
400, 400,
@ -262,7 +268,7 @@ class RequestHandlingTest extends FunctionalTest
'Should fail: Invocation through POST form handler, not contained in $allowed_actions, without CSRF token' 'Should fail: Invocation through POST form handler, not contained in $allowed_actions, without CSRF token'
); );
$data = array('action_disallowedcontrollermethod' => 1, 'SecurityID' => $securityId); $data = ['action_disallowedcontrollermethod' => 1, 'SecurityID' => $securityId];
$response = $this->post('FormActionController/Form', $data); $response = $this->post('FormActionController/Form', $data);
$this->assertEquals( $this->assertEquals(
403, 403,
@ -271,7 +277,7 @@ class RequestHandlingTest extends FunctionalTest
. ' not contained in $allowed_actions, with CSRF token' . ' not contained in $allowed_actions, with CSRF token'
); );
$data = array('action_formaction' => 1, 'SecurityID' => $securityId); $data = ['action_formaction' => 1, 'SecurityID' => $securityId];
$response = $this->post('FormActionController/Form', $data); $response = $this->post('FormActionController/Form', $data);
$this->assertEquals(200, $response->getStatusCode()); $this->assertEquals(200, $response->getStatusCode());
$this->assertEquals( $this->assertEquals(
@ -280,16 +286,16 @@ class RequestHandlingTest extends FunctionalTest
'Should pass: Invocation through POST form handler, not contained in $allowed_actions, with CSRF token' 'Should pass: Invocation through POST form handler, not contained in $allowed_actions, with CSRF token'
); );
$data = array('action_controlleraction' => 1, 'SecurityID' => $securityId); $data = ['action_controlleraction' => 1, 'SecurityID' => $securityId];
$response = $this->post('FormActionController/Form', $data); $response = $this->post('FormActionController/Form', $data);
$this->assertEquals( $this->assertEquals(
200, 200,
$response->getStatusCode(), $response->getStatusCode(),
'Should pass: Invocation through POST form handler, controller action instead of form action, contained in' 'Should pass: Invocation through POST form handler, controller action instead of form action, contained in'
. ' $allowed_actions, with CSRF token' . ' $allowed_actions, with CSRF token'
); );
$data = array('action_formactionInAllowedActions' => 1); $data = ['action_formactionInAllowedActions' => 1];
$response = $this->post('FormActionController/Form', $data); $response = $this->post('FormActionController/Form', $data);
$this->assertEquals( $this->assertEquals(
400, 400,
@ -297,7 +303,7 @@ class RequestHandlingTest extends FunctionalTest
'Should fail: Invocation through POST form handler, contained in $allowed_actions, without CSRF token' 'Should fail: Invocation through POST form handler, contained in $allowed_actions, without CSRF token'
); );
$data = array('action_formactionInAllowedActions' => 1, 'SecurityID' => $securityId); $data = ['action_formactionInAllowedActions' => 1, 'SecurityID' => $securityId];
$response = $this->post('FormActionController/Form', $data); $response = $this->post('FormActionController/Form', $data);
$this->assertEquals( $this->assertEquals(
200, 200,
@ -305,7 +311,7 @@ class RequestHandlingTest extends FunctionalTest
'Should pass: Invocation through POST form handler, contained in $allowed_actions, with CSRF token' 'Should pass: Invocation through POST form handler, contained in $allowed_actions, with CSRF token'
); );
$data = array(); $data = [];
$response = $this->post('FormActionController/formaction', $data); $response = $this->post('FormActionController/formaction', $data);
$this->assertEquals( $this->assertEquals(
404, 404,
@ -313,7 +319,7 @@ class RequestHandlingTest extends FunctionalTest
'Should fail: Invocation through POST URL, not contained in $allowed_actions, without CSRF token' 'Should fail: Invocation through POST URL, not contained in $allowed_actions, without CSRF token'
); );
$data = array(); $data = [];
$response = $this->post('FormActionController/formactionInAllowedActions', $data); $response = $this->post('FormActionController/formactionInAllowedActions', $data);
$this->assertEquals( $this->assertEquals(
200, 200,
@ -321,7 +327,7 @@ class RequestHandlingTest extends FunctionalTest
'Should pass: Invocation of form action through POST URL, contained in $allowed_actions, without CSRF token' 'Should pass: Invocation of form action through POST URL, contained in $allowed_actions, without CSRF token'
); );
$data = array('SecurityID' => $securityId); $data = ['SecurityID' => $securityId];
$response = $this->post('FormActionController/formactionInAllowedActions', $data); $response = $this->post('FormActionController/formactionInAllowedActions', $data);
$this->assertEquals( $this->assertEquals(
200, 200,
@ -329,7 +335,7 @@ class RequestHandlingTest extends FunctionalTest
'Should pass: Invocation of form action through POST URL, contained in $allowed_actions, with CSRF token' 'Should pass: Invocation of form action through POST URL, contained in $allowed_actions, with CSRF token'
); );
$data = array(); // CSRF protection doesnt kick in for direct requests $data = []; // CSRF protection doesnt kick in for direct requests
$response = $this->post('FormActionController/formactionInAllowedActions', $data); $response = $this->post('FormActionController/formactionInAllowedActions', $data);
$this->assertEquals( $this->assertEquals(
200, 200,
@ -342,12 +348,12 @@ class RequestHandlingTest extends FunctionalTest
public function testAllowedActionsEnforcedOnForm() public function testAllowedActionsEnforcedOnForm()
{ {
$data = array('action_allowedformaction' => 1); $data = ['action_allowedformaction' => 1];
$response = $this->post('ControllerFormWithAllowedActions/Form', $data); $response = $this->post('ControllerFormWithAllowedActions/Form', $data);
$this->assertEquals(200, $response->getStatusCode()); $this->assertEquals(200, $response->getStatusCode());
$this->assertEquals('allowedformaction', $response->getBody()); $this->assertEquals('allowedformaction', $response->getBody());
$data = array('action_disallowedformaction' => 1); $data = ['action_disallowedformaction' => 1];
$response = $this->post('ControllerFormWithAllowedActions/Form', $data); $response = $this->post('ControllerFormWithAllowedActions/Form', $data);
$this->assertEquals(403, $response->getStatusCode()); $this->assertEquals(403, $response->getStatusCode());
// Note: Looks for a specific 403 thrown by Form->httpSubmission(), not RequestHandler->handleRequest() // Note: Looks for a specific 403 thrown by Form->httpSubmission(), not RequestHandler->handleRequest()
@ -356,12 +362,12 @@ class RequestHandlingTest extends FunctionalTest
public function testActionHandlingOnField() public function testActionHandlingOnField()
{ {
$data = array('action_actionOnField' => 1); $data = ['action_actionOnField' => 1];
$response = $this->post('FieldController/TestForm', $data); $response = $this->post('FieldController/TestForm', $data);
$this->assertEquals(200, $response->getStatusCode()); $this->assertEquals(200, $response->getStatusCode());
$this->assertEquals('Test method on MyField', $response->getBody()); $this->assertEquals('Test method on MyField', $response->getBody());
$data = array('action_actionNotAllowedOnField' => 1); $data = ['action_actionNotAllowedOnField' => 1];
$response = $this->post('FieldController/TestForm', $data); $response = $this->post('FieldController/TestForm', $data);
$this->assertEquals(404, $response->getStatusCode()); $this->assertEquals(404, $response->getStatusCode());
} }

View File

@ -32,7 +32,9 @@ class SimpleResourceURLGeneratorTest extends SapphireTest
{ {
/** @var SimpleResourceURLGenerator $generator */ /** @var SimpleResourceURLGenerator $generator */
$generator = Injector::inst()->get(ResourceURLGenerator::class); $generator = Injector::inst()->get(ResourceURLGenerator::class);
$mtime = filemtime(__DIR__ . '/SimpleResourceURLGeneratorTest/_fakewebroot/basemodule/client/file.js'); $mtime = filemtime(
__DIR__ . '/SimpleResourceURLGeneratorTest/_fakewebroot/basemodule/client/file.js'
);
$this->assertEquals( $this->assertEquals(
'/resources/basemodule/client/file.js?m=' . $mtime, '/resources/basemodule/client/file.js?m=' . $mtime,
$generator->urlForResource('basemodule/client/file.js') $generator->urlForResource('basemodule/client/file.js')