【问题标题】:create test harness (unit test)创建测试工具(单元测试)
【发布时间】:2011-06-12 21:57:19
【问题描述】:

我必须在这个类上创建测试。有人可以帮助如何做到这一点。

public class Db    {
private System.Data.SqlClient.SqlConnection myConn;

public Db(string connString)
{
    myConn = new System.Data.SqlClient.SqlConnection(connString);
}

public bool Connected
{
    get { return (myConn.State == ConnectionState.Open); }
}

public void Connect()
{
    myConn.Open();
}

public void Disconnect()
{
    myConn.Close();
}
}

是的,连接字符串可以作为构造函数参数传递。

问候

雅虎

【问题讨论】:

  • 目前该类没有太多行为。如果您不打算添加更多方法,您可以考虑在类 Db 上执行提取接口并创建一个 IDb 接口。将其注入其他类并测试它们。但是,如果您计划向 Db 类添加功能,您可能希望对其进行测试。

标签: unit-testing testing nunit moq


【解决方案1】:

你唯一的依赖(SqlConnection)是不可注入的,所以首先要做的是至少有Poor Man's Dependency Injection构造函数链接,允许SqlConnection作为参数传递。除此之外,我看到这个类做的很少,而是充当连接的包装器。我可能会将连接抽象为 IDbConnection,并在需要时对其进行模拟,例如 Connected 方法的测试类似于:

IDbConnection conn = mockery.CreateMock<IDbConnection>();
Expect.Call(connection.State).Return(ConnectionState.Open);

mockery.ReplayAll();

Assert.IsTrue(db.Connected);

mockery.VerifyAll();

可以用类似的方式模拟连接/断开连接。

【讨论】:

  • 您可能想看看 Moq、Rhino Mocks 或较新的隔离框架之一。录制/重放已失宠。
猜你喜欢
  • 2013-12-29
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-07-06
  • 2011-02-07
  • 1970-01-01
相关资源
最近更新 更多