You are here

class BookModuleTestCase in SimpleTest 6

Hierarchy

Expanded class hierarchy of BookModuleTestCase

File

tests/book_module.test, line 3

View source
class BookModuleTestCase extends DrupalTestCase {
  var $book;
  function get_info() {
    return array(
      'name' => t('Book functionality'),
      'desc' => t('Create a book, add pages, and test book interface.'),
      'group' => t('Book Tests'),
    );
  }
  function setUp() {
    parent::setUp();
    $this
      ->drupalModuleEnable('book');
  }

  /**
   * Test book funcitonality through node interfaces.
   */
  function testBook() {

    // create users
    $book_author = $this
      ->drupalCreateUserRolePerm(array(
      'create new books',
      'create book content',
      'add content to books',
    ));
    $web_user = $this
      ->drupalCreateUserRolePerm(array(
      'access printer-friendly version',
    ));

    // create new book
    $this
      ->drupalLoginUser($book_author);
    $this->book = $this
      ->createBookNode('new');
    $book = $this->book;

    /*
     * add page hiearchy to book
     * Book
     *  |- Node 0
     *   |- Node 1
     *   |- Node 2
     *  |- Node 3
     *  |- Node 4
     */
    $nodes = array();
    $nodes[] = $this
      ->createBookNode($book->nid);

    // Node 0
    $nodes[] = $this
      ->createBookNode($book->nid, $nodes[0]->book['mlid']);

    // Node 1
    $nodes[] = $this
      ->createBookNode($book->nid, $nodes[0]->book['mlid']);

    // Node 2
    $nodes[] = $this
      ->createBookNode($book->nid);

    // Node 3
    $nodes[] = $this
      ->createBookNode($book->nid);

    // Node 4
    $this
      ->drupalGet('logout');

    // check to make sure that book pages display properly
    $this
      ->drupalLoginUser($web_user);
    $this
      ->checkBookNode($book, array(
      $nodes[0],
      $nodes[3],
      $nodes[4],
    ), false, false, $nodes[0]);
    $this
      ->checkBookNode($nodes[0], array(
      $nodes[1],
      $nodes[2],
    ), $book, $book, $nodes[1]);
    $this
      ->checkBookNode($nodes[1], NULL, $nodes[0], $nodes[0], $nodes[2]);
    $this
      ->checkBookNode($nodes[2], NULL, $nodes[1], $nodes[0], $nodes[3]);
    $this
      ->checkBookNode($nodes[3], NULL, $nodes[2], $book, $nodes[4]);
    $this
      ->checkBookNode($nodes[4], NULL, $nodes[3], $book, false);
  }

  /**
   * Checks the outline of sub-pages; previous, up, and next; and check printer friendly version.
   *
   * @param Node $node Node to check.
   * @param array $nodes Nodes that should be in outline.
   * @param Node $previous Previous link node.
   * @param Node $up Up link node.
   * @param Node $next Next link node.
   */
  function checkBookNode($node, $nodes, $previous = false, $up = false, $next = false) {
    static $number = 0;
    $this
      ->drupalGet('node/' . $node->nid);

    // check outline structure
    if ($nodes !== NULL) {
      $this
        ->assertPattern($this
        ->generateOutlinePattern($nodes), 'Node ' . $number . ' outline confirmed.');
    }
    else {
      $this
        ->assertNotNull(true, 'Node ' . $number . ' doesn\'t have outline.');
    }

    // check previous, up, and next links
    if ($previous) {
      $this
        ->assertWantedRaw(l('‹ ' . $previous->title, 'node/' . $previous->nid, array(
        'attributes' => array(
          'class' => 'page-previous',
          'title' => t('Go to previous page'),
        ),
      )), 'Prevoius page link found.');
    }
    if ($up) {
      $this
        ->assertWantedRaw(l('up', 'node/' . $up->nid, array(
        'attributes' => array(
          'class' => 'page-up',
          'title' => t('Go to parent page'),
        ),
      )), 'Up page link found.');
    }
    if ($next) {
      $this
        ->assertWantedRaw(l($next->title . ' ›', 'node/' . $next->nid, array(
        'attributes' => array(
          'class' => 'page-next',
          'title' => t('Go to next page'),
        ),
      )), 'Next page link found.');
    }

    // check printer friendly version
    $this
      ->drupalGet('book/export/html/' . $node->nid);
    $this
      ->assertText($node->title, 'Printer friendly title found.');
    $node->body = str_replace('<!--break-->', '', $node->body);
    $this
      ->assertWantedRaw(check_markup($node->body, $node->format), 'Printer friendly body found.');
    $number++;
  }

  /**
   * Create a regular expression to check for the sub-nodes in the outline.
   *
   * @param array $nodes Nodes to check in outline.
   */
  function generateOutlinePattern($nodes) {
    $outline = '';
    foreach ($nodes as $node) {
      $outline .= '(node\\/' . $node->nid . ')(.*?)(' . $node->title . ')(.*?)';
    }
    return '/<div id="book-navigation-' . $this->book->nid . '"(.*?)<ul(.*?)' . $outline . '<\\/ul>/s';
  }

  /**
   * Create book node.
   *
   * @param integer $book_nid Book node id or set to 'new' to create new book.
   * @param integer $parent Parent book reference id.
   */
  function createBookNode($book_nid, $parent = NULL) {
    static $number = 0;

    // used to ensure that when sorted nodes stay in same order
    $this
      ->drupalVariableSet('node_options_page', array(
      'status',
      'promote',
    ));
    $edit = array();
    $edit['title'] = $number . ' - SimpleTest test node ' . $this
      ->randomName(10);
    $edit['body'] = 'SimpleTest test body ' . $this
      ->randomName(32) . ' ' . $this
      ->randomName(32);
    $edit['book[bid]'] = $book_nid;
    if ($parent !== NULL) {
      $this
        ->drupalPost('node/add/book', $edit, 'Change book (update list of parents)');
      $edit['book[plid]'] = $parent;
      $this
        ->drupalPost(NULL, $edit, 'Save');
    }
    else {
      $this
        ->drupalPost('node/add/book', $edit, 'Save');
    }

    // check to make sure the book node was created
    $node = node_load(array(
      'title' => $edit['title'],
    ));
    $this
      ->assertNotNull($node === FALSE ? NULL : $node, 'Book node found in database.');
    $number++;
    return $node;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
BookModuleTestCase::$book property
BookModuleTestCase::checkBookNode function Checks the outline of sub-pages; previous, up, and next; and check printer friendly version.
BookModuleTestCase::createBookNode function Create book node.
BookModuleTestCase::generateOutlinePattern function Create a regular expression to check for the sub-nodes in the outline.
BookModuleTestCase::get_info function
BookModuleTestCase::setUp function
BookModuleTestCase::testBook function Test book funcitonality through node interfaces.
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