Skip to content

Commit

Permalink
[DependencyInjection] fix XmlDumper when a tag contains also a 'name'…
Browse files Browse the repository at this point in the history
… property
  • Loading branch information
lyrixx committed Mar 13, 2024
1 parent 6236e5e commit bfe8779
Show file tree
Hide file tree
Showing 5 changed files with 10 additions and 7 deletions.
11 changes: 6 additions & 5 deletions Dumper/XmlDumper.php
Original file line number Diff line number Diff line change
Expand Up @@ -134,16 +134,17 @@ private function addService(Definition $definition, ?string $id, \DOMElement $pa
foreach ($tags as $name => $tags) {
foreach ($tags as $attributes) {
$tag = $this->document->createElement('tag');
if (!\array_key_exists('name', $attributes)) {
$tag->setAttribute('name', $name);
} else {
$tag->appendChild($this->document->createTextNode($name));
}

// Check if we have recursive attributes
if (array_filter($attributes, \is_array(...))) {
$tag->setAttribute('name', $name);
$this->addTagRecursiveAttributes($tag, $attributes);
} else {
if (!\array_key_exists('name', $attributes)) {
$tag->setAttribute('name', $name);
} else {
$tag->appendChild($this->document->createTextNode($name));
}
foreach ($attributes as $key => $value) {
$tag->setAttribute($key, $value ?? '');
}
Expand Down
1 change: 1 addition & 0 deletions Tests/Fixtures/containers/container_non_scalar_tags.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
$container
->register('foo', FooClass::class)
->addTag('foo_tag', [
'name' => 'attributeName',
'foo' => 'bar',
'bar' => [
'foo' => 'bar',
Expand Down
1 change: 1 addition & 0 deletions Tests/Fixtures/xml/services_with_array_tags.xml
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
<service id="service_container" class="Symfony\Component\DependencyInjection\ContainerInterface" public="true" synthetic="true"/>
<service id="foo" class="Bar\FooClass">
<tag name="foo_tag">
<attribute name="name">attributeName</attribute>
<attribute name="foo">bar</attribute>
<attribute name="bar">
<attribute name="foo">bar</attribute>
Expand Down
2 changes: 1 addition & 1 deletion Tests/Fixtures/yaml/services_with_array_tags.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,4 @@ services:
foo:
class: Bar\FooClass
tags:
- foo_tag: { foo: bar, bar: { foo: bar, bar: foo } }
- foo_tag: { name: attributeName, foo: bar, bar: { foo: bar, bar: foo } }
2 changes: 1 addition & 1 deletion Tests/Loader/XmlFileLoaderTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -468,7 +468,7 @@ public function testParseServiceTagsWithArrayAttributes()
$loader = new XmlFileLoader($container, new FileLocator(self::$fixturesPath.'/xml'));
$loader->load('services_with_array_tags.xml');

$this->assertEquals(['foo_tag' => [['foo' => 'bar', 'bar' => ['foo' => 'bar', 'bar' => 'foo']]]], $container->getDefinition('foo')->getTags());
$this->assertEquals(['foo_tag' => [['name' => 'attributeName', 'foo' => 'bar', 'bar' => ['foo' => 'bar', 'bar' => 'foo']]]], $container->getDefinition('foo')->getTags());
}

public function testParseTagsWithoutNameThrowsException()
Expand Down

0 comments on commit bfe8779

Please sign in to comment.