You are here

class MenuModuleTestCase in SimpleTest 6

Hierarchy

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

Namesort descending Modifiers Type Description Overrides
DrupalTestCase::$_cleanupContentTypes property
DrupalTestCase::$_cleanupNodes property
DrupalTestCase::$_cleanupRoles property
DrupalTestCase::$_cleanupUsers property
DrupalTestCase::$_cleanupVariables property
DrupalTestCase::$_content property
DrupalTestCase::$_modules property
DrupalTestCase::$_originalModules property
DrupalTestCase::assertCopy function Will trigger a pass if both parameters refer to different objects. Fail otherwise.
DrupalTestCase::assertEqual function Will trigger a pass if the two parameters have the same value only. Otherwise a fail.
DrupalTestCase::assertError function Confirms that an error has occurred and optionally that the error text matches exactly.
DrupalTestCase::assertErrorPattern function Confirms that an error has occurred and that the error text matches a Perl regular expression.
DrupalTestCase::assertIdentical function Will trigger a pass if the two parameters have the same value and same type. Otherwise a fail.
DrupalTestCase::assertIsA 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::assertNoErrors function Confirms that no errors have occurred so far in the test method.
DrupalTestCase::assertNotA function Type and class mismatch test. Will pass if class name or underling type does not match the one specified.
DrupalTestCase::assertNotEqual function Will trigger a pass if the two parameters have a different value. Otherwise a fail.
DrupalTestCase::assertNotIdentical function Will trigger a pass if the two parameters have the different value or different type.
DrupalTestCase::assertNotNull function Will be true if the value is set.
DrupalTestCase::assertNoUnwantedPattern function Will trigger a pass if the Perl regex pattern is not present in subject. Fail if found.
DrupalTestCase::assertNoUnwantedRaw function Will trigger a pass if the raw text is NOT found on the loaded page Fail otherwise.
DrupalTestCase::assertNull function Will be true if the value is null.
DrupalTestCase::assertReference function Will trigger a pass if both parameters refer to the same object. Fail otherwise.
DrupalTestCase::assertWantedPattern function Will trigger a pass if the Perl regex pattern is found in the subject. Fail otherwise.
DrupalTestCase::assertWantedRaw function Will trigger a pass if the raw text is found on the loaded page Fail otherwise.
DrupalTestCase::checkOriginalModules function Retrieves and saves current modules list into $_originalModules and $_modules.
DrupalTestCase::clickLink function Follows a link by name.
DrupalTestCase::drupalCheckAuth function @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site.
DrupalTestCase::drupalCreateContentType function Creates a custom content type based on default settings.
DrupalTestCase::drupalCreateNode function Creates a node based on default settings.
DrupalTestCase::drupalCreateRolePerm function Create a role / perm combination specified by permissions
DrupalTestCase::drupalCreateUserRolePerm function Creates a user / role / permissions combination specified by permissions
DrupalTestCase::drupalGet function @abstract Broker for the get function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com>
DrupalTestCase::drupalGetContent function @TODO: needs documentation
DrupalTestCase::drupalLoginUser function Logs in a user with the internal browser
DrupalTestCase::drupalModuleDisable function Disables a drupal module
DrupalTestCase::drupalModuleEnable function Enables a drupal module
DrupalTestCase::drupalPost 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::drupalRawPost function @abstract Broker for the post function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com>
DrupalTestCase::DrupalTestCase function
DrupalTestCase::drupalVariableSet function Set a drupal variable and keep track of the changes for tearDown()
DrupalTestCase::randomName function Generates a random string, to be used as name or whatever
DrupalTestCase::run function Just some info for the reporter
DrupalTestCase::tearDown function tearDown implementation, setting back switched modules etc 8
MenuModuleTestCase::get_info function Implementation of get_info() for information 1
MenuModuleTestCase::setUp function 1
MenuModuleTestCase::testCreateCheckDelete function 1
MenuModuleTestCase::uiCreateLink function Create a menu link using the menu module UI.
MenuModuleTestCase::uiDeleteLink function Delete a menu link using the menu module UI.