mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Merge pull request #6425 from andrewandante/bugfix/duplicating-copies-created-dbfield
remove Created field on duplicate
This commit is contained in:
commit
fd9b872cb5
@ -531,7 +531,9 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
|
|||||||
*/
|
*/
|
||||||
public function duplicate($doWrite = true) {
|
public function duplicate($doWrite = true) {
|
||||||
$className = $this->class;
|
$className = $this->class;
|
||||||
$clone = new $className( $this->toMap(), false, $this->model );
|
$map = $this->toMap();
|
||||||
|
unset($map['Created']);
|
||||||
|
$clone = new $className( $map, false, $this->model );
|
||||||
$clone->ID = 0;
|
$clone->ID = 0;
|
||||||
|
|
||||||
$clone->invokeWithExtensions('onBeforeDuplicate', $this, $doWrite);
|
$clone->invokeWithExtensions('onBeforeDuplicate', $this, $doWrite);
|
||||||
|
@ -11,10 +11,11 @@ class DataObjectDuplicationTest extends SapphireTest {
|
|||||||
);
|
);
|
||||||
|
|
||||||
public function testDuplicate() {
|
public function testDuplicate() {
|
||||||
|
SS_Datetime::set_mock_now('2016-01-01 01:01:01');
|
||||||
$orig = new DataObjectDuplicateTestClass1();
|
$orig = new DataObjectDuplicateTestClass1();
|
||||||
$orig->text = 'foo';
|
$orig->text = 'foo';
|
||||||
$orig->write();
|
$orig->write();
|
||||||
|
SS_Datetime::set_mock_now('2016-01-02 01:01:01');
|
||||||
$duplicate = $orig->duplicate();
|
$duplicate = $orig->duplicate();
|
||||||
$this->assertInstanceOf('DataObjectDuplicateTestClass1', $duplicate,
|
$this->assertInstanceOf('DataObjectDuplicateTestClass1', $duplicate,
|
||||||
'Creates the correct type'
|
'Creates the correct type'
|
||||||
@ -28,6 +29,8 @@ class DataObjectDuplicationTest extends SapphireTest {
|
|||||||
$this->assertEquals(2, DataObjectDuplicateTestClass1::get()->Count(),
|
$this->assertEquals(2, DataObjectDuplicateTestClass1::get()->Count(),
|
||||||
'Only creates a single duplicate'
|
'Only creates a single duplicate'
|
||||||
);
|
);
|
||||||
|
$this->assertEquals(SS_Datetime::now()->Nice(), $duplicate->dbObject('Created')->Nice());
|
||||||
|
$this->assertNotEquals($orig->dbObject('Created')->Nice(), $duplicate->dbObject('Created')->Nice());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testDuplicateHasOne() {
|
public function testDuplicateHasOne() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user