diff --git a/src/Twig/Extension/RenderElementExtension.php b/src/Twig/Extension/RenderElementExtension.php index 595f9a6c310..6abb3c84256 100644 --- a/src/Twig/Extension/RenderElementExtension.php +++ b/src/Twig/Extension/RenderElementExtension.php @@ -268,8 +268,9 @@ public function renderRelationElement($element, FieldDescriptionInterface $field if (null === $propertyPath) { // For BC kept associated_tostring option behavior + // NEXT_MAJOR Remove next line. $method = $fieldDescription->getOption('associated_tostring'); - + // NEXT_MAJOR: Remove the "if" part and leave the "else" part if ($method) { @trigger_error( 'Option "associated_tostring" is deprecated since version 2.3 and will be removed in 4.0. Use "associated_property" instead.', @@ -300,8 +301,9 @@ public function renderRelationElement($element, FieldDescriptionInterface $field } /** - * NEXT_MAJOR: Make this method protected - * Get template. + * NEXT_MAJOR: Make this method private. + * + * @internal This method will be private in the next major version * * @param string $defaultTemplate * @@ -339,8 +341,6 @@ public function getTemplate( } /** - * NEXT MAJOR: Make this method private. - * * Extracts the object and requested value from the $listElement. * * @param object|array $listElement @@ -349,7 +349,7 @@ public function getTemplate( * * @return array An array containing object and value */ - public function getObjectAndValueFromListElement( + private function getObjectAndValueFromListElement( $listElement, FieldDescriptionInterface $fieldDescription ): array { diff --git a/src/Twig/Extension/SonataAdminExtension.php b/src/Twig/Extension/SonataAdminExtension.php index 66a6cbd90d8..41e65b98ec6 100644 --- a/src/Twig/Extension/SonataAdminExtension.php +++ b/src/Twig/Extension/SonataAdminExtension.php @@ -754,34 +754,4 @@ protected function getTemplate( return $this->renderElementExtension->getTemplate($fieldDescription, $defaultTemplate, $$environment); } - - /** - * NEXT_MAJOR: Remove this method - * Extracts the object and requested value from the $listElement. - * - * @param object|array $listElement - * - * @throws \TypeError when $listElement is not an object or an array with an object on offset 0 - * - * @return array An array containing object and value - * - * @deprecated since sonata-project/admin-bundle 3.x and will be removed in 4.0 - */ - private function getObjectAndValueFromListElement( - $listElement, - FieldDescriptionInterface $fieldDescription - ): array { - if ('sonata_deprecation_mute' !== (\func_get_args()[2] ?? null)) { - @trigger_error(sprintf( - 'The %s method is deprecated in favor of RenderElementExtension::getObjectAndValueFromListElement since version 3.x and will be removed in 4.0.', - __METHOD__ - ), E_USER_DEPRECATED); - } - - if (null === $this->renderElementExtension) { - $this->renderElementExtension = new RenderElementExtension($this->propertyAccessor, $this->templateRegistries, $this->logger); - } - - return $this->renderElementExtension->getObjectAndValueFromListElement($listElement, $fieldDescription); - } } diff --git a/src/Twig/Extension/XEditableExtension.php b/src/Twig/Extension/XEditableExtension.php index 3d5ba13fe8b..9650d3a282a 100644 --- a/src/Twig/Extension/XEditableExtension.php +++ b/src/Twig/Extension/XEditableExtension.php @@ -71,14 +71,6 @@ public function getXEditableType(string $type) return $this->xEditableTypeMapping[$type] ?? false; } - /** - * @param string[] $xEditableTypeMapping - */ - public function setXEditableTypeMapping($xEditableTypeMapping) - { - $this->xEditableTypeMapping = $xEditableTypeMapping; - } - /** * Return xEditable choices based on the field description choices options & catalogue options. * With the following choice options: diff --git a/tests/Twig/Extension/RenderElementExtensionTest.php b/tests/Twig/Extension/RenderElementExtensionTest.php index 5e404c929d3..6e601b8bca9 100644 --- a/tests/Twig/Extension/RenderElementExtensionTest.php +++ b/tests/Twig/Extension/RenderElementExtensionTest.php @@ -33,6 +33,8 @@ use Symfony\Component\DependencyInjection\Container; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\PropertyAccess\PropertyAccess; +use Symfony\Component\PropertyAccess\PropertyAccessor; +use Symfony\Component\PropertyAccess\PropertyAccessorInterface; use Symfony\Component\Routing\Generator\UrlGenerator; use Symfony\Component\Routing\Loader\XmlFileLoader; use Symfony\Component\Routing\RequestContext; @@ -50,6 +52,22 @@ final class RenderElementExtensionTest extends TestCase { use ExpectDeprecationTrait; + private const X_EDITABLE_TYPE_MAPPING = [ + 'choice' => 'select', + 'boolean' => 'select', + 'text' => 'text', + 'textarea' => 'textarea', + 'html' => 'textarea', + 'email' => 'email', + 'string' => 'text', + 'smallint' => 'text', + 'bigint' => 'text', + 'integer' => 'number', + 'decimal' => 'number', + 'currency' => 'number', + 'percent' => 'number', + 'url' => 'url', + ]; /** * @var RenderElementExtension @@ -115,23 +133,6 @@ protected function setUp(): void { date_default_timezone_set('Europe/London'); - $xEditableTypeMapping = [ - 'choice' => 'select', - 'boolean' => 'select', - 'text' => 'text', - 'textarea' => 'textarea', - 'html' => 'textarea', - 'email' => 'email', - 'string' => 'text', - 'smallint' => 'text', - 'bigint' => 'text', - 'integer' => 'number', - 'decimal' => 'number', - 'currency' => 'number', - 'percent' => 'number', - 'url' => 'url', - ]; - $container = new Container(); $this->pool = new Pool($container, '', ''); @@ -174,53 +175,13 @@ protected function setUp(): void 'optimizations' => 0, ]); - //NEXT_MAJOR: Remove follwing block - /** - * @var AuthorizationCheckerInterface - */ - $securityChecker = $this->createStub(AuthorizationCheckerInterface::class); - $this->twigExtension = new SonataAdminExtension( - $this->pool, - $this->logger, - $this->translator, - $this->container, - $propertyAccessor, - $securityChecker - ); - $this->twigExtension->setXEditableTypeMapping($xEditableTypeMapping, 'sonata_deprecation_mute'); - $this->environment->addExtension($this->twigExtension); - // block ends - - //NEXT_MAJOR: Uncomment block below - /* $this->twigExtension = new RenderElementExtension( $propertyAccessor, $this->container, $this->logger, ); - $this->environment->addExtension($this->twigExtension); - // xeditable extension - $xEditableExtension = new XEditableExtension($translator, $xEditableTypeMapping); - $xEditableExtension->setXEditableTypeMapping($xEditableTypeMapping); - $this->environment->addExtension($xEditableExtension); - */ - $this->environment->addExtension(new TranslationExtension($translator)); - $this->environment->addExtension(new FakeTemplateRegistryExtension()); - - // routing extension - $xmlFileLoader = new XmlFileLoader(new FileLocator([sprintf('%s/../../../src/Resources/config/routing', __DIR__)])); - $routeCollection = $xmlFileLoader->load('sonata_admin.xml'); - - $xmlFileLoader = new XmlFileLoader(new FileLocator([sprintf('%s/../../Fixtures/Resources/config/routing', __DIR__)])); - - $testRouteCollection = $xmlFileLoader->load('routing.xml'); - - $routeCollection->addCollection($testRouteCollection); - $requestContext = new RequestContext(); - $urlGenerator = new UrlGenerator($routeCollection, $requestContext); - $this->environment->addExtension(new RoutingExtension($urlGenerator)); - $this->environment->addExtension(new StringExtension()); + $this->registerRequiredTwigExtensions($propertyAccessor); // initialize object $this->object = new \stdClass(); @@ -242,12 +203,6 @@ protected function setUp(): void ->with($this->equalTo($this->object)) ->willReturn(12345); - $this->admin - ->method('trans') - ->willReturnCallback(static function ($id, $parameters = [], $domain = null) use ($translator) { - return $translator->trans($id, $parameters, $domain); - }); - $this->adminBar = $this->createMock(AbstractAdmin::class); $this->adminBar ->method('hasAccess') @@ -277,8 +232,9 @@ protected function setUp(): void } /** + * NEXT_MAJOR: Remove legacy group. + * * @group legacy - * @expectedDeprecation The Sonata\AdminBundle\Admin\AbstractAdmin::getTemplate method is deprecated (since sonata-project/admin-bundle 3.34, will be dropped in 4.0. Use TemplateRegistry services instead). * @dataProvider getRenderListElementTests */ public function testRenderListElement(string $expected, string $type, $value, array $options): void @@ -356,6 +312,9 @@ public function testRenderListElement(string $expected, string $type, $value, ar } }); + // NEXT_MAJOR: Remove next line. + $this->expectDeprecation('The Sonata\AdminBundle\Admin\AbstractAdmin::getTemplate method is deprecated (since sonata-project/admin-bundle 3.34, will be dropped in 4.0. Use TemplateRegistry services instead).'); + $this->assertSame( $this->removeExtraWhitespace($expected), $this->removeExtraWhitespace($this->twigExtension->renderListElement( @@ -367,10 +326,9 @@ public function testRenderListElement(string $expected, string $type, $value, ar } /** - * NEXT_MAJOR: Remove @expectedDeprecation. + * NEXT_MAJOR: Remove legacy group. * * @group legacy - * @expectedDeprecation The Sonata\AdminBundle\Admin\AbstractAdmin::getTemplate method is deprecated (since sonata-project/admin-bundle 3.34, will be dropped in 4.0. Use TemplateRegistry services instead). */ public function testRenderListElementWithAdditionalValuesInArray(): void { @@ -387,6 +345,9 @@ public function testRenderListElementWithAdditionalValuesInArray(): void ->method('getTemplate') ->willReturn('@SonataAdmin/CRUD/list_string.html.twig'); + // NEXT_MAJOR: Remove next line. + $this->expectDeprecation('The Sonata\AdminBundle\Admin\AbstractAdmin::getTemplate method is deprecated (since sonata-project/admin-bundle 3.34, will be dropped in 4.0. Use TemplateRegistry services instead).'); + $this->assertSame( $this->removeExtraWhitespace('