You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I have case, when my service have some state, like MemoryStorage collect some data and I want to test what it collects. This MemoryStorage filled by some listeners, subscribed to Doctrine events.
tryToTest failed, and tryToTestProof show the reason why it fail.
Problem that doctrine.orm.entity_manager is persistent service and it have EventManager, that actually ContainerAwareEventManager, that store container.
When Symfony module reboot kernel, it create new Container, but since doctrine is persistent, EventManager continue keep old container.
As a result Doctrine events work with its own container, while $I->grabService(...) work with another container.
Reproduce:
git clone [email protected]:ewgRa/symfony-standard.git
cd symfony-standard/
git checkout codeception-bug-with-container
composer install
vendor/bin/codecept run
So, is it feature? Or bug? Looks like 100% bug. Possible solution is update EventManager container also on kernel reboot. Or another solution - unpersist doctrine.
At least this must be mentioned somehow in documentation. Also some "I make service persistent, and it not works" issues can be related to this.
The text was updated successfully, but these errors were encountered:
ewgRa
changed the title
After Symfony Kernel reboot Doctrine EntityManager-EventManager keep old Container
After Symfony Kernel reboot - Doctrine EventManager keep old Container
Nov 16, 2016
We've experienced this issue as well, with event doctrine event listeners being persisted within the entity manager, whilst other services access the newly created container services (rather than the some ones in the EntityManager::$uow::$listenersInvoker::$eventManager::$listeners).
What are you trying to achieve?
I have case, when my service have some state, like MemoryStorage collect some data and I want to test what it collects. This MemoryStorage filled by some listeners, subscribed to Doctrine events.
What do you get instead?
My MemoryStorage empty.
Here is reproduce test https://github.com/ewgRa/symfony-standard/blob/codeception-bug-with-container/tests/functional/ContainerCest.php .
tryToTest failed, and tryToTestProof show the reason why it fail.
Problem that doctrine.orm.entity_manager is persistent service and it have EventManager, that actually ContainerAwareEventManager, that store container.
When Symfony module reboot kernel, it create new Container, but since doctrine is persistent, EventManager continue keep old container.
As a result Doctrine events work with its own container, while $I->grabService(...) work with another container.
Reproduce:
git clone [email protected]:ewgRa/symfony-standard.git
cd symfony-standard/
git checkout codeception-bug-with-container
composer install
vendor/bin/codecept run
So, is it feature? Or bug? Looks like 100% bug. Possible solution is update EventManager container also on kernel reboot. Or another solution - unpersist doctrine.
At least this must be mentioned somehow in documentation. Also some "I make service persistent, and it not works" issues can be related to this.
The text was updated successfully, but these errors were encountered: