Skip to content

Commit

Permalink
added unit tests for MakeCustomFunctionCall
Browse files Browse the repository at this point in the history
  • Loading branch information
bjelbo committed Dec 16, 2024
1 parent 8106120 commit 81730e2
Show file tree
Hide file tree
Showing 2 changed files with 72 additions and 17 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -247,27 +247,27 @@ public static Expression MakeFunctionCall(MemberInfo member, ODataQuerySettings
return CreateFunctionCallWithNullPropagation(functionCall, arguments, querySettings);
}

//Custom methods might contain nullable parameters and, therefore, also should be able to take arguments of type Nullable<T>
public static Expression MakeCustomFunctionCall(MethodInfo method, params Expression[] arguments)
//Custom methods might contain nullable parameters and, therefore, also should be able to take arguments of type Nullable<T>
public static Expression MakeCustomFunctionCall(MethodInfo method, params Expression[] arguments)
{
Expression functionCall;
if (method.IsStatic)
{
Expression functionCall;
if (method.IsStatic)
{
functionCall = Expression.Call(null, method, arguments);
}
else
{
functionCall = Expression.Call(arguments.First(), method, arguments.Skip(1));
}

return functionCall;
functionCall = Expression.Call(null, method, arguments);
}
else
{
functionCall = Expression.Call(arguments.First(), method, arguments.Skip(1));
}

public static Expression CreateFunctionCallWithNullPropagation(Expression functionCall, Expression[] arguments, ODataQuerySettings querySettings)
return functionCall;
}

public static Expression CreateFunctionCallWithNullPropagation(Expression functionCall, Expression[] arguments, ODataQuerySettings querySettings)
{
if (querySettings.HandleNullPropagation == HandleNullPropagationOption.True)
{
if (querySettings.HandleNullPropagation == HandleNullPropagationOption.True)
{
Expression test = CheckIfArgumentsAreNull(arguments);
Expression test = CheckIfArgumentsAreNull(arguments);

if (test == FalseConstant)
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
//------------------------------------------------------------------------------

using System;
using System.Linq;
using System.Collections.Generic;
using System.Linq.Expressions;
using System.Reflection;
Expand All @@ -16,11 +17,15 @@
using Microsoft.AspNetCore.OData.Query.Expressions;
using Microsoft.AspNetCore.OData.Query.Wrapper;
using Microsoft.AspNetCore.OData.Tests.Commons;
using Microsoft.AspNetCore.Routing;
using Microsoft.OData.Edm;
using Microsoft.OData.ModelBuilder;
using Microsoft.OData.UriParser;
using Microsoft.AspNetCore.OData.Tests.Models;
using Microsoft.AspNetCore.OData.TestCommon;
using Moq;
using Xunit;
using Xunit.Sdk;

namespace Microsoft.AspNetCore.OData.Tests.Query.Expressions;

Expand Down Expand Up @@ -493,6 +498,56 @@ private static IEdmModel BuildAndGetEdmModel()
return builder.GetEdmModel();
}
#endregion


[Theory]
[InlineData(0)]
[InlineData(null)]
public void MakeCustomFunctionCall_StaticMethod_ShouldCreateCorrectExpression(int? value)
{
// Arrange
MethodInfo methodInfo = typeof(TestCustomFunctionCall).GetMethod(nameof(TestCustomFunctionCall.StaticCustomMethod));
Expression[] arguments = { Expression.Constant(value, typeof(int?)) };

// Act
Expression result = ExpressionBinderHelper.MakeCustomFunctionCall(methodInfo, arguments);

// Assert
Assert.NotNull(result);
Assert.IsAssignableFrom<MethodCallExpression>(result);
var methodCall = (MethodCallExpression)result;
Assert.Equal(methodInfo, methodCall.Method);
Assert.Equal(arguments, methodCall.Arguments);
}

[Theory]
[InlineData(0)]
[InlineData(null)]
public void MakeCustomFunctionCall_InstanceMethod_ShouldCreateCorrectExpression(int? value)
{
// Arrange
MethodInfo methodInfo = typeof(TestCustomFunctionCall).GetMethod(nameof(TestCustomFunctionCall.InstanceCustomMethod));
Expression instance = Expression.Constant(new TestCustomFunctionCall());
Expression[] arguments = { instance, Expression.Constant(value, typeof(int?)) };

// Act
Expression result = ExpressionBinderHelper.MakeCustomFunctionCall(methodInfo, arguments);

// Assert
Assert.NotNull(result);
Assert.IsAssignableFrom<MethodCallExpression>(result);
var methodCall = (MethodCallExpression)result;
Assert.Equal(methodInfo, methodCall.Method);
Assert.Equal(arguments.Skip(1), methodCall.Arguments);
Assert.Equal(instance, methodCall.Object);
}
}


internal class TestCustomFunctionCall
{
public static void StaticCustomMethod(int? x) { }
public void InstanceCustomMethod(int? x) { }
}

public class MyQueryBinder : QueryBinder
Expand Down

0 comments on commit 81730e2

Please sign in to comment.