转载时请标明出处
作者联系方式:[email protected]
关于用GTest做单元测试
一、什么是单元测试?
要搞懂单元测试,首要要弄清楚什么是单元。单元是软件中承担单一责任的单位,一个函数、一个文件、一个类、一个模块都可以称为一个单元。单元测试便是对软件设计的最小单位进行正确性测试,以检验程序单元是否满足功能、性能、接口、设计规约等要求。
单元测试本质上也是代码,与普通代码的区别在于它是验证代码正确性的代码。软件开发天生就具有复杂性,没人敢打包票说自己写的代码一点问题都没有,或者不经测试就能保证代码正确运行,可能你在这个执行路径下能够执行,殊不知还有其他路径,有一一去验证过吗,因此,要保证程序的正确性就必须要对我们代码进行严格测试。
二、单元测试带来的好处
通常我们在做任何工作会先考虑它的回报,编写代码更是如此。如果单元测试的作用不大,没有人会愿意再写一堆无用的代码,那么单元测试到底能够给我们带来什么优点呢?如下:
- 便于后期重构。单元测试可以为代码的重构提供保障,只要重构代码之后单元测试全部运行通过,那么在很大程度上表示这次重构没有引入新的BUG,当然这是建立在完整、有效的单元测试覆盖率的基础上。
- 优化设计。编写单元测试将使用户从调用者的角度观察、思考,特别是使用TDD驱动开发的开发方式,会让使用者把程序设计成易于调用和可测试,并且解除软件中的耦合。
- 文档记录。单元测试就是一种无价的文档,它是展示函数或类如何使用的最佳文档,这份文档是可编译、可运行的、并且它保持最新,永远与代码同步。
- 具有回归性。自动化的单元测试避免了代码出现回归,编写完成之后,可以随时随地地快速运行测试,而不是将代码部署到设备之后,然后再手动地覆盖各种执行路径,这样的行为效率低下,浪费时间。
三、什么是好的单元测试
既然我们已经知道了单元测试对一个程序员的重要性。那如何写好单元测试也是程序员需掌握好的技巧。这里,我想向大家介绍测试的first原则。first并不是第一的意思,其每个字母都有独特的含义:
F
- 快速:测试必须非常快,这样开发人员可以对每一个小更改运行测试,而不用中断思绪去等待测试运行。
I
- 隔离:不同的测试用例之间是隔离的。一个测试不会依赖另一个测试。不同测试的故障是相互隔离的。
R
- REPEATABLE: - 可重演 测试程序要可在不同环境跑.
S
- SLEF-VALIDATING: - 自我确认 测试结果应是简单的T