在ASP.NET MVC中进行TDD开发
TDD介绍
TDD是一种开发方法,全称是Test-Driven development,中文是测试驱动开发。作者是Kent Beck。首先让我介绍一下三种常见的开发方式:
第一种:先Coding,然后Bug Fix。
第二种:先Coding,然后Unit Test,最后Bug Fix。很显然用了单元测试的比第一种开发方式要好不少。
第三种:就是本文要说的TDD,它的方式和第二种恰恰相反。TDD先设计单元测试,然后再Coding,最后修复Bug。看下图:
TDD开发过程可以看成:给制自己制定一个目标,然后努力去完成这个目标。下面是这个比喻对应关系。斜杠前面的是TDD,斜杠后面的是完成目标:
1、写一个测试 / 制定一个目标。
2、编译 / 了解完成目标的标准。
3、运行测试,结果失败 / 目标没有达成。
4、修改代码 / 为了完成目标,不停奋斗。
5、再次运行测试,结果通过 / 目标达成。
这个说明应该比较形象啦。
下面我们看下真正的TDD循环,如下图所示:
TDD循环:
第一步:写测试类,然后拿去编译。
第二步:将编译生成好的dll之类的拿去测试,测试失败。
第三步:失败之后,就去修改测试的代码,直到测试通过。
第四步:测试成功之后,去重构你的代码,增加代码的可读性,但不能改变程序的任何功能。重构代码之后还需要测试,必须测试成功为止。
这四个步骤之后,在从写测试类重新开始其他的功能。
ASP.NET MVC中进行TDD开发
下面用一个在asp.net mvc2 中进行一次简单的TDD开发实战。单元测试我使用NUnit。
新建一个你类库项目命名为Test.Unit。再建一个asp.net mvc2的项目。项目结构如下图:
首先进行第一步,写测试确定要实现什么:我们实现一个数据列表的显示。
在类库项目中添加一个nunit.framework引用,然后再设计一个TodoControllerTest类用于测试控制器。
using NUnit.Framework;
namespaceTest.Unit
{
[TestFixture]
public classTodoControllerTest
{
[Test]
public voidShould_Display_A_List_Of_Todo_Items()
{
}
}
}
这个测试类用于测试Todo控制器,它需要数据实体。所以我们要在asp.net mvc 项目中添加Model。在Model添加下面实体:
public class Todo
{
public static List<Todo> ThingsToBeDone = new List<Todo>
{
new Todo {Title = "Get Milk", Completed = false},
new Todo {Title = "Bring Home Bacon", Completed = false}
};
public bool Completed { get; set; }
public string Title { get; set; }
}
[TestFixture]
public class TodoControllerTest
{
[Test]
public void Should_Display_A_List_Of_Todo_Items()
{
var viewResult = (ViewResult)new TodoController().Index();
Assert.AreEqual(Todo.ThingsToBeDone, viewResult.ViewData.Model);
}
}
测试TodoCpmtroller中的Index方法返回的数据是否与Todo的ThingsToBeDone相同,而此时我们还没有在MVC项目中添加TodoController类和Index方法。
故我们需要在MVC项目中添加TodoController类,代码如下:
public class TodoController : Controller
{
// GET: /Todo/
public ActionResult Index()
{
return View();
}
}
使用Nunit进行测试,发现测试不通过,这对应TDD循环的的第二步。
因为Index中没有返回任何的数据,所有才会测试失败。修改Index方法,代码如下。
public class TodoController : Controller
{
// GET: /Todo/
public ActionResult Index()
{
ViewData.Model = Todo.ThingsToBeDone;
return View();
}
}
这个例子非常简单,也就用不着去重构代码,所以TDD循环的第四步可以省去。然后接着下一轮的循环。
总结:本文首先简单的介绍了一下TDD,随后在asp.net mvc中进行了实战。
参考:Test-Drive ASP.NET MVC