mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
FIX: ConfirmedPasswordField setName failed to set names of child fields.
FIX: ConfirmedPasswordField relied on POST variables. These should instead come from setValue(). Added all important tests for validating the field: valid if passwords match, invalid if passwords differ.
This commit is contained in:
parent
98c01a34f6
commit
8d8f3abace
@ -53,6 +53,13 @@ class ConfirmedPasswordField extends FormField {
|
|||||||
* @param boolean $showOnClick
|
* @param boolean $showOnClick
|
||||||
*/
|
*/
|
||||||
protected $showOnClick = false;
|
protected $showOnClick = false;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A place to temporarly store the confirm password value
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $confirmValue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Title for the link that triggers the visibility of password fields.
|
* Title for the link that triggers the visibility of password fields.
|
||||||
@ -247,10 +254,8 @@ class ConfirmedPasswordField extends FormField {
|
|||||||
$oldValue = $this->value;
|
$oldValue = $this->value;
|
||||||
|
|
||||||
if(is_array($value)) {
|
if(is_array($value)) {
|
||||||
//only set the value if it's valid!
|
$this->value = $value['_Password'];
|
||||||
if($this->validate(RequiredFields::create())) {
|
$this->confirmValue = $value['_ConfirmPassword'];
|
||||||
$this->value = $value['_Password'];
|
|
||||||
}
|
|
||||||
|
|
||||||
if($this->showOnClick && isset($value['_PasswordFieldVisible'])) {
|
if($this->showOnClick && isset($value['_PasswordFieldVisible'])) {
|
||||||
$this->children->fieldByName($this->getName() . '[_PasswordFieldVisible]')
|
$this->children->fieldByName($this->getName() . '[_PasswordFieldVisible]')
|
||||||
@ -274,6 +279,20 @@ class ConfirmedPasswordField extends FormField {
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the names of the child fields when updating name of field.
|
||||||
|
*
|
||||||
|
* @param string $name new name to give to the field.
|
||||||
|
*/
|
||||||
|
public function setName($name) {
|
||||||
|
$this->children->fieldByName($this->getName() . '[_Password]')
|
||||||
|
->setName($name . '[_Password]');
|
||||||
|
$this->children->fieldByName($this->getName() . '[_ConfirmPassword]')
|
||||||
|
->setName($name . '[_ConfirmPassword]');
|
||||||
|
|
||||||
|
return parent::setName($name);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Determines if the field was actually shown on the client side - if not,
|
* Determines if the field was actually shown on the client side - if not,
|
||||||
* we don't validate or save it.
|
* we don't validate or save it.
|
||||||
@ -301,9 +320,9 @@ class ConfirmedPasswordField extends FormField {
|
|||||||
|
|
||||||
$passwordField = $this->children->fieldByName($name.'[_Password]');
|
$passwordField = $this->children->fieldByName($name.'[_Password]');
|
||||||
$passwordConfirmField = $this->children->fieldByName($name.'[_ConfirmPassword]');
|
$passwordConfirmField = $this->children->fieldByName($name.'[_ConfirmPassword]');
|
||||||
$passwordField->setValue($_POST[$name]['_Password']);
|
$passwordField->setValue($this->value);
|
||||||
$passwordConfirmField->setValue($_POST[$name]['_ConfirmPassword']);
|
$passwordConfirmField->setValue($this->confirmValue);
|
||||||
|
|
||||||
$value = $passwordField->Value();
|
$value = $passwordField->Value();
|
||||||
|
|
||||||
// both password-fields should be the same
|
// both password-fields should be the same
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
* @subpackage tests
|
* @subpackage tests
|
||||||
*/
|
*/
|
||||||
class ConfirmedPasswordFieldTest extends SapphireTest {
|
class ConfirmedPasswordFieldTest extends SapphireTest {
|
||||||
|
|
||||||
public function testSetValue() {
|
public function testSetValue() {
|
||||||
$field = new ConfirmedPasswordField('Test', 'Testing', 'valueA');
|
$field = new ConfirmedPasswordField('Test', 'Testing', 'valueA');
|
||||||
$this->assertEquals('valueA', $field->Value());
|
$this->assertEquals('valueA', $field->Value());
|
||||||
@ -52,4 +53,23 @@ class ConfirmedPasswordFieldTest extends SapphireTest {
|
|||||||
$this->assertNotContains("showOnClick", $fieldHTML,
|
$this->assertNotContains("showOnClick", $fieldHTML,
|
||||||
"Test class for hiding/showing the form contents is set");
|
"Test class for hiding/showing the form contents is set");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testValidation() {
|
||||||
|
$field = new ConfirmedPasswordField('Test', 'Testing', array(
|
||||||
|
"_Password" => "abc123",
|
||||||
|
"_ConfirmPassword" => "abc123"
|
||||||
|
));
|
||||||
|
$validator = new RequiredFields();
|
||||||
|
$form = new Form($this, 'Form', new FieldList($field), new FieldList(), $validator);
|
||||||
|
$this->assertTrue($field->validate($validator));
|
||||||
|
$field->setName("TestNew"); //try changing name of field
|
||||||
|
$this->assertTrue($field->validate($validator));
|
||||||
|
//non-matching password should make the field invalid
|
||||||
|
$field->setValue(array(
|
||||||
|
"_Password" => "abc123",
|
||||||
|
"_ConfirmPassword" => "123abc"
|
||||||
|
));
|
||||||
|
$this->assertFalse($field->validate($validator));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user