以下是错误:“无法为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。我做错了什么?
答案 0 :(得分:0)
我发现了我的问题。这是删除错误的原因。
1.我添加了一个示例模拟函数来查看SqlDataReader的Shim类。一旦我找到它,我意识到我已经在Fakes文件中写了足够详细的名称。
2.用下面的代码行替换最终的添加修复了问题。
<Add FullName="System.Data.SqlClient.SqlDataReader!"/>