FIX: Injector may instantiate prototypes as if they're singletons (fixes #8567)

This commit is contained in:
Loz Calver 2019-01-23 11:26:16 +00:00
parent b9c29e7e8f
commit 746c0679ad
2 changed files with 11 additions and 1 deletions

View File

@ -866,7 +866,7 @@ class Injector {
return $this->instantiate($spec, $name); return $this->instantiate($spec, $name);
} }
return $this->instantiate($spec); return $this->instantiate($spec, null, 'prototype');
} }
/** /**

View File

@ -29,6 +29,7 @@ class DataObjectTest extends SapphireTest {
'DataObjectTest_Play', 'DataObjectTest_Play',
'DataObjectTest_Ploy', 'DataObjectTest_Ploy',
'DataObjectTest_Bogey', 'DataObjectTest_Bogey',
'DataObjectTest_Sortable',
'ManyManyListTest_Product', 'ManyManyListTest_Product',
'ManyManyListTest_Category', 'ManyManyListTest_Category',
); );
@ -38,6 +39,13 @@ class DataObjectTest extends SapphireTest {
*/ */
public function testSingleton($inst, $defaultValue, $altDefaultValue) public function testSingleton($inst, $defaultValue, $altDefaultValue)
{ {
// Calls to scaffold the test database may have cached service specs for DataObjects
// with the incorrect 'type' set (singleton instead of prototype)
Injector::nest();
$reflectionProp = new ReflectionProperty('Injector', 'specs');
$reflectionProp->setAccessible(true);
$reflectionProp->setValue(Injector::inst(), array());
$inst = $inst(); $inst = $inst();
// Test that populateDefaults() isn't called on singletons // Test that populateDefaults() isn't called on singletons
// which can lead to SQL errors during build, and endless loops // which can lead to SQL errors during build, and endless loops
@ -52,6 +60,8 @@ class DataObjectTest extends SapphireTest {
} else { } else {
$this->assertEmpty($inst->MyFieldWithAltDefault); $this->assertEmpty($inst->MyFieldWithAltDefault);
} }
Injector::unnest();
} }
public function provideSingletons() public function provideSingletons()