写在开头:Coding ain't done until all the tests run. No unit test no BB.

-------------------------------------------------------------

本文主要介绍如何在Visual Studio(2012+)下面做单元测试。主要以下内容:

  1. 单元测试介绍
  2. 单元测试的基本特点
  3. 使用VS Stub进行单元测试

单元测试介绍

测试类型很多,单元测试是开发人员使用程序自动测试自己的代码,用一张图说明:

上面的method代表的是一个独立的逻辑,并不是说所有的方法都需要测试,比如私有方法,他应该属于其他的独立逻辑,可以通过其他的方法就行测试

单元测试是代码质量的强有力的保证,是重构代码的信心保障,好的单元测试个人认为应该有以下的特点:

  1. 运行速度要快,如果你的测试运行需要一整天,以后肯定不愿意写case,也不愿意再运行和维护
  2. 测试case应该互相不依赖,不要出现运行A case 先得运行B case的情况
  3. 测试case不应该依赖外部资源,比如service,DB,应该随时都可以运行(比如断网)
  4. 单元测试应该和生产代码一样重要,要随着代码的维护而维护

在VS中使用Stub特性进行单元测试:

1. 先写一段用于测试的代码

一个用于发送email的接口

   /// <summary>
    /// interface of email handler
    /// </summary>
    public interface IEmail
    {
        bool SendEmail(string reveiver, string emailBody, string subject);
    }

Email发送的实现,调用Email service发送邮件

    /// <summary>
    /// real email handler
    /// </summary>
    class EmailImp : IEmail
    {
        public bool SendEmail(string reveiver, string emailBody, string subject)
        {
            //call email remote service here to send email
            return true;
        }
    }

业务通知类,调用EmailImp发送邮件,发送成功,返回1,失败返回0,当然真正的业务肯定要做其他事情。

 public class Notifier
    {
        public IEmail EmailHandler { get; set; }

        public Notifier()
        {
            this.EmailHandler = new EmailImp();
        }

        public int Notify()
        {
            var sendResult = this.EmailHandler.SendEmail("ut@cnblogs.com", "email body", "emailSubject");
            if (sendResult)
            {
                ;
            }
            else
            {
                ;
            }
        }
    }

2. 现在要测试Notify方法,简单的步骤,生成测试solution和基本测试代码:

3. 上面的Notify至少应该对应两个Case:

  1. 当Email Service返回true
  2. 当Emial Service返回false

上面说到,单元测试不应该依赖于外部Service,DB.等。但是程序一般肯定依赖这些。如果这些外部Service down了。DBdown了。程序怎么测试。在测试的时候如何控制Email Service 按照我们的需要来返回True、False。这就是Stub要解决的问题。Stub是存根打桩的意思,打桩是测试里面很重要的一个概念。

4. VS可以通过增加Fake程序集来完成对程序的Stub:

5. 增加fake程序集之后就可以看到:

6. 接下来sub的使用,直接通过代码来展示

上面的例子很清楚,两个case完全不依赖于外部email service。随心所欲的指定email service 的返回值,从而很轻松的验证了我们自己的逻辑。

Stub主要思想就是在运行时针对接口动态注入,动态的用我们指定的Stub类来替换真正的执行类来完成我们指定的功能。

想通过Stub进行测试,被Fake的对象必须基于接口编程。

当然基于接口编程,上面的Stub程序员也可以自己实现,何必呢,VS已经帮我们实现了。

那问题来了。如果代码没有基于接口进行编程,怎么办?是不是没有办法像Stub这么进行替换模拟呢。下一篇文章再介绍另外一个功能:Shim.

最新文章

  1. SQL如何增删修改字段
  2. Scala: 包对象
  3. reorderList使用
  4. StackExchange Redis如何实现BRPOP/BLPOP
  5. java collections读书笔记(11) Lists
  6. 常用邮件 smtp pop
  7. CSS基础知识—【结构、层叠、视觉格式化】
  8. javascript之css常用属性
  9. 支持Python 2.7的pylot
  10. (原)torch和caffe中的BatchNorm层
  11. 【机房系统知识小结点系列】之遍历窗体中的控件,判断Text是否为空?
  12. ubuntu-14.04 系统安装mysql-5.6.21
  13. Python学习笔记_Chapter 6定制数据对象
  14. 基于Spring的Appium配置应用
  15. [Python Study Notes]正则表达式
  16. puppeteer(四)常见问题——部分元素无法操作,代码没任何问题。
  17. ADO读写DateTime方式
  18. 51Nod 2020 排序相减
  19. Android 创建SQLite数据库(一)
  20. BZOJ4883 棋盘上的守卫(环套树+最小生成树)

热门文章

  1. Java学习笔记——java介绍
  2. zoj 3721 Final Exam Arrangement【贪心】
  3. [Errno 14] PYCURL ERROR 7 - &quot;couldn&#39;t connect to host&quot;
  4. Tensorflow官方文档中文版——第一章
  5. mysql设置指定ip远程访问连接的方法
  6. SAP 改表方法
  7. activiti基础--2----------------------(流程定义)
  8. Python赋值魔法技巧
  9. QMessageBox简单使用
  10. git入门篇-----本地操作