From 56961f157ea570d2b126bad38d12167bb324fb73 Mon Sep 17 00:00:00 2001 From: Ashish Dhingra <67916761+ashishdhingra@users.noreply.github.com> Date: Wed, 30 Oct 2024 14:33:04 -0700 Subject: [PATCH] Fixed an issue where primitive values in payload for InvokeFunctionCommand were not working. --- .../8795398d-3505-4b1f-8d8f-eadf6d32d4db.json | 11 +++++ aws-extensions-for-dotnet-cli.sln | 9 +++- .../Commands/InvokeFunctionCommand.cs | 16 +++++-- .../Amazon.Lambda.Tools.Test.csproj | 1 + test/Amazon.Lambda.Tools.Test/DeployTest.cs | 45 ++++++++++++++++++- testapps/TestIntegerFunction/Function.cs | 17 +++++++ .../TestIntegerFunction.csproj | 14 ++++++ .../aws-lambda-tools-defaults.json | 5 +++ 8 files changed, 113 insertions(+), 5 deletions(-) create mode 100644 .autover/changes/8795398d-3505-4b1f-8d8f-eadf6d32d4db.json create mode 100644 testapps/TestIntegerFunction/Function.cs create mode 100644 testapps/TestIntegerFunction/TestIntegerFunction.csproj create mode 100644 testapps/TestIntegerFunction/aws-lambda-tools-defaults.json diff --git a/.autover/changes/8795398d-3505-4b1f-8d8f-eadf6d32d4db.json b/.autover/changes/8795398d-3505-4b1f-8d8f-eadf6d32d4db.json new file mode 100644 index 0000000..dce52f7 --- /dev/null +++ b/.autover/changes/8795398d-3505-4b1f-8d8f-eadf6d32d4db.json @@ -0,0 +1,11 @@ +{ + "Projects": [ + { + "Name": "Amazon.Lambda.Tools", + "Type": "Patch", + "ChangelogMessages": [ + "Fixed an issue where primitive values in payload for InvokeFunctionCommand were not working." + ] + } + ] +} \ No newline at end of file diff --git a/aws-extensions-for-dotnet-cli.sln b/aws-extensions-for-dotnet-cli.sln index cb8ef54..58ba0fe 100644 --- a/aws-extensions-for-dotnet-cli.sln +++ b/aws-extensions-for-dotnet-cli.sln @@ -63,7 +63,9 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Amazon.Lambda.Tools.Integ.T EndProject Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "TestHttpFunction", "testapps\TestHttpFunction\TestHttpFunction.csproj", "{AD31D053-97C5-4262-B187-EC42BFD51A9F}" EndProject -Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "TestNativeAotNet8WebApp", "testapps\TestNativeAotNet8WebApp\TestNativeAotNet8WebApp.csproj", "{69FFA03C-D29F-40E0-9E7F-572D5E10AF77}" +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "TestNativeAotNet8WebApp", "testapps\TestNativeAotNet8WebApp\TestNativeAotNet8WebApp.csproj", "{69FFA03C-D29F-40E0-9E7F-572D5E10AF77}" +EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "TestIntegerFunction", "testapps\TestIntegerFunction\TestIntegerFunction.csproj", "{D7F1DFA4-066B-469C-B04C-DF032CF152C1}" EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution @@ -163,6 +165,10 @@ Global {69FFA03C-D29F-40E0-9E7F-572D5E10AF77}.Debug|Any CPU.Build.0 = Debug|Any CPU {69FFA03C-D29F-40E0-9E7F-572D5E10AF77}.Release|Any CPU.ActiveCfg = Release|Any CPU {69FFA03C-D29F-40E0-9E7F-572D5E10AF77}.Release|Any CPU.Build.0 = Release|Any CPU + {D7F1DFA4-066B-469C-B04C-DF032CF152C1}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {D7F1DFA4-066B-469C-B04C-DF032CF152C1}.Debug|Any CPU.Build.0 = Debug|Any CPU + {D7F1DFA4-066B-469C-B04C-DF032CF152C1}.Release|Any CPU.ActiveCfg = Release|Any CPU + {D7F1DFA4-066B-469C-B04C-DF032CF152C1}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE @@ -193,6 +199,7 @@ Global {7B2AE176-8AB5-4050-8E22-A2A80E88BB92} = {BB0A8314-3127-4159-8B6A-64F97FEF9474} {AD31D053-97C5-4262-B187-EC42BFD51A9F} = {BB3CF729-8213-4DDD-85AE-A5E7754F3944} {69FFA03C-D29F-40E0-9E7F-572D5E10AF77} = {BB3CF729-8213-4DDD-85AE-A5E7754F3944} + {D7F1DFA4-066B-469C-B04C-DF032CF152C1} = {BB3CF729-8213-4DDD-85AE-A5E7754F3944} EndGlobalSection GlobalSection(ExtensibilityGlobals) = postSolution SolutionGuid = {DBFC70D6-49A2-40A1-AB08-5D9504AB7112} diff --git a/src/Amazon.Lambda.Tools/Commands/InvokeFunctionCommand.cs b/src/Amazon.Lambda.Tools/Commands/InvokeFunctionCommand.cs index c7a9e94..a895199 100644 --- a/src/Amazon.Lambda.Tools/Commands/InvokeFunctionCommand.cs +++ b/src/Amazon.Lambda.Tools/Commands/InvokeFunctionCommand.cs @@ -62,7 +62,6 @@ protected override void ParseCommandArguments(CommandOptions values) protected override async Task PerformActionAsync() { - var invokeRequest = new InvokeRequest { FunctionName = this.GetStringValueOrDefault(this.FunctionName, LambdaDefinedCommandOptions.ARGUMENT_FUNCTION_NAME, true), @@ -81,9 +80,20 @@ protected override async Task PerformActionAsync() invokeRequest.Payload = this.Payload.Trim(); } - if(!invokeRequest.Payload.StartsWith("{")) + // We should still check for empty payload in case it is read from a file. + if (!string.IsNullOrEmpty(invokeRequest.Payload)) { - invokeRequest.Payload = "\"" + invokeRequest.Payload + "\""; + if (invokeRequest.Payload[0] != '\"' && invokeRequest.Payload[0] != '{' && invokeRequest.Payload[0] != '[') + { + double d; + long l; + bool b; + if (!double.TryParse(invokeRequest.Payload, out d) && !long.TryParse(invokeRequest.Payload, out l) && + !bool.TryParse(invokeRequest.Payload, out b)) + { + invokeRequest.Payload = "\"" + invokeRequest.Payload + "\""; + } + } } } diff --git a/test/Amazon.Lambda.Tools.Test/Amazon.Lambda.Tools.Test.csproj b/test/Amazon.Lambda.Tools.Test/Amazon.Lambda.Tools.Test.csproj index 80b0d15..949d805 100644 --- a/test/Amazon.Lambda.Tools.Test/Amazon.Lambda.Tools.Test.csproj +++ b/test/Amazon.Lambda.Tools.Test/Amazon.Lambda.Tools.Test.csproj @@ -74,6 +74,7 @@ + diff --git a/test/Amazon.Lambda.Tools.Test/DeployTest.cs b/test/Amazon.Lambda.Tools.Test/DeployTest.cs index 762528e..a37b0f7 100644 --- a/test/Amazon.Lambda.Tools.Test/DeployTest.cs +++ b/test/Amazon.Lambda.Tools.Test/DeployTest.cs @@ -310,7 +310,50 @@ public async Task RunDeployCommand() } } } - + + [Fact] + public async Task RunDeployAndInvokeWithIntegerPayloadCommand() + { + var assembly = this.GetType().GetTypeInfo().Assembly; + var toolLogger = new TestToolLogger(_testOutputHelper); + + var fullPath = Path.GetFullPath(Path.GetDirectoryName(assembly.Location) + "../../../../../../testapps/TestIntegerFunction"); + var command = new DeployFunctionCommand(toolLogger, fullPath, new string[0]); + command.FunctionName = "test-function-intpayload-" + DateTime.Now.Ticks; + command.Handler = "TestIntegerFunction::TestIntegerFunction.Function::FunctionHandler"; + command.Timeout = 10; + command.MemorySize = 512; + command.Role = await TestHelper.GetTestRoleArnAsync(); + command.Configuration = "Release"; + command.Runtime = "dotnet6"; + command.DisableInteractive = true; + + var created = await command.ExecuteAsync(); + try + { + Assert.True(created); + + await LambdaUtilities.WaitTillFunctionAvailableAsync(new TestToolLogger(_testOutputHelper), command.LambdaClient, command.FunctionName); + + toolLogger.ClearBuffer(); + + var invokeCommand = new InvokeFunctionCommand(toolLogger, fullPath, new string[0]); + invokeCommand.FunctionName = command.FunctionName; + invokeCommand.Payload = "42"; + + await invokeCommand.ExecuteAsync(); + + Assert.Contains("\"Hello 42\"", toolLogger.Buffer); + } + finally + { + if (created) + { + await command.LambdaClient.DeleteFunctionAsync(command.FunctionName); + } + } + } + [Fact] public async Task TestPowerShellLambdaParallelTestCommand() { diff --git a/testapps/TestIntegerFunction/Function.cs b/testapps/TestIntegerFunction/Function.cs new file mode 100644 index 0000000..918f71f --- /dev/null +++ b/testapps/TestIntegerFunction/Function.cs @@ -0,0 +1,17 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Threading.Tasks; + +namespace TestIntegerFunction +{ + + public class Function + { + [Amazon.Lambda.Core.LambdaSerializer(typeof(Amazon.Lambda.Serialization.Json.JsonSerializer))] + public string FunctionHandler(int input) + { + return "Hello " + input; + } + } +} diff --git a/testapps/TestIntegerFunction/TestIntegerFunction.csproj b/testapps/TestIntegerFunction/TestIntegerFunction.csproj new file mode 100644 index 0000000..d42b3bd --- /dev/null +++ b/testapps/TestIntegerFunction/TestIntegerFunction.csproj @@ -0,0 +1,14 @@ + + + net6.0 + TestIntegerFunction + Library + TestIntegerFunction + false + false + false + + + + + \ No newline at end of file diff --git a/testapps/TestIntegerFunction/aws-lambda-tools-defaults.json b/testapps/TestIntegerFunction/aws-lambda-tools-defaults.json new file mode 100644 index 0000000..7c429a6 --- /dev/null +++ b/testapps/TestIntegerFunction/aws-lambda-tools-defaults.json @@ -0,0 +1,5 @@ +{ + "region": "us-east-2", + "disable-version-check": true, + "function-memory-size": 128 +}