mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
MINOR: Tests for r64981
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@64982 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
ba4a1acc68
commit
50ea85d47a
@ -82,6 +82,29 @@ class RequestHandlingTest extends SapphireTest {
|
|||||||
$response = Director::test("testGoodBase1/TestForm/fields/SubclassedField");
|
$response = Director::test("testGoodBase1/TestForm/fields/SubclassedField");
|
||||||
$this->assertEquals("SubclassedField requested", $response->getBody());
|
$this->assertEquals("SubclassedField requested", $response->getBody());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function testDisallowedExtendedActions() {
|
||||||
|
/* Actions on magic methods are only accessible if explicitly allowed on the controller. */
|
||||||
|
$response = Director::test("testGoodBase1/extendedMethod");
|
||||||
|
$this->assertEquals(403, $response->getStatusCode());
|
||||||
|
|
||||||
|
/* Actions on an extension are allowed because they specifically provided appropriate allowed_actions items */
|
||||||
|
$response = Director::test("testGoodBase1/otherExtendedMethod");
|
||||||
|
$this->assertEquals("otherExtendedMethod", $response->getBody());
|
||||||
|
|
||||||
|
/* The failoverMethod action wasn't explicitly listed and so isnt' allowed */
|
||||||
|
$response = Director::test("testGoodBase1/failoverMethod");
|
||||||
|
$this->assertEquals(403, $response->getStatusCode());
|
||||||
|
|
||||||
|
/* However, on RequestHandlingTest_AllowedController it has been explicitly allowed */
|
||||||
|
$response = Director::test("RequestHandlingTest_AllowedController/failoverMethod");
|
||||||
|
$this->assertEquals("failoverMethod", $response->getBody());
|
||||||
|
|
||||||
|
/* The action on the extension has also been explicitly allowed even though it wasn't on the extension */
|
||||||
|
$response = Director::test("RequestHandlingTest_AllowedController/extendedMethod");
|
||||||
|
$this->assertEquals("extendedMethod", $response->getBody());
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -119,6 +142,16 @@ class RequestHandlingTest_Controller extends Controller {
|
|||||||
'$Action//$ID/$OtherID' => "handleAction",
|
'$Action//$ID/$OtherID' => "handleAction",
|
||||||
);
|
);
|
||||||
|
|
||||||
|
static $extensions = array(
|
||||||
|
'RequestHandlingTest_ControllerExtension',
|
||||||
|
'RequestHandlingTest_AllowedControllerExtension',
|
||||||
|
);
|
||||||
|
|
||||||
|
function __construct() {
|
||||||
|
$this->failover = new RequestHandlingTest_ControllerFailover();
|
||||||
|
parent::__construct();
|
||||||
|
}
|
||||||
|
|
||||||
function index($request) {
|
function index($request) {
|
||||||
return "This is the controller";
|
return "This is the controller";
|
||||||
}
|
}
|
||||||
@ -145,6 +178,63 @@ class RequestHandlingTest_Controller extends Controller {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Simple extension for the test controller
|
||||||
|
*/
|
||||||
|
class RequestHandlingTest_ControllerExtension extends Extension {
|
||||||
|
function extendedMethod() {
|
||||||
|
return "extendedMethod";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Controller for the test
|
||||||
|
*/
|
||||||
|
class RequestHandlingTest_AllowedController extends Controller {
|
||||||
|
static $url_handlers = array(
|
||||||
|
// The double-slash is need here to ensure that
|
||||||
|
'$Action//$ID/$OtherID' => "handleAction",
|
||||||
|
);
|
||||||
|
|
||||||
|
static $allowed_actions = array(
|
||||||
|
'failoverMethod', // part of the failover object
|
||||||
|
'extendedMethod', // part of the RequestHandlingTest_ControllerExtension object
|
||||||
|
);
|
||||||
|
|
||||||
|
static $extensions = array(
|
||||||
|
'RequestHandlingTest_ControllerExtension',
|
||||||
|
'RequestHandlingTest_AllowedControllerExtension',
|
||||||
|
);
|
||||||
|
|
||||||
|
function __construct() {
|
||||||
|
$this->failover = new RequestHandlingTest_ControllerFailover();
|
||||||
|
parent::__construct();
|
||||||
|
}
|
||||||
|
|
||||||
|
function index($request) {
|
||||||
|
return "This is the controller";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Simple extension for the test controller - with allowed_actions define
|
||||||
|
*/
|
||||||
|
class RequestHandlingTest_AllowedControllerExtension extends Extension {
|
||||||
|
static $allowed_actions = array(
|
||||||
|
'otherExtendedMethod'
|
||||||
|
);
|
||||||
|
|
||||||
|
function otherExtendedMethod() {
|
||||||
|
return "otherExtendedMethod";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class RequestHandlingTest_ControllerFailover extends ViewableData {
|
||||||
|
function failoverMethod() {
|
||||||
|
return "failoverMethod";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Form for the test
|
* Form for the test
|
||||||
*/
|
*/
|
||||||
@ -217,8 +307,8 @@ class RequestHandlingTest_SubclassedFormField extends RequestHandlingTest_FormFi
|
|||||||
'something' => 'customSomething',
|
'something' => 'customSomething',
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
function customSomething() {
|
function customSomething() {
|
||||||
return "customSomething";
|
return "customSomething";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user