Java基础学习总结(89)——为什么单元测试应该我们开发人员来写

时间:2021-08-13 02:00:21

软件测试是为了保证项目质量,单元测试可以快速执行测试回归测试,做好单元测试可以大大提升测试效率,项目开发真正达到敏捷效果。

单元测试做什么?

1. 核心类方法

2. 异常处理

3. 边界值测试

4. 算法效率测试

5. 业务逻辑测试

要做到以上的各种测试,且写的用例要达到像黑盒测试用例那么细致周全。这个人必须是这个技术领域内的专家,他必须看懂所测试代码,必须对所测试领域技术规范非常熟悉。如果让专人去写,这个人什么时候能成为技术领域内行家呢?即使能花了很多时间去学习了一个领域,手机模块领域众多,他能学几个?学习成本实在太高。非领域专家,写了一些普通的用例,很基本的用例,并不能达到保证质量的效果。使用测试框架写用例并不难,难得是写的用例能像黑盒测试用例一样真的可以达到保证质量的效果。

综上:相应模块的开发是他自己领域内专家,他熟悉他自己的代码,只有他自己适合写自己代码的单元测试。

那问题来了,要如何做单元测试呢?

参考Google的开发架构,Google有测试开发工程师,但是其测试开发工程师,都是原来开发年限较长的开发转岗位,他们对自己曾经的开发领域是非常熟悉的。所以他们写的单元测试用例是非常细致,考虑非常周全的,同样他们也可以进行对应代码的修改与开发,这有点结对编程的意思了。Google 的开发一直都有写单元测试的传统与习惯,中国的开发极少有这样的思想。

所以真正全面做单元测试,必须调整开发结构,说服开发,自顶向下执行,养成单元测试习惯,逐步提高测试效果,保证项目质量。