单元测试是在开发阶段由开发人员进行设计编写的测试,在不同的组织中单元测试与被测试代码实现先后顺序不同,有的组织采用先实现被测试代码,在编写测试代码,执行测试,有些组织采用先编写测试代码,执行测试,实现发生错误的被测试代码,再执行测试。 根据的区别就是组织内部是否在实践TDD开发方法。
在编写单元测试时,有几个方面需要考虑:
1、在测试一个方法时,如何构造被测试方法参数,如果参数类型比较简单那么比较容易构造,如果参数类型是复杂类型结构,并且存在多层结构,那么就需要多考虑考虑。
2、在被测试方法中,有外部服务的调用或者外部模块调用,调用结果影响测试结果,那么如何考虑进行隔离。 因为外部服务或者外部模块被调用方法的不同,针对每种调用方法都要相应的隔离技术,例如:
外部模块调用类在全局变量中被定义围静态变量
外部模块被调用类是通过参数对象传递给方法的
外部对象是一个全局静态对象,在被测试方法内直接调用
外部对象是在被测试方法中,new 出来的新实例,并在方法体内调用
外部模块是被隐式调用的,如被测试方法访问一个网络服务端口获取信息
等等
3、结果验证,单元测试要验证那些信息,按照方法结果体现形式的不同,有如下对象要验证:
直接返回值验证
间接对象验证 (如void 方法,它实现了对一个全局对象或内部私有对象实例的属性修改,那么要抓出对象实例并获得属性值验证结果)
日志文件输出
控制台信息输出
网络数据
如上要考虑的这些要考虑的方面,基本上都可以通过mock 进行处理。 mock 提供的是一种隔离技术,它提供如下几种隔离办法:
1、 完全隔离,mock整个被调用类方法
2、 部分隔离,mock部分被调用类方法
3、 服务桩隔离, 模拟被调用的服务。接受处理请求。
在基于java开发语言的项目上,可以使用PowerMock 作为Mock框架。