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

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

卷首语


《卜算子·致码农》

作者:常意

 

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

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

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

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

 

一、 什么是单元测试

 

维基百科是这样描述的:

 

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

 

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

 

1. 狭义单元测试

 

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

 

2. 广义单元测试

 

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

 

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

 

二、 单元测试的意义

 

1. 验证代码逻辑

 

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

 

2. 减少代码缺陷

 

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

 

3. 促进代码设计

 

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

 

4. 便于多人协作

 

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

 

5. 便于缺陷定位

 

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

 

6. 放心代码重构

 

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

 

 

7. 增强代码信心

 

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

 

三、单元测试的推广 

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

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

 

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

 

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

 

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

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

 

常意

2023年春

北京


相关文章
|
3月前
|
安全 Java 开发者
告别NullPointerException:Java Optional实战指南
告别NullPointerException:Java Optional实战指南
290 119
|
5月前
|
Java 关系型数据库 数据库
Java 项目实战教程从基础到进阶实战案例分析详解
本文介绍了多个Java项目实战案例,涵盖企业级管理系统、电商平台、在线书店及新手小项目,结合Spring Boot、Spring Cloud、MyBatis等主流技术,通过实际应用场景帮助开发者掌握Java项目开发的核心技能,适合从基础到进阶的学习与实践。
795 3
|
4月前
|
存储 前端开发 Java
【JAVA】Java 项目实战之 Java Web 在线商城项目开发实战指南
本文介绍基于Java Web的在线商城技术方案与实现,涵盖三层架构设计、MySQL数据库建模及核心功能开发。通过Spring MVC + MyBatis + Thymeleaf实现商品展示、购物车等模块,提供完整代码示例,助力掌握Java Web项目实战技能。(238字)
488 0
|
5月前
|
Java API Maven
2025 Java 零基础到实战最新技术实操全攻略与学习指南
本教程涵盖Java从零基础到实战的全流程,基于2025年最新技术栈,包括JDK 21、IntelliJ IDEA 2025.1、Spring Boot 3.x、Maven 4及Docker容器化部署,帮助开发者快速掌握现代Java开发技能。
1058 1
|
4月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
489 100
|
5月前
|
数据采集 JSON Java
Java爬虫获取1688店铺所有商品接口数据实战指南
本文介绍如何使用Java爬虫技术高效获取1688店铺商品信息,涵盖环境搭建、API调用、签名生成及数据抓取全流程,并附完整代码示例,助力市场分析与选品决策。
|
4月前
|
人工智能 Java API
Java AI智能体实战:使用LangChain4j构建能使用工具的AI助手
随着AI技术的发展,AI智能体(Agent)能够通过使用工具来执行复杂任务,从而大幅扩展其能力边界。本文介绍如何在Java中使用LangChain4j框架构建一个能够使用外部工具的AI智能体。我们将通过一个具体示例——一个能获取天气信息和执行数学计算的AI助手,详细讲解如何定义工具、创建智能体并处理执行流程。本文包含完整的代码示例和架构说明,帮助Java开发者快速上手AI智能体的开发。
1424 8
|
4月前
|
人工智能 Java API
Java与大模型集成实战:构建智能Java应用的新范式
随着大型语言模型(LLM)的API化,将其强大的自然语言处理能力集成到现有Java应用中已成为提升应用智能水平的关键路径。本文旨在为Java开发者提供一份实用的集成指南。我们将深入探讨如何使用Spring Boot 3框架,通过HTTP客户端与OpenAI GPT(或兼容API)进行高效、安全的交互。内容涵盖项目依赖配置、异步非阻塞的API调用、请求与响应的结构化处理、异常管理以及一些面向生产环境的最佳实践,并附带完整的代码示例,助您快速将AI能力融入Java生态。
695 12
|
3月前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
5月前
|
算法 Java 开发者
Java流程控制:条件与循环结构实战
本文深入讲解编程中的流程控制结构,涵盖条件语句(if-else、switch)、循环结构(for、while、do-while)及循环控制关键字(break、continue)的使用技巧与实战案例,帮助开发者写出更清晰、高效的代码。