数据库单元测试问题疑难解答
当您对数据库执行单元测试时,可能会遇到本主题中的问题:
运行单元测试或生成测试数据时权限不足
单元测试和运行单元测试时忽略的 App.Config 更改
运行单元测试时到意外目标的数据库部署
运行数据库单元测试时出现超时
运行单元测试或生成测试数据时权限不足
可以将单元测试配置为自动部署数据库和生成数据。 如果您没有足够的权限将数据生成到目标数据库,则可能会收到一个错误,指出您的权限不足,无法连接到数据库。
提示
若要解决此问题,请手动运行数据生成计划。 如果您没有足够的权限生成数据,则此方法将提供一则更详细的错误消息,以帮助您解决该问题。
单元测试和运行单元测试时忽略的 App.Config 更改
如果您在测试项目中修改了 App.Config 文件,则必须重新生成测试项目才能使所做的更改生效。 这些更改包括您使用**“项目配置”**对话框对 App.Config 进行的更改。 如果不重新生成测试项目,则当您运行单元测试时将不会应用这些更改。
运行单元测试时到意外目标的数据库部署
如果在执行单元测试时部署数据库,则将使用单元测试配置中指定的连接字符串信息来创建数据库。 数据库项目生成属性中指定的连接信息不会用于此任务,因此您可以针对同一个数据库的不同实例来运行不同的单元测试。
运行数据库单元测试时出现超时
如果数据库单元测试由于超时而失败,则可通过更新数据库项目中的 app.config 文件来增加超时时间。 连接字符串中的超时指定单元测试在连接到服务器时需要等待多长时间。 命令超时指定单元测试在执行 Transact-SQL 脚本时需要等待的时间。
提示
若要解决此问题,请在测试项目的 app.config 文件中的相应 Context 元素中为 CommandTimeout 特性指定较大的值。 例如,若要为 PrivilegedContext 元素指定命令超时为 120 秒,请将 app.config 更新为:
<DatabaseUnitTesting>
<DatabaseDeployment DatabaseProjectFileName="test.dbproj" Configuration="Debug" />
<DataGeneration DataGenerationFileName="test.dgen" ClearDatabase="true" />
<ExecutionContext Provider="System.Data.SqlClient" ConnectionString="another connection string" />
<PrivilegedContext Provider="System.Data.SqlClient" ConnectionString="test" CommandTimeout="120" />
</DatabaseUnitTesting>