《Java单元测试实战》——卷首语

简介: 《Java单元测试实战》——卷首语

卷首语


《卜算子·致码农》

作者:常意

 

业务要精通,眼界需开阔。

谈笑风生略几回,方案心头过。

编写守规则,测试知结果。

奋笔疾书数万行,代码无一错。

 

一、 什么是单元测试

 

维基百科是这样描述的:

 

在计算机编程中,单元测试又称为模块测试,是针对程序模块来进行正确性检验的测试工作。程序单元是应用的最小可测试部件。在过程化编程中,一个单元就是单个程序、函数、过程等;对于面向对象编程,最小单元就是方法,包括基类、抽象类、或者派生类中的方法。

 

作者认为单元测试分为狭义单元测试广义单元测试

 

1. 狭义单元测试

 

狭义单元测试是针对一个类的一个公有、私有、保护方法的测试。

 

2. 广义单元测试

 

广义单元测试是针对一个类的一个公有方法的测试。首先,对于类的使用者来说,大多数情况下只能调用公有方法;其次,公有方法可能有私有、保护方法组成,独立存在的私有、保护方法是没有意义的;最后,在测试公有方法时,已经附带着测试私有、保护方法。

 

在日常的单元测试中,大多使用广义单元测试,针对公有方法进行测试。当然,为了覆盖某些代码分支,也可以采用狭义单元测试,直接针对私有、保护方法进行测试。

 

二、 单元测试的意义

 

1. 验证代码逻辑

 

对于一个代码模块,编写单元测试的过程,就是对代码逻辑进行重新Review的过程;而执行单元测试的过程,就是验证代码是否按既定逻辑运行的过程。

 

2. 减少代码缺陷

 

我们的工程都是分层分模块的,每个模块都是独立的逻辑部分。通过单元测试保障工程各个“零件”按“规格”(需求)执行,就能保证整个“机器”(项目)运行正确,最大限度地减少bug。

 

3. 促进代码设计

 

在编写单测的过程中,如果发现单测代码非常难写,一般表明被测试的代码包含了太多的依赖或职责,需要反思代码的合理性,进而促进代码设计的优化。

 

4. 便于多人协作

 

在多人协助的项目中,所依赖的服务接口不一定已经开发完毕,导致服务进行联调工作。此时,单元测试有效地解决了这个问题——只需Mock服务接口数据,便可以完成自己代码的测试。

 

5. 便于缺陷定位

 

由于单元规模较小,复杂性较低,因而发现错误后容易隔离和定位,有利于代码调试工作。

 

6. 放心代码重构

 

如今持续型的项目越来越多,代码不断的在变化和重构,通过单元测试,开发可以放心的修改重构代码,减少改代码时的心理负担,提高重构的成功率。

 

 

7. 增强代码信心

 

写完代码,单元测试通过,虽说单元测试并不能百分之百保证代码完全正确运行,但起码大部分测过的逻辑都是可用的,这会增强我们的信心,也会增加工作成就感。

 

三、单元测试的推广 

很多软件研发人员认为:进行单元测试会花费大量时间来编写测试用例。因此,他们做单元测试的意愿比较低,导致单元测试很难推广开来。 

首先,要解决意识问题。需要让研发人员意识到单元测试的作用,比如:验证代码逻辑、减少代码缺陷、促进代码设计、增强代码信心等。有时候,只有出现了线上问题、产生了资损和客诉,才能真正地意识到单元测试的作用了。

 

再次,要解决认知问题。在单元测试的推广过程中,遇到的最大问题就是——很多人把集成测试当成单元测试。因为有时候,集成测试也具备“解除依赖”、"安全重构"、“增强信心”等功能,所以很容易与单元测试混淆。只有在弄清楚集成测试和单元测试的区别后,才能更好地做好单元测试。

 

第三,要解决方法问题。在本书中,提供了大量的单元测试实践方法,可以从根本上解决这个问题。比如:《Java编程技巧之单元测试用例编写流程》解决了编写方法问题,《Java单元测试技巧之JSON序列化》解决了编写技巧问题,《Java编程技巧之单元测试用例简化方法》解决了简化技巧问题,《Java单元测试典型案例集锦》解决了编写案例问题。

 

最后,要解决态度问题。自上而下地推广单元测试,大多数人会把单元测试当成一个任务和累赘,没有体会到单元测试的真实作用,编写单测只是为了应付上级任务,甚至于为了追求覆盖率而编写无效单元测试。这里,《那些年,我们写过的无效单元测试》介绍了如何识别无效单元测试,并提出了有效单元测试所需要遵循的原则。 

总之,单元测试的推广是一个长期而艰巨的任务。 

 

常意

2023年春

北京


目录
打赏
0
0
0
0
52
分享
相关文章
|
18天前
|
《从头开始学java,一天一个知识点》之:控制流程:if-else条件语句实战
**你是否也经历过这些崩溃瞬间?** - 看了三天教程,连`i++`和`++i`的区别都说不清 - 面试时被追问"`a==b`和`equals()`的区别",大脑突然空白 - 写出的代码总是莫名报NPE,却不知道问题出在哪个运算符 这个系列为你打造Java「速效救心丸」!每天1分钟,地铁通勤、午休间隙即可完成学习。直击高频考点和实际开发中的「坑位」,拒绝冗长概念,每篇都有可运行的代码示例。明日预告:《for与while循环的使用场景》。 ---
54 19
JVM实战—1.Java代码的运行原理
本文介绍了Java代码的运行机制、JVM类加载机制、JVM内存区域及其作用、垃圾回收机制,并汇总了一些常见问题。
JVM实战—1.Java代码的运行原理
Java机器学习实战:基于DJL框架的手写数字识别全解析
在人工智能蓬勃发展的今天,Python凭借丰富的生态库(如TensorFlow、PyTorch)成为AI开发的首选语言。但Java作为企业级应用的基石,其在生产环境部署、性能优化和工程化方面的优势不容忽视。DJL(Deep Java Library)的出现完美填补了Java在深度学习领域的空白,它提供了一套统一的API,允许开发者无缝对接主流深度学习框架,将AI模型高效部署到Java生态中。本文将通过手写数字识别的完整流程,深入解析DJL框架的核心机制与应用实践。
26 2
课时11:综合实战:简单Java类
本次分享的主题是综合实战:简单 Java 类。主要分为两个部分: 1.简单 Java 类的含义 2.简单 Java 类的开发
课时37:综合实战:数据表与简单Java类映射转换
今天我分享的是数据表与简单 Java 类映射转换,主要分为以下四部分。 1. 映射关系基础 2. 映射步骤方法 3. 项目对象配置 4. 数据获取与调试
|
2月前
|
Java中的分布式缓存与Memcached集成实战
通过在Java项目中集成Memcached,可以显著提升系统的性能和响应速度。合理的缓存策略、分布式架构设计和异常处理机制是实现高效缓存的关键。希望本文提供的实战示例和优化建议能够帮助开发者更好地应用Memcached,实现高性能的分布式缓存解决方案。
52 9
Java基础却常被忽略:全面讲解this的实战技巧!
本次分享来自于一道Java基础的面试试题,对this的各种妙用进行了深度讲解,并分析了一些关于this的常见面试陷阱,主要包括以下几方面内容: 1.什么是this 2.this的场景化使用案例 3.关于this的误区 4.总结与练习
Java基础却常被忽略:全面讲解this的实战技巧!
小米,29岁程序员,分享Java中`this`关键字的用法。`this`代表当前对象引用,用于区分成员变量与局部变量、构造方法间调用、支持链式调用及作为参数传递。文章还探讨了`this`在静态方法和匿名内部类中的使用误区,并提供了练习题。
61 1
Java 多线程并发控制:深入理解与实战应用
《Java多线程并发控制:深入理解与实战应用》一书详细解析了Java多线程编程的核心概念、并发控制技术及其实战技巧,适合Java开发者深入学习和实践参考。
122 8
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####

热门文章

最新文章