-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
Handlers for interfaced notifications are not working as expected #1050
Comments
This issue is stale because it has been open 60 days with no activity. Remove stale label or comment or this will be closed in 14 days. |
bump |
I seem to have the same problem in my project |
I stumpled upon this issue as well but solved it by copying the definition of the handler from https://github.com/jbogard/MediatR.Extensions.Microsoft.DependencyInjection/blob/020d8817ae84e18d61bbf343b00558249c37f899/src/TestApp/ConstrainedPingedHandler.cs#L8 |
It does not solve case C. |
It's been over a year since I last wrestled with notifications. I threw in the towel and pursued an alternative approach described with pseudo code in this thread last year. Drastically simplified notifications and cloud events and made execution order and debugging possible. Unfortunately, it seems the saga continues and I no longer have access to the code base. In case it helps anyone, the suggested alternative at the bottom of this thread worked like a charm... |
This issue is stale because it has been open 60 days with no activity. Remove stale label or comment or this will be closed in 14 days. |
The issue at hand
When using interfaced notifications, and handlers for the interfaces - the handler does not run unless there exists a handler targetting a concrete implementation of the respective interface.
Steps to reproduce:
Bootstrap
A) A simple notification handler that runs
B) An interfaced notification handler that runs
C) Now for the interfaced notification handler that does not run
Cases A and B are as expected, whereas case C is strange - I would expect
InterfacedGreeterHandler
to be run.Further notes
I am not sure any of this is relevant, but I did some investigating.
I have a theory that this issue is caused near
NotificationHandlerWrapper
. Inspecting the service collection, I verify that it correctly containsINotificationHandler<IGreeterInterface>
, but it does not containINotificationHandler<ImplementingGreeterNotification>
.From these lines I see that
IServiceProvider.GetServices<INotificationHandler<ImplementingGreeterNotification>>
does not return anything, which I suspect subsequently fails to resolve a respectiveNotificationHandlerExecutor
.MediatR/src/MediatR/Wrappers/NotificationHandlerWrapper.cs
Lines 24 to 26 in cac76be
It does make sense I suppose, but at face value this looks like odd behavior either way.
I tested a more basic, yet potentially related case; implementing a catch-all
INotificationHandler<INotification>
never runs if there are no otherINotificationHandler
-types registered.The text was updated successfully, but these errors were encountered: