Cannote为System.Data.SqlClient.SqlDataReaderSmi生成填充

时间:2016-06-21 22:53:53

标签: c# sql asp.net-mvc unit-testing microsoft-fakes

以下是错误:“无法为System.Data.SqlClient.SqlDataReaderSmi生成填充程序:现在可以看到导出或汇编类型(System.Data.4.0.0.0.Fakes)。

这是我的代码:

<Fakes xmlns="http://schemas.microsoft.com/fakes/2011/" Diagnostic="true">
  <Assembly Name="System.Data" Version="4.0.0.0"/>
  <StubGeneration>
    <Clear/>
  </StubGeneration>
  <ShimGeneration>
    <Clear/>
    <Remove FullName="System.Data.SqlClient"/>
    <!--Added Classes-->
    <Add FullName="System.Data.SqlClient.SqlCommand!"/>
    <Add FullName="System.Data.SqlClient.SqlConnection!"/>
    <Add FullName="System.Data.SqlClient.SqlDataRead"/>
  </ShimGeneration>
</Fakes>

在我的单元测试中,我正在模仿SqlDataReader,如下所示:

var statReqReader = new ShimSqlDataReader()
        {
            Read = () =>
            {
                if (dsrIndexCounter < testCaseCount)
                {
                    dsrIndexCounter++;
                    return true;
                }
                return false;
            },
            ItemGetString = (val) =>
            {
                // [] operator
                return dtStatReq.Rows[dsrIndexCounter - 1][val];
            }
        };

一般来说,我需要在单元测试中使用Fakes。当我尝试删除关于Fakes文件中的SqlDataReader的以下行

<Add FullName="System.Data.SqlClient.SqlDataRead"/>

我收到以下错误:

“找不到类型或命名空间名称'ShimSqlDataReader'(您是否缺少using指令或程序集引用?)

我模拟了SqlDataReader,需要使用Fakes。我做错了什么?

1 个答案:

答案 0 :(得分:0)

我发现了我的问题。这是删除错误的原因。

1.我添加了一个示例模拟函数来查看SqlDataReader的Shim类。一旦我找到它,我意识到我已经在Fakes文件中写了足够详细的名称。

2.用下面的代码行替换最终的添加修复了问题。

<Add FullName="System.Data.SqlClient.SqlDataReader!"/>