FIX Make sure VirtualPage renders correct templates

This commit is contained in:
Daniel Hensby 2017-07-17 18:16:02 +01:00
parent f511c262fd
commit 515a7cb569
No known key found for this signature in database
GPG Key ID: 5DE415D786BBB2FD
4 changed files with 28 additions and 10 deletions

View File

@ -496,10 +496,8 @@ class VirtualPage_Controller extends Page_Controller {
} }
public function getViewer($action) { public function getViewer($action) {
$originalClass = get_class($this->CopyContentFrom()); $object = $this->CopyContentFrom();
if ($originalClass == 'SiteTree') $name = 'Page_Controller'; $controller = ModelAsController::controller_for($object, $action);
else $name = $originalClass."_Controller";
$controller = new $name();
return $controller->getViewer($action); return $controller->getViewer($action);
} }
@ -538,11 +536,8 @@ class VirtualPage_Controller extends Page_Controller {
*/ */
public function hasMethod($method) { public function hasMethod($method) {
$haveIt = parent::hasMethod($method); $haveIt = parent::hasMethod($method);
if (!$haveIt) { if (!$haveIt) {
$originalClass = get_class($this->CopyContentFrom()); $controller = ModelAsController::controller_for($this->CopyContentFrom());
if ($originalClass == 'SiteTree') $name = 'ContentController';
else $name = $originalClass."_Controller";
$controller = new $name($this->dataRecord->copyContentFrom());
$haveIt = $controller->hasMethod($method); $haveIt = $controller->hasMethod($method);
} }
return $haveIt; return $haveIt;

View File

@ -9,7 +9,7 @@ class VirtualPageTest extends FunctionalTest {
'VirtualPageTest_ClassA', 'VirtualPageTest_ClassA',
'VirtualPageTest_ClassB', 'VirtualPageTest_ClassB',
'VirtualPageTest_VirtualPageSub', 'VirtualPageTest_VirtualPageSub',
'VirtualPageTest_PageWithAllowedChildren' 'VirtualPageTest_PageWithAllowedChildren',
); );
protected $illegalExtensions = array( protected $illegalExtensions = array(
@ -667,6 +667,27 @@ class VirtualPageTest extends FunctionalTest {
$this->assertEquals(301, $response->getStatusCode()); $this->assertEquals(301, $response->getStatusCode());
$this->assertEquals('http://google.com', $response->getHeader('Location')); $this->assertEquals('http://google.com', $response->getHeader('Location'));
} }
public function testVirtualPageRendersCorrectTemplate() {
$self = $this;
$this->useDraftSite(true);
$this->useTestTheme(dirname(__FILE__), 'virtualpagetest', function() use ($self) {
$page = new VirtualPageTest_ClassA();
$page->Title = 'Test Page';
$page->Content = 'NotThisContent';
$page->MyInitiallyCopiedField = 'TestContent';
$page->write();
$vp = new VirtualPage();
$vp->CopyContentFromID = $page->ID;
$vp->write();
$response = $self->get($vp->Link());
$self->assertEquals(200, $response->getStatusCode());
$self->assertContains('TestContent', $response->getBody());
$self->assertNotContains('NotThisContent', $response->getBody());
});
}
} }
class VirtualPageTest_ClassA extends Page implements TestOnly { class VirtualPageTest_ClassA extends Page implements TestOnly {

View File

@ -0,0 +1 @@
<div>$Content</div>

View File

@ -0,0 +1 @@
<div>$MyInitiallyCopiedField</div>