Merge pull request #749 from creative-commoners/pulls/5.0/option-fix-option-fix

FIX Ensure duplicated multiple option field is written (has an ID) before duplicating options
This commit is contained in:
Daniel Hensby 2018-03-27 10:50:09 +01:00 committed by GitHub
commit 20d778bfa6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 44 additions and 1 deletions

View File

@ -225,6 +225,7 @@ class UserFormFieldEditorExtension extends DataExtension
// List of EditableFieldGroups, where the key of the array is the ID of the old end group // List of EditableFieldGroups, where the key of the array is the ID of the old end group
$fieldGroups = []; $fieldGroups = [];
foreach ($oldPage->Fields() as $field) { foreach ($oldPage->Fields() as $field) {
/** @var EditableFormField $newField */
$newField = $field->duplicate(false); $newField = $field->duplicate(false);
$newField->ParentID = $this->owner->ID; $newField->ParentID = $this->owner->ID;
$newField->ParentClass = $this->owner->ClassName; $newField->ParentClass = $this->owner->ClassName;

View File

@ -123,9 +123,10 @@ class EditableMultipleOptionField extends EditableFormField
$manyMany = null; $manyMany = null;
} }
$clonedNode = parent::duplicate($doWrite, $manyMany); $clonedNode = parent::duplicate(true, $manyMany);
foreach ($this->Options() as $field) { foreach ($this->Options() as $field) {
/** @var EditableOption $newField */
$newField = $field->duplicate(false); $newField = $field->duplicate(false);
$newField->ParentID = $clonedNode->ID; $newField->ParentID = $clonedNode->ID;
$newField->Version = 0; $newField->Version = 0;

View File

@ -44,4 +44,14 @@ class EditableDropdownTest extends SapphireTest
$field->Name = 'EditableFormField_123456'; $field->Name = 'EditableFormField_123456';
$this->assertEmpty($field->getFormField()->Title()); $this->assertEmpty($field->getFormField()->Title());
} }
public function testDuplicate()
{
/** @var EditableDropdown $dropdown */
$dropdown = $this->objFromFixture(EditableDropdown::class, 'basic-dropdown');
$this->assertCount(2, $dropdown->Options());
$duplicatedDropdown = $dropdown->duplicate();
$this->assertSame($dropdown->Options()->count(), $duplicatedDropdown->Options()->count());
}
} }

View File

@ -375,6 +375,32 @@ class UserDefinedFormTest extends FunctionalTest
$this->assertNotEquals($form2GroupEnd->ID, $form3GroupStart->EndID); $this->assertNotEquals($form2GroupEnd->ID, $form3GroupStart->EndID);
} }
public function testDuplicateFormDuplicatesRecursively()
{
$this->logInWithPermission('ADMIN');
/** @var UserDefinedForm $form */
$form = $this->objFromFixture(UserDefinedForm::class, 'form-with-multioptions');
$this->assertGreaterThanOrEqual(1, $form->Fields()->count(), 'Fixtured page has a field');
$this->assertCount(
2,
$form->Fields()->Last()->Options(),
'Fixtured multiple option field has two options'
);
$newForm = $form->duplicate();
$this->assertEquals(
$form->Fields()->count(),
$newForm->Fields()->count(),
'Duplicated page has same number of fields'
);
$this->assertEquals(
$form->Fields()->Last()->Options()->count(),
$newForm->Fields()->Last()->Options()->count(),
'Duplicated dropdown field from duplicated form has duplicated options'
);
}
public function testFormOptions() public function testFormOptions()
{ {
$this->logInWithPermission('ADMIN'); $this->logInWithPermission('ADMIN');

View File

@ -344,3 +344,8 @@ SilverStripe\UserForms\Model\UserDefinedForm:
Fields: Fields:
- =>SilverStripe\UserForms\Model\EditableFormField\EditableEmailField.another-email-field - =>SilverStripe\UserForms\Model\EditableFormField\EditableEmailField.another-email-field
- =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.another-required - =>SilverStripe\UserForms\Model\EditableFormField\EditableTextField.another-required
form-with-multioptions:
Title: Form with MultipleOption fields
Fields:
- =>SilverStripe\UserForms\Model\EditableFormField\EditableDropdown.basic-dropdown