-
-
Notifications
You must be signed in to change notification settings - Fork 72
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
Heap does not return a new entity after persistState #392
Comments
When you call |
Thanks for answer! public class UserRepository implements UserRepositoryInterface
{
public function get(UserId $id): User
{
/** @var Heap $heap */
$heap = $this->orm->getHeap();
foreach ($heap->getIterator() as $entity) {
if (!$entity instanceof User) {
continue;
}
if ($entity->id->equals($id)) {
return $entity;
}
}
/** @var null|User $entity */
$entity = $this->orm->get(User::class, [
'id' => $id,
]);
return $entity ?? throw new DomainException();
}
} Of course, you can make your own storage for new entities, but you have to keep it clean after run/clean EntityManager. Or put entirely entities in domain events, not their IDs. Honestly, all variations look like architectural overcomplication. Can you explain why it was designed this way please? |
@roxblnfk I think we can review the idea of working with iterators/heaps based on local UoW. Since it's localized it will be much safer to predict collisions. In this particular case, the ID has not been confirmed by the database, so the local index for it does not exist. @KorDum It was not indendend as overcomplication. Instead, the design proposes to work with local, non-intercepting transactions instead of one huge and messy heap + uow + em like in Doctrine. The main focus is on avoiding edge cases when data can not be combined properly, for example, you created a used with the given ID and then refer it from other parts of the application. You now creating references for the object which has NOT been stored, this is OK within a single transaction, but once you span it outside of it - you can create a whole mess of side-effects when user can't be properly committed. One of the options I can suggest - we can build local indexes on a level of UoW/EM itself, which seems much more logical instead of going back to Heap. |
Thanks! |
Converted to #436 |
No duplicates 🥲.
What happened?
Hello!
Everything works excellent in simple scenarios, but there is something that does not work in a complex scenario with DDD, Command Bus, Domain Events and sync subscribers, etc.
Unfortunately, if you call
EntityManagerInterface#persistState()
and get persisted entity from ORM at once (I mean EntityProvider of course), then you will get null and even SQL-query. This doesn't allow separating logic by aggregate entities and persist to database atomically.For example simple code:
I expect the behavior to be similar to that of Doctrine ORM, where the repository returns an entity from the unit of work cache. I also see entity being attach to the storage of Heap, but not in "paths" property. So searching for an entity in the Heap returns a empty result.
As an alternative I found a solution to get the Storage and iterate over all the entities in it.
Version
The text was updated successfully, but these errors were encountered: