Skip to content

Commit

Permalink
Merge branch '6.4' into 7.1
Browse files Browse the repository at this point in the history
* 6.4:
  initialize RedisAdapter cursor to 0
  do not skip tests from data providers
  ensure compatibility with Twig 3.15
  [Mime] fix encoding issue with UTF-8 addresses containing doubles spaces
  fix translation file syntax
  [Notifier] Improve Telegrams markdown escaping
  [Validator] [Choice] Fix callback option if not array returned
  [DependencyInjection] Fix linting factories implemented via __callStatic
  [DependencyInjection] Fix replacing abstract arguments with bindings
  Minor fixes around parse_url() checks
  Ensure compatibility with mongodb v2
  Add missing translations for Turkish (tr)
  • Loading branch information
nicolas-grekas committed Oct 25, 2024
2 parents c4600c5 + 728ae8f commit 1f12f9d
Show file tree
Hide file tree
Showing 5 changed files with 44 additions and 6 deletions.
4 changes: 4 additions & 0 deletions Compiler/AbstractRecursivePass.php
Original file line number Diff line number Diff line change
Expand Up @@ -213,6 +213,10 @@ protected function getReflectionMethod(Definition $definition, string $method):
return new \ReflectionMethod(static function (...$arguments) {}, '__invoke');
}

if ($r->hasMethod('__callStatic') && ($r = $r->getMethod('__callStatic')) && $r->isPublic()) {
return new \ReflectionMethod(static function (...$arguments) {}, '__invoke');
}

throw new RuntimeException(sprintf('Invalid service "%s": method "%s()" does not exist.', $this->currentId, $class !== $this->currentId ? $class.'::'.$method : $method));
}

Expand Down
9 changes: 6 additions & 3 deletions Compiler/ResolveBindingsPass.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@

namespace Symfony\Component\DependencyInjection\Compiler;

use Symfony\Component\DependencyInjection\Argument\AbstractArgument;
use Symfony\Component\DependencyInjection\Argument\BoundArgument;
use Symfony\Component\DependencyInjection\Argument\ServiceLocatorArgument;
use Symfony\Component\DependencyInjection\Argument\TaggedIteratorArgument;
Expand Down Expand Up @@ -179,10 +180,10 @@ protected function processValue(mixed $value, bool $isRoot = false): mixed
foreach ($reflectionMethod->getParameters() as $key => $parameter) {
$names[$key] = $parameter->name;

if (\array_key_exists($key, $arguments) && '' !== $arguments[$key]) {
if (\array_key_exists($key, $arguments) && '' !== $arguments[$key] && !$arguments[$key] instanceof AbstractArgument) {
continue;
}
if (\array_key_exists($parameter->name, $arguments) && '' !== $arguments[$parameter->name]) {
if (\array_key_exists($parameter->name, $arguments) && '' !== $arguments[$parameter->name] && !$arguments[$parameter->name] instanceof AbstractArgument) {
continue;
}
if (
Expand Down Expand Up @@ -227,7 +228,9 @@ protected function processValue(mixed $value, bool $isRoot = false): mixed

foreach ($names as $key => $name) {
if (\array_key_exists($name, $arguments) && (0 === $key || \array_key_exists($key - 1, $arguments))) {
$arguments[$key] = $arguments[$name];
if (!array_key_exists($key, $arguments)) {
$arguments[$key] = $arguments[$name];
}
unset($arguments[$name]);
}
}
Expand Down
2 changes: 1 addition & 1 deletion EnvVarProcessor.php
Original file line number Diff line number Diff line change
Expand Up @@ -308,7 +308,7 @@ public function getEnv(string $prefix, string $name, \Closure $getEnv): mixed
throw new RuntimeException(sprintf('Invalid URL in env var "%s".', $name));
}
if (!isset($params['scheme'], $params['host'])) {
throw new RuntimeException(sprintf('Invalid URL env var "%s": schema and host expected, "%s" given.', $name, $env));
throw new RuntimeException(sprintf('Invalid URL in env var "%s": scheme and host expected.', $name));
}
$params += [
'port' => null,
Expand Down
18 changes: 18 additions & 0 deletions Tests/Compiler/CheckTypeDeclarationsPassTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -982,6 +982,17 @@ public function testCallableClass()
$this->addToAssertionCount(1);
}

public function testStaticCallableClass()
{
$container = new ContainerBuilder();
$container->register('foo', StaticCallableClass::class)
->setFactory([StaticCallableClass::class, 'staticMethodCall']);

(new CheckTypeDeclarationsPass())->process($container);

$this->addToAssertionCount(1);
}

public function testIgnoreDefinitionFactoryArgument()
{
$container = new ContainerBuilder();
Expand Down Expand Up @@ -1017,3 +1028,10 @@ public function __call($name, $arguments)
{
}
}

class StaticCallableClass
{
public static function __callStatic($name, $arguments)
{
}
}
17 changes: 15 additions & 2 deletions Tests/Compiler/ResolveBindingsPassTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
namespace Symfony\Component\DependencyInjection\Tests\Compiler;

use PHPUnit\Framework\TestCase;
use Symfony\Component\DependencyInjection\Argument\AbstractArgument;
use Symfony\Component\DependencyInjection\Argument\BoundArgument;
use Symfony\Component\DependencyInjection\Argument\ServiceLocatorArgument;
use Symfony\Component\DependencyInjection\Argument\TaggedIteratorArgument;
Expand Down Expand Up @@ -256,11 +257,23 @@ public function testBindWithNamedArgs()
$definition->setArguments(['c' => 'C', 'hostName' => 'H']);
$definition->setBindings($bindings);

$container->register('foo', CaseSensitiveClass::class);

$pass = new ResolveBindingsPass();
$pass->process($container);

$this->assertEquals(['C', 'K', 'H'], $definition->getArguments());
}

public function testAbstractArg()
{
$container = new ContainerBuilder();

$definition = $container->register(NamedArgumentsDummy::class, NamedArgumentsDummy::class);
$definition->setArguments([new AbstractArgument(), 'apiKey' => new AbstractArgument()]);
$definition->setBindings(['$c' => new BoundArgument('C'), '$apiKey' => new BoundArgument('K')]);

$pass = new ResolveBindingsPass();
$pass->process($container);

$this->assertEquals(['C', 'K'], $definition->getArguments());
}
}

0 comments on commit 1f12f9d

Please sign in to comment.