单元测试,Linq to SQL和解决数据上下文

时间:2009-09-08 08:05:46

标签: c# unit-testing linq-to-sql mocking datacontext

我一直在研究以下内容,看起来使用编译查询可以获得很多好处...... http://blogs.msdn.com/ricom/archive/2008/01/14/performance-quiz-13-linq-to-sql-compiled-query-cost-solution.aspx

我的问题是我想对我的查询进行单元测试,但是编译后的查询需要一个派生自DataContext的类的具体实例(特别难以模拟出来)...因此我想出了以下代码我想知道是否有人知道我是否仍然可以获得编译查询的性能优势......

private static readonly Func<IDatabase, IActionParameters, ISportProgramMapper, IQueryable<ISportProgram>> _GetQueryUnCompiled =
    (db, parameters, mapper) => from x in db.SportProgramDataSource.ThatHaveActiveSports()
                                where x.SportProgramId == parameters.Id
                                select mapper.FromDataToEntity(x);

private static readonly Func<Database, IActionParameters, ISportProgramMapper, IQueryable<ISportProgram>> _GetQuery = CompiledQuery.Compile<Database, int, ISportProgramMapper, IQueryable<ISportProgram>>((db, parameters, mapper) => _GetQueryUnCompiled(db, parameters, mapper));

public IActionResult<ISportProgram> Get(IActionParameters parameters)
{
    Check.Argument("parameters").ThatValue(parameters).IsNotNull();

    IDatabase db = this.CreateDatabase(); 
    ISportProgramMapper mapper = this.CreateMapper<ISportProgramMapper>();
    Database typedDb = db as Database;

    var result = typedDb != null ? _GetQuery(typedDb, parameters, mapper).FirstOrDefault() : _GetQueryUnCompiled(db, parameters, mapper).FirstOrDefault();

    return this.CreateActionResult(result);
}

注意在单元测试场景中,我的数据库不是类型数据库,这意味着它将调用未编译的版本,在prod场景中它将是Database类型并将运行编译版本。

干杯 安东尼

更新: 好吧,即使我重构代码,以便我当前在DAL中的方法使用返回IQueryable的存储库仍然保留基础问题,使用编译查询的存储库版本将包装包含原始查询的版本,以类似于我现在正在做的方式...使用_GetQuery调用_GetQueryUnCompiled的模式我还能获得性能优势吗?

1 个答案:

答案 0 :(得分:1)

只是一个想法,你能重构只使用分层来使用IEnumerable<>吗?这样,您可以与查询分开测试数据库代码吗?