Skip to content

Commit

Permalink
[11.x] Handle allows null parameter instead of requiring default value
Browse files Browse the repository at this point in the history
Signed-off-by: Mior Muhammad Zaki <[email protected]>
  • Loading branch information
crynobone committed Sep 20, 2024
1 parent 2714f96 commit 4e06c3e
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 0 deletions.
2 changes: 2 additions & 0 deletions src/Illuminate/Container/Container.php
Original file line number Diff line number Diff line change
Expand Up @@ -1083,6 +1083,8 @@ protected function resolvePrimitive(ReflectionParameter $parameter)

if ($parameter->isDefaultValueAvailable()) {
return $parameter->getDefaultValue();
} elseif ($parameter->allowsNull()) {
return null;
}

if ($parameter->isVariadic()) {
Expand Down
48 changes: 48 additions & 0 deletions tests/Container/ContextualAttributeBindingTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -228,6 +228,7 @@ public function testAttributeOnAppCall()
$container->singleton('config', fn () => new Repository([
'app' => [
'timezone' => 'Europe/Paris',
'locale' => null,
],
]));

Expand All @@ -236,6 +237,35 @@ public function testAttributeOnAppCall()
});

$this->assertEquals('Europe/Paris', $value);

$value = $container->call(function (#[Config('app.locale')] ?string $value) {
return $value;
});

$this->assertNull($value);
}

public function testNestedAttributeOnAppCall()
{
$container = new Container;
$container->singleton('config', fn () => new Repository([
'app' => [
'timezone' => 'Europe/Paris',
'locale' => null,
],
]));

$value = $container->call(function (TimezoneObject $object) {
return $object;
});

$this->assertEquals('Europe/Paris', $value->timezone);

$value = $container->call(function (LocaleObject $object) {
return $object;
});

$this->assertNull($value->locale);
}

public function testTagAttribute()
Expand Down Expand Up @@ -404,3 +434,21 @@ public function __construct(#[Storage('foo')] Filesystem $foo, #[Storage('bar')]
{
}
}

final class TimezoneObject
{
public function __construct(
#[Config('app.timezone')] public readonly ?string $timezone
) {
//
}
}

final class LocaleObject
{
public function __construct(
#[Config('app.locale')] public readonly ?string $locale
) {
//
}
}

0 comments on commit 4e06c3e

Please sign in to comment.