使用MS Test做单元测试

声明:本篇博客翻译自:http://www.c-sharpcorner.com/article/unit-testing-with-ms-tests-in-c-sharp/

写在翻译之前:

依然清晰的记得刚工作的第一个项目中,在完成一个功能模块开发后,师傅让我把代码做一下单元测试。当时一脸“懵懂”。心里的疑惑油然而生,测试不应该是测试人员做的吗?然后就写了一些测试用例把功能简单过了一遍。过了几天后,师傅问我单元测试完成了吗?我很自信的告诉师傅搞定了。师傅让我把单元测试的代码提交到服务器上,他想Review一下!我更加疑惑了,对师傅说,单元测试还要写代码呀?:(

前言:

很多初级开发工程师都会有这样的困惑:谁应该来做单元测试。单元测试应该是由开发者来完成的。

单元测试:

通过一些代码来测试一个方法/函数的行为。

使用MS Test做单元测试

为什么需要单元测试:

  • 通常情况下,一个软件项目会长期运行/维护/更新,这个时间至少也会有5年的时间;

  • 在这期间,维护这个程序非常重要;

  • 任何一个代码的改动都有可能会影响程序的其他功能模块;

  • 因此在更新程序之间,会需要做大量的回归测试(Regression Testing),这将花费测试工程师大量的时间。

想象一下如果代码修改需要非常频繁,那么花费在回归测试上的精力会非常多,同样的,也会有很大的几率捕捉到功能回退(修改缺陷)的问题。

回归测试:

使用MS Test做单元测试

回归测试是确保当增加了新的修改后,老的功能依旧可以正常使用。

单元测试:

使用MS Test做单元测试

  • 单元测试将会最小化回归测试的范围:

  • 每一个方法/函数都会被一系列的测试方法覆盖,这些测试方法将测试真实方法的功能;

  • 测试方法会检查下面的场景/行为:

    • 成功/正常流程

    • 失败

    • 异常/错误处理

  • 一个方法可能需要多个测试方法,这取决于测试方法的复杂度;

  • 在代码交付之前,开发者需要确保所有的测试方法均运行通过

TDD:

使用MS Test做单元测试

 

在写产品代码之前先写单元测试代码,然后使用产品代码来填充/覆盖测试代码。最终使测试代码都运行通过。

编写测试用例:

在C#中有2个测试框架

  • MS Test

  • NUnit

我们使用AAA模式来编写单元测试

使用MS Test做单元测试

  1. 安排所以必须的前置条件和输入;

  2. 在测试代码中操作被测试对象和方法;

  3. 断言期待的结果;

右击解决方案浏览器,选择Unit Test Project并添加:

使用MS Test做单元测试

Employee类:


public class Employee
{
    public string GetName(string firstName, string lastName)
    {
        return string.Concat(firstName, " ", lastName);
    }
}

 单元测试类:


[TestClass]
public class EmpoyeeFunctionalTest
{
    [TestMethod]
    public void GetNameTest()
    {
        // Arrange
        Employee employee = new Employee();
        string firstName = "Jimmy";
        string lastName = "Yang";
        string expacted = "Jimmy Yang";
        string actual = string.Empty;
 
        // Act
        actual = employee.GetName(firstName, lastName);
 
        // Assert
        Assert.AreEqual(expacted, actual);
    }
}

 希望上述内容能够帮助你对单元测试有一个概念性的认识。

原文:http://www.cnblogs.com/yang-fei/p/7858078.html



.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

使用MS Test做单元测试