list = new DataList(Team::class); $config = GridFieldConfig::create()->addComponent(new GridFieldDeleteAction()); $this->gridField = new GridField('testfield', 'testfield', $this->list, $config); $this->form = new Form(null, 'mockform', new FieldList(array($this->gridField)), new FieldList()); } public function testDontShowDeleteButtons() { if (Security::getCurrentUser()) { Security::setCurrentUser(null); } $content = new CSSContentParser($this->gridField->FieldHolder()); // Check that there are content $this->assertEquals(4, count($content->getBySelector('.ss-gridfield-item'))); // Make sure that there are no delete buttons $this->assertEquals( 0, count($content->getBySelector('.gridfield-button-delete')), 'Delete buttons should not show when not logged in.' ); } public function testShowDeleteButtonsWithAdminPermission() { $this->logInWithPermission('ADMIN'); $content = new CSSContentParser($this->gridField->FieldHolder()); $deleteButtons = $content->getBySelector('.gridfield-button-delete'); $this->assertEquals(3, count($deleteButtons), 'Delete buttons should show when logged in.'); } public function testActionsRequireCSRF() { $this->logInWithPermission('ADMIN'); $this->expectException(HTTPResponse_Exception::class); $this->expectExceptionMessage(_t( "SilverStripe\\Forms\\Form.CSRF_FAILED_MESSAGE", "There seems to have been a technical problem. Please click the back button, ". "refresh your browser, and try again." )); $this->expectExceptionCode(400); $stateID = 'testGridStateActionField'; $request = new HTTPRequest( 'POST', 'url', array(), array( 'action_gridFieldAlterAction?StateID='.$stateID, 'SecurityID' => null, ) ); $this->gridField->gridFieldAlterAction(array('StateID'=>$stateID), $this->form, $request); } public function testDeleteActionWithoutCorrectPermission() { if (Security::getCurrentUser()) { Security::setCurrentUser(null); } $this->expectException(ValidationException::class); $stateID = 'testGridStateActionField'; $session = Controller::curr()->getRequest()->getSession(); $session->set( $stateID, array( 'grid' => '', 'actionName' => 'deleterecord', 'args' => array( 'RecordID' => $this->idFromFixture(Team::class, 'team1') ) ) ); $token = SecurityToken::inst(); $request = new HTTPRequest( 'POST', 'url', array(), array( 'action_gridFieldAlterAction?StateID='.$stateID => true, $token->getName() => $token->getValue(), ) ); $request->setSession($session); $this->gridField->gridFieldAlterAction(array('StateID'=>$stateID), $this->form, $request); $this->assertEquals( 3, $this->list->count(), 'User should\'t be able to delete records without correct permissions.' ); } public function testDeleteActionWithAdminPermission() { $this->logInWithPermission('ADMIN'); $stateID = 'testGridStateActionField'; $session = Controller::curr()->getRequest()->getSession(); $session->set( $stateID, array( 'grid'=>'', 'actionName'=>'deleterecord', 'args' => array( 'RecordID' => $this->idFromFixture(Team::class, 'team1') ) ) ); $token = SecurityToken::inst(); $request = new HTTPRequest( 'POST', 'url', array(), array( 'action_gridFieldAlterAction?StateID='.$stateID=>true, $token->getName() => $token->getValue(), ) ); $request->setSession($session); $this->gridField->gridFieldAlterAction(array('StateID'=>$stateID), $this->form, $request); $this->assertEquals(2, $this->list->count(), 'User should be able to delete records with ADMIN permission.'); } public function testDeleteActionRemoveRelation() { $this->logInWithPermission('ADMIN'); $config = GridFieldConfig::create()->addComponent(new GridFieldDeleteAction(true)); $session = Controller::curr()->getRequest()->getSession(); $gridField = new GridField('testfield', 'testfield', $this->list, $config); new Form(null, 'mockform', new FieldList(array($gridField)), new FieldList()); $stateID = 'testGridStateActionField'; $session->set( $stateID, array( 'grid'=>'', 'actionName'=>'deleterecord', 'args' => array( 'RecordID' => $this->idFromFixture(Team::class, 'team1') ) ) ); $token = SecurityToken::inst(); $request = new HTTPRequest( 'POST', 'url', array(), array( 'action_gridFieldAlterAction?StateID='.$stateID=>true, $token->getName() => $token->getValue(), ) ); $request->setSession($session); $gridField->gridFieldAlterAction(array('StateID'=>$stateID), $this->form, $request); $this->assertEquals(2, $this->list->count(), 'User should be able to delete records with ADMIN permission.'); } }