Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix EventArgs::getEntityManger deprecation #2639

Merged
merged 6 commits into from
Oct 29, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
24 changes: 24 additions & 0 deletions src/Mapping/Event/Adapter/ORM.php
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,18 @@ public function getObjectManager()
throw new \LogicException(sprintf('Event args must be set before calling "%s()".', __METHOD__));
}

if (\method_exists($this->args, 'getObjectManager')) {
DubbleClick marked this conversation as resolved.
Show resolved Hide resolved
return $this->args->getObjectManager();
}

@trigger_error(sprintf(
'Calling "%s()" on an event of type "%s" is deprecated since gedmo/doctrine-extensions 3.x'
.' and will throw a "%s" error in version 4.0.',
__METHOD__,
get_class($this->args),
\TypeError::class
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should this be \Error::class?

Copy link
Contributor Author

@DubbleClick DubbleClick Sep 15, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think a TypeError is fine if we look at it as the $args class (type) not implementing the getObjectManager method. If we look at it like "the type $args::class must implement getObjectManager for version 4.0" then it should be \Error.

Edit: never mind, you're right. It wouldn't throw a TypeError.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If there won't be an instanceof check here, I guess we can't even be sure if\Error will be thrown. If that is the case, I guess we should say something like "it will be not supported" instead.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No instanceof check is required, calling a method that doesn't exist throws an \Error.

Fatal error: Uncaught Error: Call to undefined method OldEventArgs::getObjectManager()

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we maybe add instanceof checks with LifecycleEventArgs, LoadClassMetadataEventArgs, ManagerEventArgs and OnClearEventArgs? Maybe they should all extend from ManagerEventArgs in doctrine/persistence 🤔 ? For the getObjectManager() call I mean, or any other solution?

It would be nice to finally move this forward.

Copy link
Contributor Author

@DubbleClick DubbleClick Oct 17, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't see any need to do that. The \method_exists call will make sure that it's fully backwards compatible for now.

If anything, that would be a discussion for later (when Doctrine ORM 3.0 releases and getEntityManager is removed
and we release DoctrineExtensions 4.0) when we remove the \method_exists call and directly call getObjectManager(). But even then, I don't see a point in checking the type of the args - all we care about is that they abide by Doctrines interfaces and implement getObjectManager() instead of getEntityManager() (that we currently also call without checking).

), E_USER_DEPRECATED);

return $this->args->getEntityManager();
}

Expand All @@ -104,6 +116,18 @@ public function getObject(): object
throw new \LogicException(sprintf('Event args must be set before calling "%s()".', __METHOD__));
}

if (\method_exists($this->args, 'getObject')) {
return $this->args->getObject();
}

@trigger_error(sprintf(
'Calling "%s()" on an event of type "%s" is deprecated since gedmo/doctrine-extensions 3.x'
.' and will throw a "%s" error in version 4.0.',
__METHOD__,
get_class($this->args),
\TypeError::class
), E_USER_DEPRECATED);

return $this->args->getEntity();
}

Expand Down
31 changes: 31 additions & 0 deletions src/Uploadable/Event/UploadableBaseEventArgs.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@

use Doctrine\Common\EventArgs;
use Doctrine\ORM\EntityManagerInterface;
use Doctrine\Persistence\ObjectManager;
use Gedmo\Uploadable\FileInfo\FileInfoInterface;
use Gedmo\Uploadable\UploadableListener;

Expand Down Expand Up @@ -100,6 +101,21 @@ public function getListener()
* @return EntityManagerInterface
*/
public function getEntityManager()
{
@trigger_error(sprintf(
'"%s()" is deprecated since gedmo/doctrine-extensions 3.x and will be removed in version 4.0.',
__METHOD__
), E_USER_DEPRECATED);

return $this->em;
}

/**
* Retrieve associated EntityManager
*
* @return ObjectManager
*/
public function getObjectManager()
{
return $this->em;
DubbleClick marked this conversation as resolved.
Show resolved Hide resolved
}
Expand All @@ -110,6 +126,21 @@ public function getEntityManager()
* @return object
*/
public function getEntity()
{
@trigger_error(sprintf(
'"%s()" is deprecated since gedmo/doctrine-extensions 3.x and will be removed in version 4.0.',
__METHOD__
), E_USER_DEPRECATED);

return $this->entity;
}

/**
* Retrieve associated Object
*
* @return object
*/
public function getObject()
{
return $this->entity;
}
Expand Down
4 changes: 2 additions & 2 deletions tests/Gedmo/Mapping/MappingEventAdapterTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -53,10 +53,10 @@ public function testAdapterBehavior(): void
->disableOriginalConstructor()
->getMock();
$eventArgsMock->expects(static::once())
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe we could even replace these mocks to use a class that is no deprecated, like Doctrine\ORM\Event\PrePersistEventArgs or Doctrine\ORM\Event\PreUpdateEventArgs.

->method('getEntityManager');
->method('getObjectManager');

$eventArgsMock->expects(static::once())
->method('getEntity')
->method('getObject')
->willReturn(new \stdClass());

$eventAdapter = new EventAdapterORM();
Expand Down