mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
BUG fix dependency injection stumbling over ViewableData's __isset
This commit is contained in:
parent
a584c8c83a
commit
d516063db7
@ -654,10 +654,10 @@ class Injector {
|
|||||||
// If the type defines some injections, set them here
|
// If the type defines some injections, set them here
|
||||||
if ($injections && count($injections)) {
|
if ($injections && count($injections)) {
|
||||||
foreach ($injections as $property => $value) {
|
foreach ($injections as $property => $value) {
|
||||||
// we're checking isset in case it already has a property at this name
|
// we're checking empty in case it already has a property at this name
|
||||||
// this doesn't catch privately set things, but they will only be set by a setter method,
|
// this doesn't catch privately set things, but they will only be set by a setter method,
|
||||||
// which should be responsible for preventing further setting if it doesn't want it.
|
// which should be responsible for preventing further setting if it doesn't want it.
|
||||||
if (!isset($object->$property)) {
|
if (empty($object->$property)) {
|
||||||
$value = $this->convertServiceProperty($value);
|
$value = $this->convertServiceProperty($value);
|
||||||
$this->setObjectProperty($object, $property, $value);
|
$this->setObjectProperty($object, $property, $value);
|
||||||
}
|
}
|
||||||
|
@ -458,6 +458,18 @@ class InjectorTest extends SapphireTest {
|
|||||||
$this->assertEquals('NewRequirementsBackend', get_class($si->backend));
|
$this->assertEquals('NewRequirementsBackend', get_class($si->backend));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testSetterInjections() {
|
||||||
|
$injector = new Injector();
|
||||||
|
$config = array(
|
||||||
|
'NewRequirementsBackend',
|
||||||
|
);
|
||||||
|
|
||||||
|
$injector->load($config);
|
||||||
|
|
||||||
|
$si = $injector->get('TestSetterInjections');
|
||||||
|
$this->assertEquals('NewRequirementsBackend', get_class($si->getBackend()));
|
||||||
|
}
|
||||||
|
|
||||||
public function testCustomObjectCreator() {
|
public function testCustomObjectCreator() {
|
||||||
$injector = new Injector();
|
$injector = new Injector();
|
||||||
$injector->setObjectCreator(new SSObjectCreator($injector));
|
$injector->setObjectCreator(new SSObjectCreator($injector));
|
||||||
@ -752,6 +764,28 @@ class TestStaticInjections implements TestOnly {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make sure DI works with ViewableData's implementation of __isset
|
||||||
|
*/
|
||||||
|
class TestSetterInjections extends ViewableData implements TestOnly {
|
||||||
|
|
||||||
|
protected $backend;
|
||||||
|
|
||||||
|
/** @config */
|
||||||
|
private static $dependencies = array(
|
||||||
|
'backend' => '%$NewRequirementsBackend'
|
||||||
|
);
|
||||||
|
|
||||||
|
public function getBackend() {
|
||||||
|
return $this->backend;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setBackend($backend) {
|
||||||
|
$this->backend = $backend;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An example object creator that uses the SilverStripe class(arguments) mechanism for
|
* An example object creator that uses the SilverStripe class(arguments) mechanism for
|
||||||
* creating new objects
|
* creating new objects
|
||||||
|
Loading…
x
Reference in New Issue
Block a user