mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
35e642d0bf
You shouldn't have to worry about exactly formatting the reference to get a ChangeSetItem related to a DataObject, and doing it that way makes you vulnerable to breakages like introduced in previous API change
98 lines
2.4 KiB
PHP
98 lines
2.4 KiB
PHP
<?php
|
|
|
|
class ChangeSetItemTest_Versioned extends DataObject {
|
|
private static $db = [
|
|
'Foo' => 'Int'
|
|
];
|
|
|
|
private static $extensions = [
|
|
"Versioned"
|
|
];
|
|
|
|
function canEdit($member = null) { return true; }
|
|
}
|
|
|
|
/**
|
|
* @package framework
|
|
* @subpackage tests
|
|
*/
|
|
class ChangeSetItemTest extends SapphireTest {
|
|
|
|
protected $extraDataObjects = [
|
|
'ChangeSetItemTest_Versioned'
|
|
];
|
|
|
|
function testChangeType() {
|
|
$object = new ChangeSetItemTest_Versioned(['Foo' => 1]);
|
|
$object->write();
|
|
|
|
$item = new ChangeSetItem([
|
|
'ObjectID' => $object->ID,
|
|
'ObjectClass' => ClassInfo::baseDataClass($object->ClassName)
|
|
]);
|
|
|
|
$this->assertEquals(
|
|
ChangeSetItem::CHANGE_CREATED, $item->ChangeType,
|
|
'New objects that aren\'t yet published should return created'
|
|
);
|
|
|
|
$object->publishRecursive();
|
|
|
|
$this->assertEquals(
|
|
ChangeSetItem::CHANGE_NONE, $item->ChangeType,
|
|
'Objects that have just been published should return no change'
|
|
);
|
|
|
|
$object->Foo += 1;
|
|
$object->write();
|
|
|
|
$this->assertEquals(
|
|
ChangeSetItem::CHANGE_MODIFIED, $item->ChangeType,
|
|
'Object that have unpublished changes written to draft should show as modified'
|
|
);
|
|
|
|
$object->publishRecursive();
|
|
|
|
$this->assertEquals(
|
|
ChangeSetItem::CHANGE_NONE, $item->ChangeType,
|
|
'Objects that have just been published should return no change'
|
|
);
|
|
|
|
// We need to use a copy, because ID is set to 0 by delete, causing the following unpublish to fail
|
|
$objectCopy = clone $object; $objectCopy->delete();
|
|
|
|
$this->assertEquals(
|
|
ChangeSetItem::CHANGE_DELETED, $item->ChangeType,
|
|
'Objects that have been deleted from draft (but not yet unpublished) should show as deleted'
|
|
);
|
|
|
|
$object->doUnpublish();
|
|
|
|
$this->assertEquals(
|
|
ChangeSetItem::CHANGE_NONE, $item->ChangeType,
|
|
'Objects that have been deleted and then unpublished should return no change'
|
|
);
|
|
}
|
|
|
|
function testGetForObject() {
|
|
$object = new ChangeSetItemTest_Versioned(['Foo' => 1]);
|
|
$object->write();
|
|
|
|
$item = new ChangeSetItem([
|
|
'ObjectID' => $object->ID,
|
|
'ObjectClass' => ClassInfo::baseDataClass($object)
|
|
]);
|
|
$item->write();
|
|
|
|
$this->assertEquals(
|
|
ChangeSetItemTest_Versioned::get()->byID($object->ID)->toMap(),
|
|
ChangeSetItem::get_for_object($object)->first()->Object()->toMap()
|
|
);
|
|
|
|
$this->assertEquals(
|
|
ChangeSetItemTest_Versioned::get()->byID($object->ID)->toMap(),
|
|
ChangeSetItem::get_for_object_by_id($object->ID, $object->ClassName)->first()->Object()->toMap()
|
|
);
|
|
}
|
|
}
|