FIX: Duplicating many_many relationships looses the extra fields in 4.0

This commit is contained in:
UndefinedOffset 2018-04-18 10:45:51 -03:00
parent e2c8c80f02
commit fe4b90edc0
3 changed files with 26 additions and 2 deletions

View File

@ -459,8 +459,20 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
// Copy all components from source to destination // Copy all components from source to destination
$source = $sourceObject->getManyManyComponents($manyManyName); $source = $sourceObject->getManyManyComponents($manyManyName);
$dest = $destinationObject->getManyManyComponents($manyManyName); $dest = $destinationObject->getManyManyComponents($manyManyName);
if ($source instanceof UnsavedRelationList) {
$extraFieldNames = array();
} else {
$extraFieldNames = $source->getExtraFields();
}
foreach ($source as $item) { foreach ($source as $item) {
$dest->add($item); // Merge extra fields
$extraFields = array();
foreach ($extraFieldNames as $fieldName => $fieldType) {
$extraFields[$fieldName] = $item->getField($fieldName);
}
$dest->add($item, $extraFields);
} }
} }

View File

@ -102,7 +102,7 @@ class DataObjectDuplicationTest extends SapphireTest
//create relations //create relations
$one->twos()->add($two); $one->twos()->add($two);
$one->threes()->add($three); $one->threes()->add($three, array('TestExtra'=>'three'));
$one = DataObject::get_by_id(DataObjectDuplicationTest\Class1::class, $one->ID); $one = DataObject::get_by_id(DataObjectDuplicationTest\Class1::class, $one->ID);
$two = DataObject::get_by_id(DataObjectDuplicationTest\Class2::class, $two->ID); $two = DataObject::get_by_id(DataObjectDuplicationTest\Class2::class, $two->ID);
@ -161,6 +161,12 @@ class DataObjectDuplicationTest extends SapphireTest
$threeCopy->ones()->First()->ID, $threeCopy->ones()->First()->ID,
"Match between relation of copy and the original" "Match between relation of copy and the original"
); );
$this->assertEquals(
'three',
$oneCopy->threes()->byID($three->ID)->TestExtra,
"Match between extra field of copy and the original"
);
} }
public function testDuplicateManyManyFiltered() public function testDuplicateManyManyFiltered()

View File

@ -20,4 +20,10 @@ class Class1 extends DataObject implements TestOnly
private static $many_many = array( private static $many_many = array(
'threes' => Class3::class 'threes' => Class3::class
); );
private static $many_many_extraFields = array(
'threes' => array(
'TestExtra' => 'Varchar'
)
);
} }