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() ); } }