diff --git a/src/Symfony/Component/DependencyInjection/Dumper/XmlDumper.php b/src/Symfony/Component/DependencyInjection/Dumper/XmlDumper.php
index 05d424d15d653..6ae8d5c611906 100644
--- a/src/Symfony/Component/DependencyInjection/Dumper/XmlDumper.php
+++ b/src/Symfony/Component/DependencyInjection/Dumper/XmlDumper.php
@@ -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 ?? '');
}
diff --git a/src/Symfony/Component/DependencyInjection/Tests/Fixtures/containers/container_non_scalar_tags.php b/src/Symfony/Component/DependencyInjection/Tests/Fixtures/containers/container_non_scalar_tags.php
index 76c69868cc49a..2a1234fa7e26a 100644
--- a/src/Symfony/Component/DependencyInjection/Tests/Fixtures/containers/container_non_scalar_tags.php
+++ b/src/Symfony/Component/DependencyInjection/Tests/Fixtures/containers/container_non_scalar_tags.php
@@ -10,6 +10,7 @@
$container
->register('foo', FooClass::class)
->addTag('foo_tag', [
+ 'name' => 'attributeName',
'foo' => 'bar',
'bar' => [
'foo' => 'bar',
diff --git a/src/Symfony/Component/DependencyInjection/Tests/Fixtures/xml/services_with_array_tags.xml b/src/Symfony/Component/DependencyInjection/Tests/Fixtures/xml/services_with_array_tags.xml
index 8e910be31431c..ba8d790571e8b 100644
--- a/src/Symfony/Component/DependencyInjection/Tests/Fixtures/xml/services_with_array_tags.xml
+++ b/src/Symfony/Component/DependencyInjection/Tests/Fixtures/xml/services_with_array_tags.xml
@@ -4,6 +4,7 @@
+ attributeName
bar
bar