C# 单元测试EntityFramework中的DbFunctions中的函数

C# 单元测试中mock EntityFramework中的DbFunctions中的函数




1. 写一个挡板类来提供C#代码的实现
public static class DbFunctionUnitTestable
    {
        /// <summary>
        /// This is for Unit Test.
        /// When Running against DB ,EF will generate the SQL and ignore the implemenation
        /// in this method . when calling from C#(Unit test) , will exeucte the logic below
        /// </summary>
        /// <param name="dt"></param>
        /// <returns></returns>
        [System.Data.Entity.DbFunction("Edm", "TruncateTime")]
        public static DateTime? TruncateTime(DateTime? dt)
        {
            if (dt.HasValue)
            {
                return dt.Value.Date;
            }


            return null;
        }
    }



2. 在运行时,如果是LINQ to ENTITY,EF会忽略c#的实现而选择[DbFunction()]的定义,对于本例,SQL PROFILER抓到的sql如下:


exec sp_executesql N'SELECT 
   ...
    FROM [dbo].[TKT_Ticket_Usage] AS [Extent1]
    WHERE ([Extent1].[TicketCode] = @p__linq__0) AND (((convert (datetime2, convert(varchar(255), [Extent1].[UsageDate], 102) ,  102)) = (convert (datetime2, convert(varchar(255), @p__linq__1, 102) ,  102))) OR ((convert (datetime2, convert(varchar(255), [Extent1].[UsageDate], 102) ,  102) IS NULL) AND (convert (datetime2, convert(varchar(255), @p__linq__1, 102) ,  102) IS NULL)))',N'@p__linq__0 nvarchar(4000),@p__linq__1 datetime2(7)',@p__linq__0=N'72016122817373389038',@p__linq__1='2017-02-08 00:00:00'



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值