C# 单元测试EntityFramework中的DbFunctions中的函数
来源:互联网 发布:linux复制命令 编辑:程序博客网 时间:2024/05/02 02:58
C# 单元测试中mock EntityFramework中的DbFunctions中的函数
1. 写一个挡板类来提供C#代码的实现
2. 在运行时,如果是LINQ to ENTITY,EF会忽略c#的实现而选择[DbFunction()]的定义,对于本例,SQL PROFILER抓到的sql如下:
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'
3 0
- C# 单元测试EntityFramework中的DbFunctions中的函数
- C# 解耦EntityFramework进行单元测试
- C#中的单元测试
- C#中单元测试中的断言(Assert)
- C#中的函数指针
- C#中的构造函数
- C#中的时间函数
- C#中的随机函数
- C#中的函数重载
- C#中的构造函数
- c#中的构造函数
- C#中的构造函数
- C#中的函数指针
- C#中的函数重载
- C#中的函数指针
- C#中的函数指针
- C#中的构造函数
- C# 中的eval ()函数
- CSS:两栏布局,三栏布局
- Iterator ------迭代器
- android AP热点(wifi热点)开发
- UIDocumentInteractionController 文档交互控制器 pdf 游览
- 使用夜神模拟器调试HBuilder Android项目
- C# 单元测试EntityFramework中的DbFunctions中的函数
- VR系列——Oculus Publishing文档:七、常见问题
- C语言中的操作符优先级
- 剑指:反转链表
- 给校园招聘中应聘嵌入式程序员的几点建议
- socket通信 简单的客户端和服务器的通信 服务器的代码
- 前端模块化方案的比较(webpack/require.js/seajs/browserify
- Mybatis-Spring 的高级配置 (SqlSessionFactoryBean)
- Leetcode 238 - Product of Array Except Self(递推)