Correcting an issue where page controller methods

would end up with the error page response code, causing them to not work. This code only looks to be causing issues from what I can see.

An example is an autocomplete that is populated using a method on page controller. The moment you end up on a 404 error page, the autocomplete will attempt to populate and end up with a 404 response.
This commit is contained in:
Nathan 2016-10-20 15:35:09 +11:00 committed by Nathan Glasl
parent 02b9de93c3
commit a5b33ab916
2 changed files with 12 additions and 23 deletions

View File

@ -323,22 +323,5 @@ class ErrorPage extends Page {
* @package cms * @package cms
*/ */
class ErrorPage_Controller extends Page_Controller { class ErrorPage_Controller extends Page_Controller {
/**
* Overload the provided {@link Controller::handleRequest()} to append the
* correct status code post request since otherwise permission related error
* pages such as 401 and 403 pages won't be rendered due to
* {@link SS_HTTPResponse::isFinished() ignoring the response body.
*
* @param SS_HTTPRequest $request
* @param DataModel $model
* @return SS_HTTPResponse
*/
public function handleRequest(SS_HTTPRequest $request, DataModel $model = NULL) {
$body = parent::handleRequest($request, $model);
$this->getResponse()->setStatusCode($this->ErrorCode);
return $this->getResponse();
}
} }

View File

@ -65,11 +65,17 @@ class ErrorPageTest extends FunctionalTest {
$page = $this->objFromFixture('ErrorPage', '403'); $page = $this->objFromFixture('ErrorPage', '403');
$page->publish('Stage', 'Live'); $page->publish('Stage', 'Live');
$response = $this->get($page->RelativeLink()); try {
$controller = singleton('ContentController');
$controller->httpError(403);
$this->fail('Expected exception to be thrown');
}
catch(SS_HTTPResponse_Exception $e) {
$response = $e->getResponse();
$this->assertEquals($response->getStatusCode(), '403'); $this->assertEquals($response->getStatusCode(), '403');
$this->assertNotNull($response->getBody(), 'We have body text from the error page'); $this->assertNotNull($response->getBody(), 'We have body text from the error page');
} }
}
public function testSecurityError() { public function testSecurityError() {
// Generate 404 page // Generate 404 page