You are here

class TaxonomyTestNodeApi in SimpleTest 6

Same name and namespace in other branches
  1. 5 tests/taxonomy.module.test \TaxonomyTestNodeApi

Hierarchy

Expanded class hierarchy of TaxonomyTestNodeApi

File

tests/taxonomy.module.test, line 236

View source
class TaxonomyTestNodeApi extends DrupalTestCase {
  function get_info() {
    return array(
      'name' => 'Taxonomy nodeapi',
      'desc' => "Save & edit a node and assert that taxonomy terms are saved/loaded properly.",
      'group' => 'Taxonomy',
    );
  }
  function testTaxonomyNode() {

    //preparing data

    // vocabulary hierarchy->single, multiple -> on
    $edit = array();
    $_t = array(
      'vid',
      'name',
      'description',
      'help',
      'relations',
      'hierarchy',
      'multiple',
      'required',
      'tags',
      'module',
      'weight',
      'nodes',
    );
    foreach ($_t as $key) {
      $edit[$key] = 0;
    }
    $name = $this
      ->randomName(20);
    $edit['hierarchy'] = 1;
    $edit['multiple'] = 1;
    $edit['name'] = $name;
    $edit['nodes'] = array(
      'story' => 'story',
    );
    taxonomy_save_vocabulary($edit);
    $vid = $edit['vid'];

    // we need to persist vid after $edit is unset()
    $parent = array();
    $patternArray = array();

    // create 1st term
    $termname = $this
      ->randomName(20);
    $data = array(
      'name' => $termname,
      'description' => '',
      'weight' => 0,
      'synonyms' => '',
      'vid' => $vid,
      'tid' => 0,
      'relations' => 0,
    );
    taxonomy_save_term($data);
    $_tArray = taxonomy_get_term_by_name($termname);
    $parent[$_tArray[0]->tid] = $_tArray[0]->tid;
    $patternArray['term name 1'] = $termname;

    // create 2nd term
    $termname = $this
      ->randomName(20);
    $data = array(
      'name' => $termname,
      'description' => '',
      'weight' => 0,
      'synonyms' => '',
      'vid' => $vid,
      'tid' => 0,
      'relations' => 0,
    );
    taxonomy_save_term($data);
    $_tArray = taxonomy_get_term_by_name($termname);
    $parent[$_tArray[0]->tid] = $_tArray[0]->tid;
    $patternArray['term name 2'] = $termname;

    // create test user and login
    $perm = array(
      'access content',
      'create story content',
      'edit own story content',
      'delete own story content',
    );
    $account = $this
      ->drupalCreateUserRolePerm($perm);
    $this
      ->drupalLoginUser($account);

    // why is this printing out the user profile page?
    // go to node/add/story
    $this
      ->drupalGet('node/add/story');
    $req = $this->_browser
      ->getRequest();
    $headers = $this->_browser
      ->getHeaders();
    $content = $this
      ->drupalGetContent();

    //    print($content). "\n\n\n all done \n\n";
    // try to create story
    $title = $this
      ->randomName();
    $body = $this
      ->randomName(100);
    $edit = array(
      'title' => $title,
      'body' => $body,
      'taxonomy-' . $vid => $parent,
    );

    // multiple slect box was failing through drupalPost. Use raw POST instead
    // Failing because they were being sent/handled wrong (earnest.berry@gmail.com <Souvent22>)
    $action = url('node/add/story', array(
      'absolute' => TRUE,
    ));
    $this
      ->drupalPost($action, $edit, 'Save');
    $content = $this
      ->drupalGetContent();
    $patternArray['body text'] = $body;
    $patternArray['title'] = $title;

    //    $node = array2object(node_load(array('title' => $title)));
    $node = node_load(array(
      'title' => $title,
    ));
    $this->_browser
      ->get(url("node/{$node->nid}"));
    foreach ($patternArray as $name => $termPattern) {
      $this
        ->assertText($termPattern, "Checking {$name}");
    }

    // checking database fields
    $result = db_query('SELECT tid FROM {term_node} WHERE nid = %d', $node->nid);
    while ($nodeRow = db_fetch_array($result)) {
      $this
        ->assertTrue(in_array($nodeRow['tid'], $parent), 'Checking database record');
    }

    // ok, lets create new terms, and change this node

    //pop array
    array_pop($parent);

    // create 1st term
    $termname = $this
      ->randomName(20);
    $data = array(
      'name' => $termname,
      'description' => '',
      'weight' => 0,
      'synonyms' => '',
      'vid' => $vid,
      'tid' => 0,
      'relations' => 0,
    );
    taxonomy_save_term($data);
    $_tArray = taxonomy_get_term_by_name($termname);
    $parent[] = $_tArray[0]->tid;
    $patternArray['term name 2'] = $termname;

    // create 2nd term
    $termname = $this
      ->randomName(20);
    $data = array(
      'name' => $termname,
      'description' => '',
      'weight' => 0,
      'synonyms' => '',
      'vid' => $vid,
      'tid' => 0,
      'relations' => 0,
    );
    taxonomy_save_term($data);
    $_tArray = taxonomy_get_term_by_name($termname);
    $parent[] = $_tArray[0]->tid;
    $patternArray['term name 3'] = $termname;
    $edit = array(
      'title' => $title,
      'body' => $body,
      'taxonomy-' . $vid => $parent,
    );
    $this
      ->drupalPost('node/' . $node->nid . '/edit', $edit, 'Save');

    // TODO Do a MUCH better check here of the information msg
    $patternArray['information message'] = 'been updated';
    foreach ($patternArray as $name => $termPattern) {
      $this
        ->assertText($termPattern, "Checking {$name}");
    }

    // checking database fields
    $result = db_query('SELECT tid FROM {term_node} WHERE nid = %d', $node->nid);
    while ($nodeRow = db_fetch_array($result)) {
      $this
        ->assertTrue(in_array($nodeRow['tid'], $parent), 'Checking database field');
    }

    // delete node through browser
    $this
      ->drupalPost('node/' . $node->nid . '/delete', array(), 'Delete');

    // checking after delete
    $this->_browser
      ->get(url("node/" . $node->nid));
    $this
      ->assertNoUnwantedText($termname, "Checking if node exists");

    // checking database fields
    $num_rows = db_result(db_query('SELECT COUNT(*) FROM {term_node} WHERE nid = %d', $node->nid));
    $this
      ->assertEqual($num_rows, 0, 'Checking database field after deletion');

    // delete vocabulary
    // to avoid exception messages create array with empty fields
    $edit = array();
    foreach ($_t as $key) {
      $edit[$key] = 0;
    }
    $edit['name'] = 0;
    $edit['vid'] = $vid;
    taxonomy_save_vocabulary($edit);

    // restoring status
    $this
      ->drupalModuleDisable('story');
  }

}

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
TaxonomyTestNodeApi::get_info function
TaxonomyTestNodeApi::testTaxonomyNode function