FIX Add eagerloaded data to ALL relevant lists (#11139)

This commit is contained in:
Guy Sartorelli 2024-02-15 11:57:22 +13:00 committed by GitHub
parent c493485281
commit d33332cb9e
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 37 additions and 2 deletions

View File

@ -1372,7 +1372,7 @@ class DataList extends ViewableData implements SS_List, Filterable, Sortable, Li
if ($parentData->hasID($parentID)) { if ($parentData->hasID($parentID)) {
$parentData->addEagerLoadedData($relationName, $parentID, $eagerLoadedData); $parentData->addEagerLoadedData($relationName, $parentID, $eagerLoadedData);
$added = true; $added = true;
break; // can't break here, because the parent might be in multiple relation lists
} }
} else { } else {
throw new LogicException("Invalid parent for eager loading $relationType relation $relationName"); throw new LogicException("Invalid parent for eager loading $relationType relation $relationName");

View File

@ -940,7 +940,7 @@ class EagerLoadedList extends ViewableData implements Relation, SS_List, Filtera
/** /**
* Gets the final rows for this list after applying all transformations. * Gets the final rows for this list after applying all transformations.
* Currently only limit is applied lazily, but others could be done this was as well. * Currently only limit and sort are applied lazily, but filter could be done this was as well in the future.
*/ */
private function getFinalisedRows(): array private function getFinalisedRows(): array
{ {

View File

@ -1254,4 +1254,39 @@ class DataListEagerLoadingTest extends SapphireTest
$obj = EagerLoadObject::get()->eagerLoad('HasManyEagerLoadObjects')->last(); $obj = EagerLoadObject::get()->eagerLoad('HasManyEagerLoadObjects')->last();
$this->assertInstanceOf(EagerLoadedList::class, $obj->HasManyEagerLoadObjects()); $this->assertInstanceOf(EagerLoadedList::class, $obj->HasManyEagerLoadObjects());
} }
/**
* Tests that if the same record exists in multiple relations, its data is
* eagerloaded without extra unnecessary queries.
*/
public function testEagerLoadingSharedRelations()
{
$record1 = EagerLoadObject::create(['Title' => 'My obj1']);
$record1->write();
$record2 = EagerLoadObject::create(['Title' => 'My obj2']);
$record2->write();
$manyMany = ManyManyEagerLoadObject::create(['Title' => 'My manymany']);
$manyMany->write();
$record1->ManyManyEagerLoadObjects()->add($manyMany);
$record2->ManyManyEagerLoadObjects()->add($manyMany);
$subManyMany = ManyManySubEagerLoadObject::create(['Title' => 'My submanymany']);
$subManyMany->write();
$manyMany->ManyManySubEagerLoadObjects()->add($subManyMany);
$eagerLoadQuery = EagerLoadObject::get()
->filter(['ID' => [$record1->ID, $record2->ID]])
->eagerLoad('ManyManyEagerLoadObjects.ManyManySubEagerLoadObjects');
$loop1Count = 0;
$loop2Count = 0;
foreach ($eagerLoadQuery as $record) {
$loop1Count++;
$eagerLoaded1 = $record->ManyManyEagerLoadObjects();
$this->assertInstanceOf(EagerLoadedList::class, $eagerLoaded1);
foreach ($eagerLoaded1 as $manyManyRecord) {
$loop2Count++;
$eagerLoaded2 = $manyManyRecord->ManyManySubEagerLoadObjects();
$this->assertInstanceOf(EagerLoadedList::class, $eagerLoaded2);
}
}
}
} }