mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
FIX: Set many-many-through joinRecord on newly added records.
When many-many-through relations are queried, a joinRecord is set on each DataObject in the list to provide the extra fields defined on the connector object. This didn’t previously happen when the record was first add()ed to a list. This fixes that bug.
This commit is contained in:
parent
6446b50c4a
commit
01d3b4fd96
@ -217,6 +217,11 @@ class ManyManyThroughList extends RelationList
|
|||||||
$record = $hasManyList->createDataObject($extraFields ?: []);
|
$record = $hasManyList->createDataObject($extraFields ?: []);
|
||||||
$record->$localKey = $itemID;
|
$record->$localKey = $itemID;
|
||||||
$hasManyList->add($record);
|
$hasManyList->add($record);
|
||||||
|
|
||||||
|
// Link the join object to the $item, as if it were queried from within this list
|
||||||
|
if ($item instanceof DataObject) {
|
||||||
|
$item->setJoin($record, $this->manipulator->getJoinAlias());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -6,6 +6,7 @@ use SilverStripe\Core\Config\Config;
|
|||||||
use SilverStripe\Dev\SapphireTest;
|
use SilverStripe\Dev\SapphireTest;
|
||||||
use SilverStripe\ORM\DataObject;
|
use SilverStripe\ORM\DataObject;
|
||||||
use SilverStripe\ORM\ManyManyThroughList;
|
use SilverStripe\ORM\ManyManyThroughList;
|
||||||
|
use SilverStripe\ORM\Tests\ManyManyThroughListTest\Item;
|
||||||
use SilverStripe\ORM\Tests\ManyManyThroughListTest\PolyItem;
|
use SilverStripe\ORM\Tests\ManyManyThroughListTest\PolyItem;
|
||||||
use SilverStripe\ORM\Tests\ManyManyThroughListTest\PolyJoinObject;
|
use SilverStripe\ORM\Tests\ManyManyThroughListTest\PolyJoinObject;
|
||||||
use SilverStripe\ORM\Tests\ManyManyThroughListTest\Locale;
|
use SilverStripe\ORM\Tests\ManyManyThroughListTest\Locale;
|
||||||
@ -75,6 +76,14 @@ class ManyManyThroughListTest extends SapphireTest
|
|||||||
$this->assertNotNull($item2->getJoin());
|
$this->assertNotNull($item2->getJoin());
|
||||||
$this->assertEquals('join 2', $item2->getJoin()->Title);
|
$this->assertEquals('join 2', $item2->getJoin()->Title);
|
||||||
$this->assertEquals('join 2', $item2->ManyManyThroughListTest_JoinObject->Title);
|
$this->assertEquals('join 2', $item2->ManyManyThroughListTest_JoinObject->Title);
|
||||||
|
|
||||||
|
// Check that the join record is set for new records added
|
||||||
|
$item3 = new Item;
|
||||||
|
$this->assertNull($item3->getJoin());
|
||||||
|
$parent->Items()->add($item3);
|
||||||
|
$expectedJoinObject = ManyManyThroughListTest\JoinObject::get()->filter(['ParentID' => $parent->ID, 'ChildID' => $item3->ID ])->first();
|
||||||
|
$this->assertEquals($expectedJoinObject->ID, $item3->getJoin()->ID);
|
||||||
|
$this->assertEquals(get_class($expectedJoinObject), get_class($item3->getJoin()));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user