SecurityAdminTest.php
2.53 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
<?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('Member', 'admin'));
		
		$group = $this->objFromFixture('Group', 'admin');
		
		Config::inst()->update('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()
		);
	}
}