2016-03-30 23:37:12 +02:00
|
|
|
<?php
|
|
|
|
|
2016-06-15 06:03:16 +02:00
|
|
|
use SilverStripe\ORM\DataObject;
|
|
|
|
use SilverStripe\ORM\Versioning\ChangeSetItem;
|
|
|
|
|
2016-03-30 23:37:12 +02:00
|
|
|
class ChangeSetItemTest_Versioned extends DataObject {
|
|
|
|
private static $db = [
|
|
|
|
'Foo' => 'Int'
|
|
|
|
];
|
|
|
|
|
|
|
|
private static $extensions = [
|
2016-06-15 06:03:16 +02:00
|
|
|
"SilverStripe\\ORM\\Versioning\\Versioned"
|
2016-03-30 23:37:12 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
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,
|
2016-05-25 07:09:29 +02:00
|
|
|
'ObjectClass' => $object->baseClass(),
|
2016-03-30 23:37:12 +02:00
|
|
|
]);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
ChangeSetItem::CHANGE_CREATED, $item->ChangeType,
|
|
|
|
'New objects that aren\'t yet published should return created'
|
|
|
|
);
|
|
|
|
|
2016-04-01 05:27:59 +02:00
|
|
|
$object->publishRecursive();
|
2016-03-30 23:37:12 +02:00
|
|
|
|
|
|
|
$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'
|
|
|
|
);
|
|
|
|
|
2016-04-01 05:27:59 +02:00
|
|
|
$object->publishRecursive();
|
2016-03-30 23:37:12 +02:00
|
|
|
|
|
|
|
$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'
|
|
|
|
);
|
|
|
|
}
|
2016-04-11 22:54:38 +02:00
|
|
|
|
|
|
|
function testGetForObject() {
|
|
|
|
$object = new ChangeSetItemTest_Versioned(['Foo' => 1]);
|
|
|
|
$object->write();
|
|
|
|
|
|
|
|
$item = new ChangeSetItem([
|
|
|
|
'ObjectID' => $object->ID,
|
2016-05-25 07:09:29 +02:00
|
|
|
'ObjectClass' => $object->baseClass(),
|
2016-04-11 22:54:38 +02:00
|
|
|
]);
|
|
|
|
$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()
|
|
|
|
);
|
|
|
|
}
|
2016-03-30 23:37:12 +02:00
|
|
|
}
|