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

Dependency injection fails to create IMessageHandler when the constructor contains additional parameters #166

Open
1 task
bslatner opened this issue Nov 11, 2024 · 4 comments
Labels
bug Something isn't working m Effort estimation: medium p2 This is a standard priority issue queued

Comments

@bslatner
Copy link

bslatner commented Nov 11, 2024

Describe the bug

Starting with a project created with:

dotnet new serverless.Messaging

I registered an IAmazonDynamoDB client with the IServiceCollection passed to ConfigureServices in Startup.cs. I changed the constructor definition in the provided GreetingMessageHandler to receive a registered service as a parameter and store it in an instance field.

I run the app and publish a message to the queue. The log indicates that Functions.Handler() gets called and that it, in turn, invokes _LambdaMessaging.ProcessLambdaEventWithBatchResponseAsync() without error. However, the HandleAsync method of GreetingMessageHandler never gets called.

Some investigation and additional logging shows that GreetingMessageHandler never even gets constructed. Function.Handler() winds up getting called over and over again because the message never leaves the queue.

Regression Issue

  • Select this option if this issue appears to be a regression.

Expected Behavior

I would expect the framework to properly construct the IMessageHandler instance as long as the DI framework can resolve all the parameters passed to the constructor.

I would also expect that when ProcessLambdaEventWithBatchResponseAsync is invoked -- and possibly even before that -- if the message handler for the type of the message passed to it cannot be constructed, an exception should be thrown or, at the very least, an entry added to the log with information about why.

Current Behavior

Messages sent to the queue never get processed. The registered Lambda function that handles them gets invoked, but the IMessageHandler for that message type is never constructed or invoked.

Reproduction Steps

Create a new project using dotnet new serverless.Messaging

Open Startup.cs and on the line before services.AddAWSMessageBus add some instance to the DI container. In my case, I called:

services.AddAWSService<IAmazonDynamoDB>(); services.AddSingleton<IDataAccess>(x => { var ddb = x.GetRequiredService<IAmazonDynamoDB>(); return new DynamoDbDataAccess(ddb, Environment.GetEnvironmentVariable("TABLE_NAME")); });

Add a parameter for the service you added to the constructor GreetingMessageHandler . In my case, I added IDataAccess dataAccess.

Publish the stack and invoke the message sender function with a valid message.

Possible Solution

No response

Additional Information/Context

No response

AWS.Messaging (or related) package versions

Include="AWS.Messaging.Lambda" Version="0.10.0"

Targeted .NET Platform

.NET 8

Operating System and version

Windows 11

@bslatner bslatner added bug Something isn't working needs-triage This issue or PR still needs to be triaged. labels Nov 11, 2024
@ashishdhingra ashishdhingra self-assigned this Nov 12, 2024
@ashishdhingra ashishdhingra added needs-reproduction This issue needs reproduction. p2 This is a standard priority issue and removed needs-triage This issue or PR still needs to be triaged. labels Nov 12, 2024
@bslatner
Copy link
Author

I've figured it out. The behavior I've described happens when an exception occurs in the constructor of the service. This test case demonstrates the behavior. The issue, at this point, is that the log has no info about the exception.

The attached sample works normally. To duplicate the behavior I'm talking about, uncomment the throw exception in Startup.cs.

MessagingIssue.zip

@ashishdhingra
Copy link
Contributor

I've figured it out. The behavior I've described happens when an exception occurs in the constructor of the service. This test case demonstrates the behavior. The issue, at this point, is that the log has no info about the exception.

The attached sample works normally. To duplicate the behavior I'm talking about, uncomment the throw exception in Startup.cs.

MessagingIssue.zip

@bslatner Good afternoon. Thanks for sharing the scenario and reproduction code. I'm unsure if this is an issue since exception occurs while resolving dependency in GreetingMessageHandler which is added as a Singleton in Startup class. Is your use case is that even for below test message handler request:

{
  "Records": [
    {
      "messageId": "19dd0b57-b21e-4ac1-bd88-01bbb068cb78",
      "receiptHandle": "MessageReceiptHandle",
      "body": "{\"id\":\"d9b4bfc7-9398-44aa-8049-85c07490fb35\",\"source\":\"/AWSLambda/FunctionName\",\"specversion\":\"1.0\",\"type\":\"DotNETMessagingTest.GreetingMessage\",\"time\":\"2024-03-22T21:01:03.5484607+00:00\",\"data\":\"{\\u0022SenderName\\u0022:\\u0022value2\\u0022,\\u0022Greeting\\u0022:\\u0022value1\\u0022}\"}",
      "attributes": {
        "ApproximateReceiveCount": "1",
        "SentTimestamp": "1523232000000",
        "SenderId": "123456789012",
        "ApproximateFirstReceiveTimestamp": "1523232000001"
      },
      "messageAttributes": {},
      "md5OfBody": "7b270e59b47ff90a553787216d55d91d",
      "eventSource": "aws:sqs",
      "eventSourceARN": "arn:{partition}:sqs:{region}:123456789012:MyQueue",
      "awsRegion": "{region}"
    }
  ]
}

the function still executes successfully and reports the below output:

{
  "batchItemFailures": [
    {
      "itemIdentifier": "19dd0b57-b21e-4ac1-bd88-01bbb068cb78"
    }
  ]
}

And that it should actually throw error since the dependency is not able to be resolved due to exception while resolving it from IServiceCollection. Please confirm.

Thanks,
Ashish

@ashishdhingra ashishdhingra added response-requested Waiting on additional info and feedback. Will move to "closing-soon" in 7 days. and removed needs-reproduction This issue needs reproduction. labels Nov 13, 2024
@bslatner
Copy link
Author

I can confirm what you're seeing.

The problem as I see it, at this point, is that there is no way to diagnose this problem. At least not easily. The exception is completely lost. I'm not even sure how I would go about guarding against it, because at the point of construction there is no way to acquire a context to which you can log.

@ashishdhingra
Copy link
Contributor

I can confirm what you're seeing.

The problem as I see it, at this point, is that there is no way to diagnose this problem. At least not easily. The exception is completely lost. I'm not even sure how I would go about guarding against it, because at the point of construction there is no way to acquire a context to which you can log.

@bslatner Thanks. I will review this with the team.

@ashishdhingra ashishdhingra added needs-review queued m Effort estimation: medium and removed response-requested Waiting on additional info and feedback. Will move to "closing-soon" in 7 days. needs-review labels Nov 14, 2024
@ashishdhingra ashishdhingra removed their assignment Nov 18, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working m Effort estimation: medium p2 This is a standard priority issue queued
Projects
None yet
Development

No branches or pull requests

2 participants