2011-03-23 22:51:00 +13:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @package cms
|
|
|
|
* @subpackage tests
|
|
|
|
*/
|
|
|
|
class SecurityAdminTest extends FunctionalTest {
|
2011-03-29 17:54:08 +13:00
|
|
|
|
2011-03-23 22:51:00 +13:00
|
|
|
static $fixture_file = 'sapphire/admin/tests/LeftAndMainTest.yml';
|
|
|
|
|
2011-03-29 17:54:08 +13:00
|
|
|
protected $extraDataObjects = array('LeftAndMainTest_Object');
|
|
|
|
|
2011-03-23 22:51:00 +13:00
|
|
|
function testGroupExport() {
|
|
|
|
$this->session()->inst_set('loggedInAs', $this->idFromFixture('Member', 'admin'));
|
|
|
|
|
|
|
|
/* First, open the applicable group */
|
2011-12-22 15:57:01 +01:00
|
|
|
$response = $this->get('admin/security/show/' . $this->idFromFixture('Group','admin'));
|
|
|
|
$inputs = $this->cssParser()->getBySelector('input#Form_EditForm_Title');
|
|
|
|
$this->assertNotNull($inputs);
|
|
|
|
$this->assertEquals('Administrators', (string)$inputs[0]['value']);
|
2011-03-23 22:51:00 +13:00
|
|
|
|
|
|
|
/* Then load the export page */
|
|
|
|
$this->get('admin/security/EditForm/field/Members/export');
|
|
|
|
$lines = preg_split('/\n/', $this->content());
|
|
|
|
|
|
|
|
$this->assertEquals(count($lines), 3, "Export with members has one content row");
|
|
|
|
$this->assertRegExp('/"","","admin@example.com"/', $lines[1], "Member values are correctly exported");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testEmptyGroupExport() {
|
|
|
|
$this->session()->inst_set('loggedInAs', $this->idFromFixture('Member', 'admin'));
|
|
|
|
|
|
|
|
/* First, open the applicable group */
|
|
|
|
$this->get('admin/security/show/' . $this->idFromFixture('Group','empty'));
|
2011-12-22 15:57:01 +01:00
|
|
|
$inputs = $this->cssParser()->getBySelector('input#Form_EditForm_Title');
|
|
|
|
$this->assertNotNull($inputs);
|
|
|
|
$this->assertEquals('Empty Group', (string)$inputs[0]['value']);
|
2011-03-23 22:51:00 +13:00
|
|
|
|
|
|
|
/* Then load the export page */
|
|
|
|
$this->get('admin/security/EditForm/field/Members/export');
|
|
|
|
$lines = preg_split('/\n/', $this->content());
|
|
|
|
|
|
|
|
$this->assertEquals(count($lines), 2, "Empty export only has header fields and an empty row");
|
|
|
|
$this->assertEquals($lines[1], '', "Empty export only has no content row");
|
|
|
|
}
|
|
|
|
|
|
|
|
function testAddHiddenPermission() {
|
|
|
|
SecurityAdmin::add_hidden_permission('CMS_ACCESS_ReportAdmin');
|
|
|
|
$this->assertContains('CMS_ACCESS_ReportAdmin', SecurityAdmin::get_hidden_permissions());
|
|
|
|
|
|
|
|
// reset to defaults
|
|
|
|
SecurityAdmin::clear_hidden_permissions();
|
|
|
|
}
|
|
|
|
|
|
|
|
function testRemoveHiddenPermission() {
|
|
|
|
SecurityAdmin::add_hidden_permission('CMS_ACCESS_ReportAdmin');
|
|
|
|
$this->assertContains('CMS_ACCESS_ReportAdmin', SecurityAdmin::get_hidden_permissions());
|
|
|
|
SecurityAdmin::remove_hidden_permission('CMS_ACCESS_ReportAdmin');
|
|
|
|
$this->assertNotContains('CMS_ACCESS_ReportAdmin', SecurityAdmin::get_hidden_permissions());
|
|
|
|
|
|
|
|
// reset to defaults
|
|
|
|
SecurityAdmin::clear_hidden_permissions();
|
|
|
|
}
|
|
|
|
|
|
|
|
function testClearHiddenPermission() {
|
|
|
|
SecurityAdmin::add_hidden_permission('CMS_ACCESS_ReportAdmin');
|
|
|
|
$this->assertContains('CMS_ACCESS_ReportAdmin', SecurityAdmin::get_hidden_permissions());
|
|
|
|
SecurityAdmin::clear_hidden_permissions('CMS_ACCESS_ReportAdmin');
|
|
|
|
$this->assertNotContains('CMS_ACCESS_ReportAdmin', SecurityAdmin::get_hidden_permissions());
|
|
|
|
}
|
|
|
|
|
|
|
|
function testPermissionFieldRespectsHiddenPermissions() {
|
|
|
|
$this->session()->inst_set('loggedInAs', $this->idFromFixture('Member', 'admin'));
|
|
|
|
|
|
|
|
$group = $this->objFromFixture('Group', 'admin');
|
|
|
|
|
|
|
|
SecurityAdmin::add_hidden_permission('CMS_ACCESS_ReportAdmin');
|
|
|
|
$response = $this->get('admin/security/show/' . $group->ID);
|
|
|
|
|
|
|
|
$this->assertContains(
|
2011-03-29 17:54:08 +13:00
|
|
|
'CMS_ACCESS_SecurityAdmin',
|
2011-03-23 22:51:00 +13:00
|
|
|
$response->getBody()
|
|
|
|
);
|
|
|
|
$this->assertNotContains(
|
|
|
|
'CMS_ACCESS_ReportAdmin',
|
|
|
|
$response->getBody()
|
|
|
|
);
|
|
|
|
|
|
|
|
// reset to defaults
|
|
|
|
SecurityAdmin::clear_hidden_permissions();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|