mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 08:05:56 +02:00
BUGFIX Validate SiteTree::$can_be_root on saving, as well as for VirtualPage originals (AIR-80)
This commit is contained in:
parent
062e3b6a0c
commit
0e4e8034d6
@ -1512,6 +1512,22 @@ class SiteTree extends DataObject implements PermissionProvider,i18nEntityProvid
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// "Can be root" validation
|
||||||
|
if(!$this->stat('can_be_root') && !$this->ParentID) {
|
||||||
|
$result->error(
|
||||||
|
sprintf(
|
||||||
|
_t(
|
||||||
|
'SiteTree.PageTypNotAllowedOnRoot',
|
||||||
|
'Page type "%s" is not allowed on the root level',
|
||||||
|
PR_MEDIUM,
|
||||||
|
'First argument is a class name'
|
||||||
|
),
|
||||||
|
$this->i18n_singular_name()
|
||||||
|
),
|
||||||
|
'CAN_BE_ROOT'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -245,6 +245,29 @@ class VirtualPage extends Page {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function validate() {
|
||||||
|
$result = parent::validate();
|
||||||
|
|
||||||
|
// "Can be root" validation
|
||||||
|
$orig = $this->CopyContentFrom();
|
||||||
|
if(!$orig->stat('can_be_root') && !$this->ParentID) {
|
||||||
|
$result->error(
|
||||||
|
sprintf(
|
||||||
|
_t(
|
||||||
|
'VirtualPage.PageTypNotAllowedOnRoot',
|
||||||
|
'Original page type "%s" is not allowed on the root level for this virtual page',
|
||||||
|
PR_MEDIUM,
|
||||||
|
'First argument is a class name'
|
||||||
|
),
|
||||||
|
$orig->i18n_singular_name()
|
||||||
|
),
|
||||||
|
'CAN_BE_ROOT_VIRTUAL'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Ensure we have an up-to-date version of everything.
|
* Ensure we have an up-to-date version of everything.
|
||||||
*/
|
*/
|
||||||
|
@ -15,7 +15,8 @@ class SiteTreeTest extends SapphireTest {
|
|||||||
'SiteTreeTest_ClassB',
|
'SiteTreeTest_ClassB',
|
||||||
'SiteTreeTest_ClassC',
|
'SiteTreeTest_ClassC',
|
||||||
'SiteTreeTest_ClassD',
|
'SiteTreeTest_ClassD',
|
||||||
'SiteTreeTest_ClassCext'
|
'SiteTreeTest_ClassCext',
|
||||||
|
'SiteTreeTest_NotRoot',
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -848,6 +849,24 @@ class SiteTreeTest extends SapphireTest {
|
|||||||
|
|
||||||
Session::set("loggedInAs", null);
|
Session::set("loggedInAs", null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function testCanBeRoot() {
|
||||||
|
$page = new SiteTree();
|
||||||
|
$page->ParentID = 0;
|
||||||
|
$page->write();
|
||||||
|
|
||||||
|
$notRootPage = new SiteTreeTest_NotRoot();
|
||||||
|
$notRootPage->ParentID = 0;
|
||||||
|
$isDetected = false;
|
||||||
|
try {
|
||||||
|
$notRootPage->write();
|
||||||
|
} catch(ValidationException $e) {
|
||||||
|
$this->assertContains('is not allowed on the root level', $e->getMessage());
|
||||||
|
$isDetected = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!$isDetected) $this->fail('Fails validation with $can_be_root=false');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**#@+
|
/**#@+
|
||||||
@ -906,3 +925,7 @@ class SiteTreeTest_ClassCext extends SiteTreeTest_ClassC implements TestOnly {
|
|||||||
// Override SiteTreeTest_ClassC definitions
|
// Override SiteTreeTest_ClassC definitions
|
||||||
static $allowed_children = array('SiteTreeTest_ClassB');
|
static $allowed_children = array('SiteTreeTest_ClassB');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class SiteTreeTest_NotRoot extends Page implements TestOnly {
|
||||||
|
static $can_be_root = false;
|
||||||
|
}
|
@ -6,6 +6,7 @@ class VirtualPageTest extends SapphireTest {
|
|||||||
protected $extraDataObjects = array(
|
protected $extraDataObjects = array(
|
||||||
'VirtualPageTest_ClassA',
|
'VirtualPageTest_ClassA',
|
||||||
'VirtualPageTest_ClassB',
|
'VirtualPageTest_ClassB',
|
||||||
|
'VirtualPageTest_NotRoot',
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -466,6 +467,33 @@ class VirtualPageTest extends SapphireTest {
|
|||||||
'write() on original page does increment version on related VirtualPage'
|
'write() on original page does increment version on related VirtualPage'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function testCanBeRoot() {
|
||||||
|
$page = new SiteTree();
|
||||||
|
$page->ParentID = 0;
|
||||||
|
$page->write();
|
||||||
|
|
||||||
|
$notRootPage = new VirtualPageTest_NotRoot();
|
||||||
|
// we don't want the original on root, but rather the VirtualPage pointing to it
|
||||||
|
$notRootPage->ParentID = $page->ID;
|
||||||
|
$notRootPage->write();
|
||||||
|
|
||||||
|
$virtual = new VirtualPage();
|
||||||
|
$virtual->CopyContentFromID = $page->ID;
|
||||||
|
$virtual->write();
|
||||||
|
|
||||||
|
$virtual = DataObject::get_by_id('VirtualPage', $virtual->ID, false);
|
||||||
|
$virtual->CopyContentFromID = $notRootPage->ID;
|
||||||
|
$isDetected = false;
|
||||||
|
try {
|
||||||
|
$virtual->write();
|
||||||
|
} catch(ValidationException $e) {
|
||||||
|
$this->assertContains('is not allowed on the root level', $e->getMessage());
|
||||||
|
$isDetected = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!$isDetected) $this->fail('Fails validation with $can_be_root=false');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class VirtualPageTest_ClassA extends Page implements TestOnly {
|
class VirtualPageTest_ClassA extends Page implements TestOnly {
|
||||||
@ -486,3 +514,7 @@ class VirtualPageTest_ClassB extends Page implements TestOnly {
|
|||||||
class VirtualPageTest_ClassC extends Page implements TestOnly {
|
class VirtualPageTest_ClassC extends Page implements TestOnly {
|
||||||
static $allowed_children = array();
|
static $allowed_children = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class VirtualPageTest_NotRoot extends Page implements TestOnly {
|
||||||
|
static $can_be_root = false;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user