You are here

class OgPost in Organic groups 5.7

Same name and namespace in other branches
  1. 5.8 tests/og_post.test \OgPost
  2. 5 tests/og_post.test \OgPost
  3. 5.2 tests/og_post.test \OgPost
  4. 5.3 tests/og_post.test \OgPost
  5. 6.2 tests/og.post.test \OgPost
  6. 6 tests/og.post.test \OgPost

Hierarchy

Expanded class hierarchy of OgPost

File

tests/og_post.test, line 5

View source
class OgPost extends OgTestCase {
  function get_info() {
    return array(
      'name' => t('Og posting test'),
      'desc' => t('Tests to post a page to an og.'),
      'group' => 'Organic groups',
    );
  }
  function testOgPost() {
    $og_type = $this
      ->addNodeType();
    $admin_user = $this
      ->drupalCreateUserRolePerm(array(
      'access content',
      'create groups',
      "create {$og_type} content",
      "edit {$og_type} content",
    ));
    $this
      ->drupalLoginUser($admin_user);
    $gid = $this
      ->addOg($og_type, OG_OPEN);
    $node = node_load($gid);

    /* Prepare a user to do the stuff */
    $this->_browser = new SimpleBrowser();
    $web_user = $this
      ->drupalCreateUserRolePerm(array(
      'access content',
      "create page content",
    ));
    $this
      ->drupalLoginUser($web_user);
    $url = url("og/subscribe/{$gid}");
    $ret = $this
      ->get($url, FALSE, FALSE, TRUE);
    $this
      ->assertTrue($ret, " [browser] GET {$url}");
    $this
      ->assertWantedRaw(t('Are you sure you want to join the group %title?', array(
      '%title' => $node->title,
    )), "Confirmation text found.");
    $this
      ->clickSubmit("Join");
    $this
      ->assertNoUnwantedRaw(t('Page not found'), 'page not not found.');
    $this
      ->assertWantedRaw(t('You are now a member of the @group', array(
      '@group' => $node->title,
    )), 'User subscribed to group - text not found.');
    $edit = array();
    $edit['title'] = '!SimpleTest og test node! ' . $this
      ->randomName(10);
    $edit['body'] = '!SimpleTest og test body! ' . $this
      ->randomName(32) . ' ' . $this
      ->randomName(32);

    //$edit['og_public']      = true;
    $edit['og_groups[' . $gid . ']'] = true;
    $this
      ->drupalPostRequest("node/add/page", $edit, 'Submit');
    $this
      ->assertWantedRaw(t('Your %post has been created.', array(
      '%post' => node_get_types('name', 'page'),
    )), 'post created');
    $url = url("node/{$gid}");
    $ret = $this
      ->get($url, FALSE, FALSE, TRUE);
    $this
      ->assertTrue($ret, " [browser] GET {$url}");
    $this
      ->assertWantedText($edit['title'], 'Group node title found.');
    $node = node_load(array(
      'title' => $edit['title'],
    ));
    $this
      ->assertNotNull($node, 'Node found in database. %s');
    node_delete($node->nid);
    node_delete($gid);
  }

}

Members

Namesort descending Modifiers Type Description Overrides
DrupalTestCase::$_cleanupModules property
DrupalTestCase::$_cleanupRoles property
DrupalTestCase::$_cleanupUsers property
DrupalTestCase::$_cleanupVariables property
DrupalTestCase::$_content 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::clickLink function Follows a link by name. Will click the first link found with this link text by default, or a later one if an index is given. Match is case insensitive with normalised space. Does make assertations if the click was sucessful or not and it does…
DrupalTestCase::drupalCheckAuth function @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site.
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 Brokder 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::drupalPostRequest function Do a post request on a drupal page. It will be done as usual post request with SimpleBrowser
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 druapl 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
OgPost::get_info function Overrides OgTestCase::get_info
OgPost::testOgPost function
OgTestCase::$_cleanupGroups property
OgTestCase::addNodeType function
OgTestCase::addOg function
OgTestCase::tearDown function tearDown implementation, setting back switched modules etc Overrides DrupalTestCase::tearDown