class BookModuleTestCase in SimpleTest 6
Hierarchy
- class \DrupalTestCase extends \WebTestCase
- class \BookModuleTestCase
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
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
BookModuleTestCase:: |
property | |||
BookModuleTestCase:: |
function | Checks the outline of sub-pages; previous, up, and next; and check printer friendly version. | ||
BookModuleTestCase:: |
function | Create book node. | ||
BookModuleTestCase:: |
function | Create a regular expression to check for the sub-nodes in the outline. | ||
BookModuleTestCase:: |
function | |||
BookModuleTestCase:: |
function | |||
BookModuleTestCase:: |
function | Test book funcitonality through node interfaces. | ||
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 |