-
Notifications
You must be signed in to change notification settings - Fork 168
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
SessionDestroyListeners are not called when an exception is thrown during detach #20293
Comments
Suppose Vaadin catches the exceptions when invoking detach listeners, how then it should handle this exception? Moreover, how should it tell session destroy listeners invoker to ignore this exception? |
I agree that in general, we should just let the exception bubble up and not pretend that everything is fine. But I would rather apply that to the detach hooks, as they do not know whether they are invoked because the session is destroyed, or a component is removed from the dom, or maybe even just reattached. Vaadin offers an API to get notified when the session is destroyed. When I use that API, I expect that to work reliably, without having to check every detach hook of my application, including third party tools. It should be the responsibility of the destroy event mechanism to guarantee that listeners are properly called, not the responsibility of every detach hook. Now regarding what to do exactly and how to handle it, I think we should look at what flow/flow-server/src/main/java/com/vaadin/flow/server/VaadinService.java Lines 703 to 732 in db675fe
I think something similar would work also in the loop before where all the UIs are removed. For the sake of this issue, one big try catch around the whole loop would be enough, but in the same spirit I would say that failing to remove one UI should not prevent the next UI to be removed, so probably a try-catch for each UI would be best. |
When session destroy is triggered, wraps each UI close/detach to catch exceptions, making sure session destroy listeners are called. Fixes #20293
When session destroy is triggered, wraps each UI close/detach to catch exceptions, making sure session destroy listeners are called. Fixes #20293
When session destroy is triggered, wraps each UI close/detach to catch exceptions, making sure session destroy listeners are called. Fixes #20293
This ticket/PR has been released with Vaadin 24.6.0.rc1 and is also targeting the upcoming stable 24.6.0 version. |
This ticket/PR has been released with Vaadin 24.4.21. |
This ticket/PR has been released with Vaadin 24.5.9. |
Description of the bug
When a VaadinSession is destroyed, first all UIs are removed and then SessionDestroyListeners are called. When removing the UIs, all the onDetach hooks and DetachListeners will be notified about it.
If one of those hooks or listeners throws an exception, the SessionDestroyListeners will not be called.
Expected behavior
Exceptions in detach hooks and listeners should not prevent SessionDestroyListeners from being called.
Minimal reproducible example
Versions
The text was updated successfully, but these errors were encountered: