mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
FIX 7934 When lazy loading fields respect version of the record
This commit is contained in:
parent
68894c1e35
commit
fbfff8df28
@ -2056,7 +2056,11 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
|
|||||||
// TableField sets the record ID to "new" on new row data, so don't try doing anything in that case
|
// TableField sets the record ID to "new" on new row data, so don't try doing anything in that case
|
||||||
if(!is_numeric($this->record['ID'])) return false;
|
if(!is_numeric($this->record['ID'])) return false;
|
||||||
|
|
||||||
|
// Limit query to the current record, unless it has the Versioned extension,
|
||||||
|
// in which case it requires special handling through augmentLoadLazyFields()
|
||||||
|
if (!isset($this->record['Version'])){
|
||||||
$dataQuery->where("\"$tableClass\".\"ID\" = {$this->record['ID']}")->limit(1);
|
$dataQuery->where("\"$tableClass\".\"ID\" = {$this->record['ID']}")->limit(1);
|
||||||
|
}
|
||||||
$columns = array();
|
$columns = array();
|
||||||
|
|
||||||
// Add SQL for fields, both simple & multi-value
|
// Add SQL for fields, both simple & multi-value
|
||||||
@ -2069,7 +2073,8 @@ class DataObject extends ViewableData implements DataObjectInterface, i18nEntity
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ($columns) {
|
if ($columns) {
|
||||||
$query = $dataQuery->query(); // eh?
|
$query = $dataQuery->query();
|
||||||
|
$this->extend('augmentLoadLazyFields', $query, $dataQuery, $this->record);
|
||||||
$this->extend('augmentSQL', $query, $dataQuery);
|
$this->extend('augmentSQL', $query, $dataQuery);
|
||||||
|
|
||||||
$dataQuery->setQueriedColumns($columns);
|
$dataQuery->setQueriedColumns($columns);
|
||||||
|
@ -258,6 +258,21 @@ class Versioned extends DataExtension {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* For lazy loaded fields requiring extra sql manipulation, ie versioning
|
||||||
|
* @param SQLQuery $query
|
||||||
|
* @param DataQuery $dataQuery
|
||||||
|
* @param array $record
|
||||||
|
*/
|
||||||
|
function augmentLoadLazyFields(SQLQuery &$query, DataQuery &$dataQuery = null, $record) {
|
||||||
|
$dataClass = $dataQuery->dataClass();
|
||||||
|
if (isset($record['Version'])){
|
||||||
|
$dataQuery->where("\"$dataClass\".\"RecordID\" = " . $record['ID']);
|
||||||
|
$dataQuery->where("\"$dataClass\".\"Version\" = " . $record['Version']);
|
||||||
|
$dataQuery->setQueryParam('Versioned.mode', 'all_versions');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Keep track of the archive tables that have been created
|
* Keep track of the archive tables that have been created
|
||||||
*/
|
*/
|
||||||
|
@ -6,9 +6,12 @@
|
|||||||
|
|
||||||
class DataObjectLazyLoadingTest extends SapphireTest {
|
class DataObjectLazyLoadingTest extends SapphireTest {
|
||||||
|
|
||||||
static $fixture_file = 'DataObjectTest.yml';
|
static $fixture_file = array(
|
||||||
|
'DataObjectTest.yml',
|
||||||
|
'VersionedTest.yml'
|
||||||
|
);
|
||||||
|
|
||||||
// These are all defined in DataObjectTest.php
|
// These are all defined in DataObjectTest.php and VersionedTest.php
|
||||||
protected $extraDataObjects = array(
|
protected $extraDataObjects = array(
|
||||||
'DataObjectTest_Team',
|
'DataObjectTest_Team',
|
||||||
'DataObjectTest_Fixture',
|
'DataObjectTest_Fixture',
|
||||||
@ -18,7 +21,9 @@ class DataObjectLazyLoadingTest extends SapphireTest {
|
|||||||
'DataObjectTest_FieldlessSubTable',
|
'DataObjectTest_FieldlessSubTable',
|
||||||
'DataObjectTest_ValidatedObject',
|
'DataObjectTest_ValidatedObject',
|
||||||
'DataObjectTest_Player',
|
'DataObjectTest_Player',
|
||||||
'DataObjectTest_TeamComment'
|
'DataObjectTest_TeamComment',
|
||||||
|
'VersionedTest_DataObject',
|
||||||
|
'VersionedTest_Subclass'
|
||||||
);
|
);
|
||||||
|
|
||||||
public function testQueriedColumnsID() {
|
public function testQueriedColumnsID() {
|
||||||
@ -244,4 +249,32 @@ class DataObjectLazyLoadingTest extends SapphireTest {
|
|||||||
$this->assertArrayNotHasKey('SubclassDatabaseField_Lazy', $subteam1Lazy->toMap());
|
$this->assertArrayNotHasKey('SubclassDatabaseField_Lazy', $subteam1Lazy->toMap());
|
||||||
$this->assertArrayHasKey('SubclassDatabaseField', $subteam1Lazy->toMap());
|
$this->assertArrayHasKey('SubclassDatabaseField', $subteam1Lazy->toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testLazyLoadedFieldsOnVersionedRecords() {
|
||||||
|
// Save another record, sanity check that we're getting the right one
|
||||||
|
$obj2 = new VersionedTest_Subclass();
|
||||||
|
$obj2->Name = "test2";
|
||||||
|
$obj2->ExtraField = "foo2";
|
||||||
|
$obj2->write();
|
||||||
|
|
||||||
|
// Save the actual inspected record
|
||||||
|
$obj1 = new VersionedTest_Subclass();
|
||||||
|
$obj1->Name = "test";
|
||||||
|
$obj1->ExtraField = "foo";
|
||||||
|
$obj1->write();
|
||||||
|
$version1 = $obj1->Version;
|
||||||
|
$obj1->Name = "test2";
|
||||||
|
$obj1->ExtraField = "baz";
|
||||||
|
$obj1->write();
|
||||||
|
$version2 = $obj1->Version;
|
||||||
|
|
||||||
|
$reloaded = Versioned::get_version('VersionedTest_Subclass', $obj1->ID, $version1);
|
||||||
|
$this->assertEquals($reloaded->Name, 'test');
|
||||||
|
$this->assertEquals($reloaded->ExtraField, 'foo');
|
||||||
|
|
||||||
|
$reloaded = Versioned::get_version('VersionedTest_Subclass', $obj1->ID, $version2);
|
||||||
|
$this->assertEquals($reloaded->Name, 'test2');
|
||||||
|
$this->assertEquals($reloaded->ExtraField, 'baz');
|
||||||
|
$obj1->delete();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user