mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
813d34b15e
Updates the CMS profile page and SecurityAdmin to give developers a few ways to customise the required fields. Added extension hook updateValidator for getValidator for things like modules to inject required fields to go along with Injector for replacing the entire class for project specific use.
94 lines
2.7 KiB
PHP
94 lines
2.7 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @package framework
|
|
* @subpackage tests
|
|
*/
|
|
class CMSProfileControllerTest extends FunctionalTest {
|
|
|
|
protected static $fixture_file = 'CMSProfileControllerTest.yml';
|
|
|
|
public $autoFollowRedirection = false;
|
|
|
|
public function testMemberCantEditAnother() {
|
|
$member = $this->objFromFixture('Member', 'user1');
|
|
$anotherMember = $this->objFromFixture('Member', 'user2');
|
|
$this->session()->inst_set('loggedInAs', $member->ID);
|
|
|
|
$response = $this->post('admin/myprofile/EditForm', array(
|
|
'action_save' => 1,
|
|
'ID' => $anotherMember->ID,
|
|
'FirstName' => 'JoeEdited',
|
|
'Surname' => 'BloggsEdited',
|
|
'Email' => $member->Email,
|
|
'Locale' => $member->Locale,
|
|
'Password[_Password]' => 'password',
|
|
'Password[_ConfirmPassword]' => 'password',
|
|
));
|
|
|
|
$anotherMember = $this->objFromFixture('Member', 'user2');
|
|
|
|
$this->assertNotEquals($anotherMember->FirstName, 'JoeEdited', 'FirstName field stays the same');
|
|
}
|
|
|
|
public function testMemberEditsOwnProfile() {
|
|
$member = $this->objFromFixture('Member', 'user1');
|
|
$this->session()->inst_set('loggedInAs', $member->ID);
|
|
|
|
$response = $this->post('admin/myprofile/EditForm', array(
|
|
'action_save' => 1,
|
|
'ID' => $member->ID,
|
|
'FirstName' => 'JoeEdited',
|
|
'Surname' => 'BloggsEdited',
|
|
'Email' => $member->Email,
|
|
'Locale' => $member->Locale,
|
|
'Password[_Password]' => 'password',
|
|
'Password[_ConfirmPassword]' => 'password',
|
|
));
|
|
|
|
$member = $this->objFromFixture('Member', 'user1');
|
|
|
|
$this->assertEquals($member->FirstName, 'JoeEdited', 'FirstName field was changed');
|
|
}
|
|
|
|
public function testExtendedPermissionsStopEditingOwnProfile() {
|
|
$existingExtensions = Config::inst()->get('Member', 'extensions');
|
|
Config::inst()->update('Member', 'extensions', array('CMSProfileControllerTestExtension'));
|
|
|
|
$member = $this->objFromFixture('Member', 'user1');
|
|
$this->session()->inst_set('loggedInAs', $member->ID);
|
|
|
|
$response = $this->post('admin/myprofile/EditForm', array(
|
|
'action_save' => 1,
|
|
'ID' => $member->ID,
|
|
'FirstName' => 'JoeEdited',
|
|
'Surname' => 'BloggsEdited',
|
|
'Email' => $member->Email,
|
|
'Locale' => $member->Locale,
|
|
'Password[_Password]' => 'password',
|
|
'Password[_ConfirmPassword]' => 'password',
|
|
));
|
|
|
|
$member = $this->objFromFixture('Member', 'user1');
|
|
|
|
$this->assertNotEquals($member->FirstName, 'JoeEdited',
|
|
'FirstName field was NOT changed because we modified canEdit');
|
|
|
|
Config::inst()->remove('Member', 'extensions');
|
|
Config::inst()->update('Member', 'extensions', $existingExtensions);
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* @package framework
|
|
* @subpackage tests
|
|
*/
|
|
class CMSProfileControllerTestExtension extends DataExtension {
|
|
|
|
public function canEdit($member = null) {
|
|
return false;
|
|
}
|
|
|
|
}
|