From 28fe03bbee2aa445320dea813dc26a6187bf416a Mon Sep 17 00:00:00 2001 From: Fran Moreno Date: Thu, 10 Dec 2020 20:44:39 +0100 Subject: [PATCH] Deprecate passing other type than string|null as prefix --- src/Util/FormBuilderIterator.php | 12 +++++++++++- tests/Admin/AdminHelperTest.php | 4 ++-- tests/Util/FormBuilderIteratorTest.php | 18 ++++++++++++++++++ 3 files changed, 31 insertions(+), 3 deletions(-) diff --git a/src/Util/FormBuilderIterator.php b/src/Util/FormBuilderIterator.php index a16083a2cd..3c97587bc5 100644 --- a/src/Util/FormBuilderIterator.php +++ b/src/Util/FormBuilderIterator.php @@ -52,10 +52,20 @@ class FormBuilderIterator extends \RecursiveArrayIterator * * @param string|false $prefix */ - public function __construct(FormBuilderInterface $formBuilder, $prefix = false) + public function __construct(FormBuilderInterface $formBuilder, $prefix = null) { parent::__construct(); $this->formBuilder = $formBuilder; + + // NEXT_MAJOR: Remove this block. + if (null !== $prefix && !\is_string($prefix)) { + @trigger_error(sprintf( + 'Passing other type than string or null as argument 2 for method %s() is deprecated since' + .' sonata-project/admin-bundle 3.x. It will accept only string and null in version 4.0.', + __METHOD__ + ), E_USER_DEPRECATED); + } + // NEXT_MAJOR: Remove next line. $this->prefix = \is_string($prefix) ? $prefix : $formBuilder->getName(); // NEXT_MAJOR: Uncomment next line. diff --git a/tests/Admin/AdminHelperTest.php b/tests/Admin/AdminHelperTest.php index cff0c57bb8..f9a657fac5 100644 --- a/tests/Admin/AdminHelperTest.php +++ b/tests/Admin/AdminHelperTest.php @@ -91,8 +91,8 @@ public function testGetChildFormBuilder(): void public function testGetGrandChildFormBuilder(): void { - $formFactory = $this->createMock(FormFactoryInterface::class); - $eventDispatcher = $this->createMock(EventDispatcherInterface::class); + $formFactory = $this->createStub(FormFactoryInterface::class); + $eventDispatcher = $this->createStub(EventDispatcherInterface::class); $formBuilder = new FormBuilder('parent', \stdClass::class, $eventDispatcher, $formFactory); $childFormBuilder = new FormBuilder('child', \stdClass::class, $eventDispatcher, $formFactory); diff --git a/tests/Util/FormBuilderIteratorTest.php b/tests/Util/FormBuilderIteratorTest.php index ff15f7708c..6ff9a8c617 100644 --- a/tests/Util/FormBuilderIteratorTest.php +++ b/tests/Util/FormBuilderIteratorTest.php @@ -15,6 +15,7 @@ use PHPUnit\Framework\TestCase; use Sonata\AdminBundle\Util\FormBuilderIterator; +use Symfony\Bridge\PhpUnit\ExpectDeprecationTrait; use Symfony\Component\EventDispatcher\EventDispatcherInterface; use Symfony\Component\Form\Extension\Core\Type\TextType; use Symfony\Component\Form\FormBuilder; @@ -25,6 +26,8 @@ */ class FormBuilderIteratorTest extends TestCase { + use ExpectDeprecationTrait; + /** * @var EventDispatcherInterface */ @@ -69,4 +72,19 @@ public function testHasChildren(): void $iterator = new FormBuilderIterator($this->builder); $this->assertTrue($iterator->hasChildren()); } + + /** + * NEXT_MAJOR: Remove this test. + * + * @group legacy + */ + public function testTriggersADeprecationWithWrongPrefixType(): void + { + $this->expectDeprecation('Passing other type than string or null as argument 2 for method Sonata\AdminBundle\Util\FormBuilderIterator::__construct() is deprecated since sonata-project/admin-bundle 3.x. It will accept only string and null in version 4.0.'); + + $this->builder->add('name', TextType::class); + $iterator = new FormBuilderIterator($this->builder, new \stdClass()); + + $this->assertSame($iterator->key(), 'name_name'); + } }