class MenuModuleTestCase in SimpleTest 6
Hierarchy
- class \DrupalTestCase extends \WebTestCase
- class \MenuModuleTestCase
Expanded class hierarchy of MenuModuleTestCase
File
- tests/
menu_module.test, line 3
View source
class MenuModuleTestCase extends DrupalTestCase {
/**
* Implementation of get_info() for information
*/
function get_info() {
return array(
'name' => t('Menu link creation/deletion'),
'desc' => t('Create two links in the Navigation menu, check their data, and delete them using the menu module UI.'),
'group' => 'Menu Module Tests',
);
}
function setUp() {
parent::setUp();
$this
->drupalModuleEnable('menu');
}
function testCreateCheckDelete() {
$web_user = $this
->drupalCreateUserRolePerm(array(
'access content',
'administer menu',
'access administration pages',
));
$this
->drupalLoginUser($web_user);
$mlid1 = $this
->uiCreateLink();
$mlid2 = $this
->uiCreateLink($mlid1);
$link1 = menu_link_load($mlid1);
$this
->assertTrue((bool) $link1, '1st link created and loaded');
$link2 = menu_link_load($mlid2);
$this
->assertTrue((bool) $link2, '2nd link created as child and loaded');
// Check the structure in the DB of the two links.
// In general, if $n = $link['depth'] then $link['p'. $n] == $link['mlid'] and $link['p'. ($n - 1)] == $link['plid'] (unless depth == 0).
// All $link['p'. $n] for $n > depth must be 0.
// We know link1 is at the top level, so $link1['deptj'] == 1 and $link1['plid'] == 0.
// We know that the parent of link2 is link1, so $link2['plid'] == $link1['mlid'].
// Both links were created in the avigation menu.
$this
->assertTrue($link1['p2'] == 0 && $link1['p1'] == $mlid1 && $link1['plid'] == 0 && $link1['depth'] == 1 && $link1['has_children'], '1st link has correct data');
$this
->assertTrue($link2['menu_name'] == 'navigation' && $link2['p2'] == $mlid2 && $link2['p1'] == $mlid1 && $link2['plid'] == $mlid1 && $link2['depth'] == 2, '2nd link has correct data');
$this
->uiDeleteLink($mlid1);
$this
->assertFalse(menu_link_load($mlid1), '1st link deleted');
$link2 = menu_link_load($mlid2);
$this
->assertTrue($link2['plid'] == 0, '2nd link re-parented');
$this
->uiDeleteLink($mlid2);
$this
->assertFalse(menu_link_load($mlid2), '2nd link link deleted');
}
/**
* Delete a menu link using the menu module UI.
*/
function uiDeleteLink($mlid) {
$this
->drupalPost("admin/build/menu/item/" . $mlid . "/delete", array(), "Confirm");
}
/**
* Create a menu link using the menu module UI.
*/
function uiCreateLink($plid = 0, $menu_name = 'navigation') {
$this
->drupalGet("admin/build/menu-customize/{$menu_name}/add");
$this
->assertResponse(200);
$title = '!link_' . $this
->randomName(16);
$edit = array(
'menu[link_path]' => '<front>',
'menu[link_title]' => $title,
'menu[description]' => '',
'menu[parent]' => $menu_name . ':' . $plid,
'menu[weight]' => '0',
);
$this
->drupalPost("admin/build/menu-customize/" . $menu_name . "/add", $edit, "Save");
$out = $this
->drupalGet("admin/build/menu-customize/{$menu_name}");
$this
->assertText($title, 'Link created');
$mlid = db_result(db_query("SELECT mlid FROM {menu_links} WHERE link_title = '%s'", $title));
return $mlid;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
function | Will trigger a pass if both parameters refer to different objects. Fail otherwise. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have the same value only. Otherwise a fail. | ||
DrupalTestCase:: |
function | Confirms that an error has occurred and optionally that the error text matches exactly. | ||
DrupalTestCase:: |
function | Confirms that an error has occurred and that the error text matches a Perl regular expression. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have the same value and same type. Otherwise a fail. | ||
DrupalTestCase:: |
function | Type and class test. Will pass if class matches the type name or is a subclass or if not an object, but the type is correct. | ||
DrupalTestCase:: |
function | Confirms that no errors have occurred so far in the test method. | ||
DrupalTestCase:: |
function | Type and class mismatch test. Will pass if class name or underling type does not match the one specified. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have a different value. Otherwise a fail. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have the different value or different type. | ||
DrupalTestCase:: |
function | Will be true if the value is set. | ||
DrupalTestCase:: |
function | Will trigger a pass if the Perl regex pattern is not present in subject. Fail if found. | ||
DrupalTestCase:: |
function | Will trigger a pass if the raw text is NOT found on the loaded page Fail otherwise. | ||
DrupalTestCase:: |
function | Will be true if the value is null. | ||
DrupalTestCase:: |
function | Will trigger a pass if both parameters refer to the same object. Fail otherwise. | ||
DrupalTestCase:: |
function | Will trigger a pass if the Perl regex pattern is found in the subject. Fail otherwise. | ||
DrupalTestCase:: |
function | Will trigger a pass if the raw text is found on the loaded page Fail otherwise. | ||
DrupalTestCase:: |
function | Retrieves and saves current modules list into $_originalModules and $_modules. | ||
DrupalTestCase:: |
function | Follows a link by name. | ||
DrupalTestCase:: |
function | @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site. | ||
DrupalTestCase:: |
function | Creates a custom content type based on default settings. | ||
DrupalTestCase:: |
function | Creates a node based on default settings. | ||
DrupalTestCase:: |
function | Create a role / perm combination specified by permissions | ||
DrupalTestCase:: |
function | Creates a user / role / permissions combination specified by permissions | ||
DrupalTestCase:: |
function | @abstract Broker for the get function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com> | ||
DrupalTestCase:: |
function | @TODO: needs documentation | ||
DrupalTestCase:: |
function | Logs in a user with the internal browser | ||
DrupalTestCase:: |
function | Disables a drupal module | ||
DrupalTestCase:: |
function | Enables a drupal module | ||
DrupalTestCase:: |
function | Do a post request on a drupal page. It will be done as usual post request with SimpleBrowser By $reporting you specify if this request does assertions or not Warning: empty ("") returns will cause fails with $reporting | ||
DrupalTestCase:: |
function | @abstract Broker for the post function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com> | ||
DrupalTestCase:: |
function | |||
DrupalTestCase:: |
function | Set a drupal variable and keep track of the changes for tearDown() | ||
DrupalTestCase:: |
function | Generates a random string, to be used as name or whatever | ||
DrupalTestCase:: |
function | Just some info for the reporter | ||
DrupalTestCase:: |
function | tearDown implementation, setting back switched modules etc | 8 | |
MenuModuleTestCase:: |
function | Implementation of get_info() for information | 1 | |
MenuModuleTestCase:: |
function | 1 | ||
MenuModuleTestCase:: |
function | 1 | ||
MenuModuleTestCase:: |
function | Create a menu link using the menu module UI. | ||
MenuModuleTestCase:: |
function | Delete a menu link using the menu module UI. |