- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个带有 Web 项目的解决方案,我决定向该解决方案添加一个单元测试项目。在运行测试时,其中一个测试失败并出现此错误:
Result Message:
Test method DetailsRoleController threw exception:
System.InvalidOperationException: No connection string named 'EquipmentEntities' could be found in the application config file.
这是我的测试脚本:
[TestClass]
public class RoleControllerTest
{
RoleController RC = new RoleController();
[TestMethod]
public void IndexRoleController()
{
}
[TestMethod]
public void DetailsRoleController()
{
var result = RC.Delete(1);
Assert.IsNotNull(result);
}
}
和 Controller 方法:
public ActionResult Details(int? id)
{
if (id == null)
{
return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
}
Role role = db.Roles.Find(id);
if (role == null)
{
return HttpNotFound();
}
return View(role);
}
为什么这个测试失败了?
这个测试用例不是使用主项目的connectrionstrings/context 运行的吗?
好的,我编辑了我的应用程序配置,现在看起来是这样的:
<configuration>
<appSettings>
</appSettings>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
<providers>
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>
</entityFramework>
<connectionStrings>
<add name="EquipmentEntities" connectionString="metadata=res://*/Models.MagazynModel.csdl|res://*/Models.MagazynModel.ssdl|res://*/Models.MagazynModel.msl;provider=System.Data.SqlClient;provider connection string="data source=XYZ\sqlexpress;initial catalog=Equipment;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework"" providerName="System.Data.EntityClient" />
</connectionStrings>
</configuration>
但现在我有另一个错误:
Result Message: Unable to create instance of class magazynTest.Controllers.RoleControllerTest. Error: System.TypeInitializationException:
The type initializer for 'System.Data.Entity.Internal.AppConfig' threw an exception. ---> System.Configuration.ConfigurationErrorsException:
Configuration system failed to initialize ---> System.Configuration.ConfigurationErrorsException: Unrecognized configuration section entityFramework.
最佳答案
默认情况下它不会从您的 Web 应用程序中获取它。
它将在当前运行的项目中寻找它。
您必须将其添加到包含您的连接设置的单元测试项目中的 app.config 文件中。
另一种方法是将它注入(inject)到您的 Controller 中,这样在您的测试中您可以传入一个模拟对象,这将完全避免处理实际的数据库实例。
如果您重新设计了使用存储库模式的方法,但没有看到您的类,如下所示:
public class RoleController : Controller
{
private IRoleRepository roleRepository;
// This constructor would not be needed if you were to use IOC container
public RoleController ()
{
this.roleRepository = new RoleRepository(new RoleContext());
}
public RoleController(IRoleRepository studentRepository)
{
this.roleRepository = roleRepository;
}
....
然后您可以像下面这样模拟存储库:
[TestClass]
public class RoleControllerTest
{
private Mock<IRoleRepository> _roleRepository;
[SetUp]
public void SetUp()
{
_roleRepository = new Mock<IRoleRepository>();
}
[TestMethod]
public void IndexRoleController()
{
}
[TestMethod]
public void DetailsRoleController()
{
RoleController RC = new RoleController(_roleRepository.Object);
var result = RC.Delete(1);
Assert.IsNotNull(result);
}
}
更多信息请看这里:
http://kakimotonline.com/2011/02/13/tdd-in-asp-net-mvc-applications-with-moq-framework/
关于c# - 在测试项目应用程序配置文件中找不到 connectionString,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21778022/
例如,我有一个父类Author: class Author { String name static hasMany = [ fiction: Book,
代码如下: dojo.query(subNav.navClass).forEach(function(node, index, arr){ if(dojo.style(node, 'd
我有一个带有 Id 和姓名的学生表和一个带有 Id 和 friend Id 的 Friends 表。我想加入这两个表并找到学生的 friend 。 例如,Ashley 的 friend 是 Saman
我通过互联网浏览,但仍未找到问题的答案。应该很容易: class Parent { String name Child child } 当我有一个 child 对象时,如何获得它的 paren
我正在尝试创建一个以 Firebase 作为我的后端的社交应用。现在我正面临如何(在哪里?)找到 friend 功能的问题。 我有每个用户的邮件地址。 我可以访问用户的电话也预订。 在传统的后端中,我
我主要想澄清以下几点: 1。有人告诉我,在 iOS 5 及以下版本中,如果您使用 Game Center 设置多人游戏,则“查找 Facebook 好友”(如与好友争夺战)的功能不是内置的,因此您需要
关于redis docker镜像ENTRYPOINT脚本 docker-entrypoint.sh : #!/bin/sh set -e # first arg is `-f` or `--some-
我是一名优秀的程序员,十分优秀!