Skip to content

Commit

Permalink
FIX Allow passing objects to InjectionCreator::create()
Browse files Browse the repository at this point in the history
Co-authored-by: Nate Devereux <[email protected]>
  • Loading branch information
emteknetnz and Nate Devereux committed Oct 19, 2022
1 parent 0b80643 commit 063674c
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 3 deletions.
22 changes: 19 additions & 3 deletions src/Core/Injector/InjectionCreator.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,29 @@
*/
class InjectionCreator implements Factory
{
/**
* Create a new instance of a class
*
* Passing an object for $class will result from using an anonymous class in unit testing, e.g.
* Injector::inst()->load([SomeClass::class => ['class' => new class { ... }]]);
*
* @param string|object $class - string: The FQCN of the class, object: A class instance
*/
public function create($class, array $params = [])
{
if (!class_exists($class ?? '')) {
if (is_object($class)) {
$class = get_class($class);
}
if (!is_string($class)) {
throw new \InvalidArgumentException('$class parameter must be a string or an object');
}
if (!class_exists($class)) {
throw new InjectorNotFoundException("Class {$class} does not exist");
}

// Ensure there are no string keys as they cannot be unpacked with the `...` operator
$values = array_values($params ?? []);
$values = array_values($params);

return new $class(...$values);
}
}
}
23 changes: 23 additions & 0 deletions tests/php/Core/Injector/InjectorTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -1065,4 +1065,27 @@ public function testNest()
Injector::unnest();
$this->nestingLevel--;
}

public function testAnonymousClass()
{
Injector::inst()->load([
'Some\\Project\\Class' => [
// the php anonymous class syntax will instantiate a new anonymous class object, with ('abc')
// passed to the constructor
'class' => new class ('abc') {
private string $property;
public function __construct(string $value)
{
$this->property = $value;
}
public function foo(): string
{
return $this->property;
}
}
],
]);
// assert that Injector creates a new instance of the anonymous class, with ('def') passed to the constructor
$this->assertSame('def', Injector::inst()->create('Some\\Project\\Class', 'def')->foo());
}
}

0 comments on commit 063674c

Please sign in to comment.