mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
ENHANCEMENT Added test suite (currently just testing menu generation)
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@52175 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
d713777d73
commit
755d6bb484
47
tests/LeftAndMainTest.php
Normal file
47
tests/LeftAndMainTest.php
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
<?php
|
||||||
|
class LeftAndMainTest extends SapphireTest {
|
||||||
|
|
||||||
|
public function testMainMenuSpecification() {
|
||||||
|
|
||||||
|
// clear existing menu
|
||||||
|
LeftAndMain::clear_menu();
|
||||||
|
$allMenuItems = LeftAndMain::get_menu_items();
|
||||||
|
$this->assertTrue((empty($allMenuItems)), 'Menu can be cleared');
|
||||||
|
|
||||||
|
// populate defaults and check for "content" entry
|
||||||
|
LeftAndMain::populate_default_menu();
|
||||||
|
$contentMenuItem = LeftAndMain::get_menu_item('content');
|
||||||
|
$this->assertTrue((is_array($contentMenuItem)) && !empty($contentMenuItem), '"Content" menu entry exists');
|
||||||
|
|
||||||
|
// try duplicate adding
|
||||||
|
$duplicateAddSuccess = LeftAndMain::add_menu_item(
|
||||||
|
"content",
|
||||||
|
_t('LeftAndMain.SITECONTENT',"Site Content",PR_HIGH,"Menu title"),
|
||||||
|
"admin/",
|
||||||
|
"CMSMain"
|
||||||
|
);
|
||||||
|
$this->assertTrue(($duplicateAddSuccess === false), '"Content" menu entry can\'t be readded through add_menu_item()');
|
||||||
|
|
||||||
|
// try replacing
|
||||||
|
$replaceSuccess = LeftAndMain::replace_menu_item(
|
||||||
|
"content",
|
||||||
|
'My Custom Title',
|
||||||
|
"mycustomroute",
|
||||||
|
"MyCMSMain"
|
||||||
|
);
|
||||||
|
$replacedMenuItem = LeftAndMain::get_menu_item("content");
|
||||||
|
$this->assertEquals($replacedMenuItem['title'],'My Custom Title');
|
||||||
|
$this->assertEquals($replacedMenuItem['url'],'mycustomroute');
|
||||||
|
$this->assertEquals($replacedMenuItem['controllerClass'],'MyCMSMain');
|
||||||
|
|
||||||
|
// try removing
|
||||||
|
LeftAndMain::remove_menu_item("content");
|
||||||
|
$removedMenuItem = LeftAndMain::get_menu_item("content");
|
||||||
|
$this->assertTrue(($removedMenuItem === false), 'Menu item can be removed');
|
||||||
|
|
||||||
|
// restore default menu
|
||||||
|
LeftAndMain::populate_default_menu();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
?>
|
Loading…
Reference in New Issue
Block a user