silverstripe-framework/admin/tests/SecurityAdminTest.php
2016-07-07 11:32:28 +12:00

67 lines
2.6 KiB
PHP

<?php
/**
* @package cms
* @subpackage tests
*/
class SecurityAdminTest extends FunctionalTest {
protected static $fixture_file = 'LeftAndMainTest.yml';
protected $extraDataObjects = array('LeftAndMainTest_Object');
// TODO Fix export feature (moved from MemberTableField to GridFieldExportButton)
// public function testGroupExport() {
// $this->session()->inst_set('loggedInAs', $this->idFromFixture('Member', 'admin'));
// /* First, open the applicable group */
// $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']);
// /* 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");
// }
// TODO Fix export feature (moved from MemberTableField to GridFieldExportButton)
// public 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'));
// $inputs = $this->cssParser()->getBySelector('input#Form_EditForm_Title');
// $this->assertNotNull($inputs);
// $this->assertEquals('Empty Group', (string)$inputs[0]['value']);
// /* 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");
// }
public function testPermissionFieldRespectsHiddenPermissions() {
$this->session()->inst_set('loggedInAs', $this->idFromFixture('SilverStripe\\Security\\Member', 'admin'));
$group = $this->objFromFixture('SilverStripe\\Security\\Group', 'admin');
Config::inst()->update('SilverStripe\\Security\\Permission', 'hidden_permissions', array('CMS_ACCESS_ReportAdmin'));
$response = $this->get(sprintf('admin/security/EditForm/field/Groups/item/%d/edit', $group->ID));
$this->assertContains(
'CMS_ACCESS_SecurityAdmin',
$response->getBody()
);
$this->assertNotContains(
'CMS_ACCESS_ReportAdmin',
$response->getBody()
);
}
}