class ContentAccessModuleTestCase in Content Access 5
Same name and namespace in other branches
- 6 tests/content_access.test \ContentAccessModuleTestCase
- 7 tests/content_access.test \ContentAccessModuleTestCase
Hierarchy
- class \DrupalTestCase extends \WebTestCase
- class \ContentAccessTestCase
- class \ContentAccessModuleTestCase
- class \ContentAccessTestCase
Expanded class hierarchy of ContentAccessModuleTestCase
File
- tests/
content_access.test, line 10
View source
class ContentAccessModuleTestCase extends ContentAccessTestCase {
var $node1;
var $node2;
/**
* Implementation of get_info() for information
*/
function get_info() {
return array(
'name' => t('Content Access Module Tests'),
'desc' => t('Various tests to check permission settings on nodes.'),
'group' => 'Content Access',
);
}
function setUp() {
parent::setUp();
// Create test nodes
$this->node1 = $this
->createNode();
$this->node2 = $this
->createNode();
}
/**
* Test for viewing nodes
*/
function testViewAccess() {
// Restrict access to the content type (access is only allowed for the author)
$access_permissions = array(
'view[author]' => TRUE,
'view[1]' => FALSE,
'view[2]' => FALSE,
);
$this
->changeAccessContentType($access_permissions);
// Logout admin and try to access the node anonymously
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid));
$this
->assertText(t('Access denied'), 'node is not viewable');
// Login test user, view node, access must be denied
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid));
$this
->assertText(t('Access denied'), 'node is not viewable');
// Login admin and grant access for viewing to the test user
$this
->drupalGet(url('logout'));
$this
->drupalLoginUser($this->admin_user);
$this
->changeAccessContentTypeKeyword('view');
// Logout admin and try to access the node anonymously
// access must be denied again
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid));
$this
->assertText(t('Access denied'), 'node is not viewable');
// Login test user, view node, access must be granted
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid));
$this
->assertNoText(t('Access denied'), 'node is viewable');
// Login admin and enable per node access
$this
->drupalGet(url('logout'));
$this
->drupalLoginUser($this->admin_user);
$this
->changeAccessPerNode();
// Restrict access on node2 for the test user role
$this
->changeAccessNodeKeyword($this->node2, 'view', FALSE);
// Logout admin and try to access both nodes anonymously
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid));
$this
->assertText(t('Access denied'), 'node1 is not viewable');
$this
->drupalGet(url('node/' . $this->node2->nid));
$this
->assertText(t('Access denied'), 'node2 is not viewable');
// Login test user, view node1, access must be granted
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid));
$this
->assertNoText(t('Access denied'), 'node1 is viewable');
// View node2, access must be denied
$this
->drupalGet(url('node/' . $this->node2->nid));
$this
->assertText(t('Access denied'), 'node2 is not viewable');
// Login admin, swap permissions between content type and node2
$this
->drupalGet(url('logout'));
$this
->drupalLoginUser($this->admin_user);
// Restrict access to content type
$this
->changeAccessContentTypeKeyword('view', FALSE);
// Grant access to node2
$this
->changeAccessNodeKeyword($this->node2, 'view');
// Logout admin and try to access both nodes anonymously
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid));
$this
->assertText(t('Access denied'), 'node1 is not viewable');
$this
->drupalGet(url('node/' . $this->node2->nid));
$this
->assertText(t('Access denied'), 'node2 is not viewable');
// Login test user, view node1, access must be denied
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid));
$this
->assertText(t('Access denied'), 'node1 is not viewable');
// View node2, access must be granted
$this
->drupalGet(url('node/' . $this->node2->nid));
$this
->assertNoText(t('Access denied'), 'node2 is viewable');
}
/**
* Test for editing nodes
*/
function testEditAccess() {
// Logout admin and try to edit the node anonymously
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid . '/edit'));
$this
->assertText(t('Access denied'), 'edit access denied for anonymous');
// Login test user, edit node, access must be denied
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid . '/edit'));
$this
->assertText(t('Access denied'), 'edit access denied for test user');
// Login admin and grant access for editing to the test user
$this
->drupalGet(url('logout'));
$this
->drupalLoginUser($this->admin_user);
$this
->changeAccessContentTypeKeyword('update');
// Logout admin and try to edit the node anonymously
// access must be denied again
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid . '/edit'));
$this
->assertText(t('Access denied'), 'edit access denied for anonymous');
// Login test user, edit node, access must be granted
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid . '/edit'));
$this
->assertNoText(t('Access denied'), 'node1 is editable');
// Login admin and enable per node access
$this
->drupalGet(url('logout'));
$this
->drupalLoginUser($this->admin_user);
$this
->changeAccessPerNode();
// Restrict edit access on node2 for the test user
$this
->changeAccessNodeKeyword($this->node2, 'update', FALSE);
// Logout admin and try to edit both nodes anonymously
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid . '/edit'));
$this
->assertText(t('Access denied'), 'node1 is not editable');
$this
->drupalGet(url('node/' . $this->node2->nid . '/edit'));
$this
->assertText(t('Access denied'), 'node2 is not editable');
// Login test user, edit node1, access must be granted
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid . '/edit'));
$this
->assertNoText(t('Access denied'), 'node1 is editable');
// Edit node2, access must be denied
$this
->drupalGet(url('node/' . $this->node2->nid . '/edit'));
$this
->assertText(t('Access denied'), 'node2 is not editable');
// Login admin, swap permissions between content type and node2
$this
->drupalGet(url('logout'));
$this
->drupalLoginUser($this->admin_user);
// Restrict edit access to content type
$this
->changeAccessContentTypeKeyword('update', FALSE);
// Grant edit access to node2
$this
->changeAccessNodeKeyword($this->node2, 'update');
// Logout admin and try to edit both nodes anonymously
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid . '/edit'));
$this
->assertText(t('Access denied'), 'node1 is not editable');
$this
->drupalGet(url('node/' . $this->node2->nid . '/edit'));
$this
->assertText(t('Access denied'), 'node2 is not editable');
// Login test user, edit node1, access must be denied
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid . '/edit'));
$this
->assertText(t('Access denied'), 'node1 is not editable');
// Edit node2, access must be granted
$this
->drupalGet(url('node/' . $this->node2->nid . '/edit'));
$this
->assertNoText(t('Access denied'), 'node2 is editable');
}
/**
* Test for deleting nodes
*/
function testDeleteAccess() {
// Logout admin and try to delete the node anonymously
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid . '/delete'));
$this
->assertText(t('Access denied'), 'delete access denied for anonymous');
// Login test user, delete node, access must be denied
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid . '/delete'));
$this
->assertText(t('Access denied'), 'delete access denied for test user');
// Login admin and grant access for deleting to the test user
$this
->drupalGet(url('logout'));
$this
->drupalLoginUser($this->admin_user);
$this
->changeAccessContentTypeKeyword('delete');
// Logout admin and try to edit the node anonymously
// access must be denied again
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid . '/delete'));
$this
->assertText(t('Access denied'), 'delete access denied for anonymous');
// Login test user, delete node, access must be granted
$this
->drupalLoginUser($this->test_user);
$this
->drupalPostRequest('node/' . $this->node1->nid . '/delete', array(), 'Delete');
$this
->assertWantedRaw(t('%node has been deleted', array(
'%node' => $this->node1->title,
)), 'Test node was deleted successfully by test user');
// Login admin and recreate test node1
$this
->drupalGet(url('logout'));
$this
->drupalLoginUser($this->admin_user);
$this->node1 = $this
->createNode();
// Enable per node access
$this
->changeAccessPerNode();
// Restrict delete access on node2 for the test user
$this
->changeAccessNodeKeyword($this->node2, 'delete', FALSE);
// Logout admin and try to delete both nodes anonymously
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid . '/delete'));
$this
->assertText(t('Access denied'), 'node1 is not deletable');
$this
->drupalGet(url('node/' . $this->node2->nid . '/delete'));
$this
->assertText(t('Access denied'), 'node2 is not deletable');
// Login test user, delete node1, access must be granted
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid . '/delete'));
$this
->assertNoText(t('Access denied'), 'node1 is deletable');
// Delete node2, access must be denied
$this
->drupalGet(url('node/' . $this->node2->nid . '/delete'));
$this
->assertText(t('Access denied'), 'node2 is not deletable');
// Login admin, swap permissions between content type and node2
$this
->drupalGet(url('logout'));
$this
->drupalLoginUser($this->admin_user);
// Restrict delete access to content type
$this
->changeAccessContentTypeKeyword('delete', FALSE);
// Grant delete access to node2
$this
->changeAccessNodeKeyword($this->node2, 'delete');
// Logout admin and try to delete both nodes anonymously
$this
->drupalGet(url('logout'));
$this
->drupalGet(url('node/' . $this->node1->nid . '/delete'));
$this
->assertText(t('Access denied'), 'node1 is not deletable');
$this
->drupalGet(url('node/' . $this->node2->nid . '/delete'));
$this
->assertText(t('Access denied'), 'node2 is not deletable');
// Login test user, delete node1, access must be denied
$this
->drupalLoginUser($this->test_user);
$this
->drupalGet(url('node/' . $this->node1->nid . '/delete'));
$this
->assertText(t('Access denied'), 'node1 is not deletable');
// Delete node2, access must be granted
$this
->drupalGet(url('node/' . $this->node2->nid . '/delete'));
$this
->assertNoText(t('Access denied'), 'node2 is deletable');
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ContentAccessModuleTestCase:: |
property |
Overrides ContentAccessTestCase:: |
||
ContentAccessModuleTestCase:: |
property |
Overrides ContentAccessTestCase:: |
||
ContentAccessModuleTestCase:: |
function | Implementation of get_info() for information | ||
ContentAccessModuleTestCase:: |
function |
Preparation work that is done before each test.
Test users, content types, nodes etc. are created. Overrides ContentAccessTestCase:: |
||
ContentAccessModuleTestCase:: |
function | Test for deleting nodes | ||
ContentAccessModuleTestCase:: |
function | Test for editing nodes | ||
ContentAccessModuleTestCase:: |
function | Test for viewing nodes | ||
ContentAccessTestCase:: |
property | |||
ContentAccessTestCase:: |
property | |||
ContentAccessTestCase:: |
property | |||
ContentAccessTestCase:: |
property | |||
ContentAccessTestCase:: |
function | Change access permissions for a content type | ||
ContentAccessTestCase:: |
function | Change access permissions for a content type by a given keyword (view, update or delete) for the role of the user | ||
ContentAccessTestCase:: |
function | Change access permission for a node | ||
ContentAccessTestCase:: |
function | Change access permissions for a node by a given keyword (view, update or delete) | ||
ContentAccessTestCase:: |
function | Change the per node access setting for a content type | ||
ContentAccessTestCase:: |
function | Creates a node for testing purposes | ||
ContentAccessTestCase:: |
function | Stores the current page in the files directory, so it can be viewed by the developer. Useful for debugging code. | ||
ContentAccessTestCase:: |
function | Replacement for drupalPostRequest() if we don't want to reload a path | ||
ContentAccessTestCase:: |
function |
Clear up work that is done after each test.
Users get deleted automatically, so we just have to delete the content type.
(nodes get deleted automatically, too) Overrides DrupalTestCase:: |
||
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 | 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:: |
function | @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site. | ||
DrupalTestCase:: |
function | Create a role / perm combination specified by permissions | ||
DrupalTestCase:: |
function | Creates a user / role / permissions combination specified by permissions | ||
DrupalTestCase:: |
function | @abstract Brokder 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 | ||
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 druapl 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 |