《Java单元测试实战》——单测认证:单元测试认证问题、答案和解析(上)

简介: 《Java单元测试实战》——单测认证:单元测试认证问题、答案和解析(上)

1. 找出单测中存在的问题

 

题目:号称“单测小王子”的小明,写起单测用例毫不费力,且新增代码的单测覆盖率达到90%+。在一次代码评审中,小明的单测用例却被评审者挑战了,你认为会被评审者挑战的单测问题有哪些?

 

image.png



选项

 

A. 无需用代码构建真实dataList对象,直接mock或new一个虚拟dataList对象

B. 没有验证返回值pageData的全部属性

C. 没有验证 mock 的方法调用

D. 同一对象实例, 建议使用 Assert.assertSame 代替Assert.assertEquals

 

 

答案:ABCD

 

1. 学习单测偷懒大法

 

题目在业务需求交付的压力下,小明总结了一套快速提高单测覆盖率的“方法论”。在只保证单测覆盖率、不保证单测有效性的前提下,以下哪些方法是有效的?

 

 

选项

 

A. 不验证数据对象(属性、参数、返回值)

B. 不验证抛出异常

C. 不验证方法调用

D. 不模拟方法返回

 

 

答案:ABC

 

解析:不模拟方法返回,就无法进入某些分支,所以不利于提高单测覆盖率。

 

2. 如何单测虚基类

 

题目:在一次新需求开发时,小明遇到了虚基类单元测试编写问题。在跟周围的同事请教后,小明得到了4套解决方案,他一时无法分辨孰好孰坏。你帮他看看哪套方案最佳?

 

选项

 

A. 找一个子类测试,连带测试了基类

B. 实现一个子类测试,然后基于子类测试基类

C. 先spy基类对象,再mock虚方法,最后测试基类所有方法

D. 以上方案都可取

 

 

答案:C

 

解析:针对基类要单独测试,尽量不采用联合测试。

 

3. 单元测试和集成测试的区别

 

题目:小白刚入职,分不清单元测试和集成测试。向师兄们请教后,发现他们对单元测试和集成测试的理解也不尽相同。请你帮小白分辨下,以下哪些观点是正确的?

 

 

选项

 

A. 满足AIR、FIRST原则的测试用例都是单元测试

B. 单元测试是对软件设计最小单位的程序模块进行测试,集成测试是对这些程序模块组装成的系统模块进行测试

C. 单元测试和集成测试的主要区别就是有没有外部依赖

D. 单元测试和集成测试没有严格区分,只要满足AIR、FIRST原则,执行时间小于一定门限(比如100ms)就可以认为是单元测试

 

 

答案:B

 

解析

 

A. 集成测试也可能满足AIR、FIRST原则

B. 正确

C. 集成测试也可能没有外部依赖

D. 单元测试和集成测试概念不一样,虽然集成测试可以替换单元测试,但是不能混淆

 

4. 如何单测异常

 

题目

 

小白在帮同事做Code Review时,发现同一个项目中存在4种异常验证方法:

 

1) 通过try-catch语句验证异常;

2) 通过@Test注解验证异常;

3) 通过@Rule注解验证异常;

4) 通过Assert.assertThrows方法验证异常。

 

关于这些异常验证方法,下面说法正确的是?

 

选项

 

A. 方法2最简单,推荐大家使用

B. 方法3已废弃,不推荐大家使用

C. 方法4最完美,推荐大家使用

D. 方法1/4可以验证方法,而方法2/3无法验证方法

 

 

答案:BCD

 

解析

 

A. 方法2无法验证方法

B. 正确

C. 正确

D. 正确

 

5. 单测的回归验证功能

 

题目:小明对原有代码进行了重构后,执行原有单元测试用例进行回归验证。针对单测的回归验证,下列说法是正确的是?

 

选项

 

A. 新增的对象属性字段(保证不为null),可以通过Assert.assertEquals等方法验证出来

B. 方法是否被调用,可以通过Mockito.verify方法验证出来

C. 多余的方法调用,可以通过Mockito.verifyNoMoreInteractions方法验证出来

D. 执行单测的回归验证完全通过,就表示重构的代码逻辑没有问题

 

 

答案:ABC

 

解析:执行单测出错,表示重构的代码逻辑肯定有问题;执行单测不出错,并不表示重构的代码逻辑没有问题。

 

 

 

 

6. 关于单测简化方法

 

题目:小明一直致力于单元测试的简化,希望利用最少的代码测试最多的代码。通过阅读相关单元测试资料,小明总结了以下单测简化方法。请问,下面单测简化方法中,哪些是有效的?

 

选项

 

A. 对于简单方法(比如Objects.equals),可以写在同一个测试方法中

B. 只写一个测试用例,通过条件判断是否mock或verify方法,利用参数化测试传入不同数据来测试所有代码分支流程

C. 利用测试用例特性简化测试用例,比如:不关心对象内容时,可以用虚拟对象代替真实数据

D. 利用工具类特性简化测试用例,比如:利用JSON反序列化简化对象构建语句,利用JSON序列化简化对象验证据

E. 为了减少单测代码量,可以不写对象和方法验证语句

 

 

答案:ACD

 

解析

 

B.测试用例复杂且不可读

E.属于偷懒行为,写出来的是无效单测

 




《Java单元测试实战》——单测认证:单元测试认证问题、答案和解析(下) https://developer.aliyun.com/article/1231988?groupCode=java

相关文章
|
1天前
|
存储 Java
深入解析 Java 面向对象编程与类属性应用
面向对象编程 (OOP) 是一种编程范式,它将程序组织成对象。对象包含数据和操作数据的方法。 OOP 的优势: 更快、更易于执行 提供清晰的结构 代码更易于维护、修改和调试 提高代码重用性 减少开发时间
16 0
|
1天前
|
存储 安全 Java
Java并发基础:CopyOnWriteArraySet全面解析
CopyOnWriteArraySet类的优点在于能够实现无锁读取,确保高并发下的读取性能,同时,写操作通过复制底层数据来保证数据一致性,避免了多线程间的数据冲突,因此,它非常适合读多写少且对数据一致性要求较高的场景。
Java并发基础:CopyOnWriteArraySet全面解析
|
1天前
|
Java 程序员 API
Java并发基础:concurrent Flow API全面解析
java.util.concurrent.Flow定义了响应式编程的核心接口,促进了Java在异步数据处理和背压机制方面的标准化,这使得第三方库如Reactor和RxJava能够基于这些接口提供丰富的实现和功能,同时简化了响应式编程在Java中的使用,Flow API增强了Java在并发编程领域的灵活性,使得处理异步数据流变得更加自然和高效。
Java并发基础:concurrent Flow API全面解析
|
2天前
|
前端开发 Java API
Java并发基础:CompletableFuture全面解析
CompletableFuture类使得并发任务的处理变得简单而高效,通过简洁的API,开发者能轻松创建、组合和链式调用异步操作,无需关心底层线程管理,这不仅提升了程序的响应速度,还优化了资源利用率,让复杂的并发逻辑变得易于掌控。
Java并发基础:CompletableFuture全面解析
|
2天前
|
存储 安全 Java
Java并发基础:CopyOnWriteArrayList全面解析
CopyOnWriteArrayList类的最大优点在于读取时无需加锁,非常适合读多写少的并发场景,由于其写操作通过复制底层数据来实现,从而保证了读取数据的一致性和高效性,此外,它简单易用,是快速实现线程安全列表的不错选择,CopyOnWriteArrayList在读操作占主导的场景下,能够提供出色的性能和稳定性。
Java并发基础:CopyOnWriteArrayList全面解析
|
3天前
|
存储 安全 算法
Java并发基础:ConcurrentSkipListMap全面解析
ConcurrentSkipListMap类它融合了跳表的高效查找与并发控制的稳定性,在多线程环境下,该类提供了出色的线程安全性能,确保数据的一致性与完整性,其操作具有对数级别的时间复杂度,即使在大数据集下也能维持高效性能。
Java并发基础:ConcurrentSkipListMap全面解析
|
3天前
|
存储 安全 算法
Java并发基础:ConcurrentSkipListSet全面解析!
ConcurrentSkipListSet类在多线程环境下,它能够轻松应对大量的插入、删除和查找操作,同时保持数据的完整性和一致性,其内部基于跳表数据结构的实现,确保了即使在处理大规模数据时,也能具有出色的性能表现。
Java并发基础:ConcurrentSkipListSet全面解析!
|
5天前
|
缓存 安全 Java
Java并发基础:SynchronousQueue全面解析!
SynchronousQueue的优点在于其直接性和高效性,它实现了线程间的即时数据交换,无需中间缓存,确保了数据传输的实时性和准确性,同时,其灵活的阻塞机制使得线程同步变得简单而直观,适用于需要精确协调的生产者-消费者模型。
Java并发基础:SynchronousQueue全面解析!
|
5天前
|
安全 Java API
Java并发基础:Exchanger全面解析!
Exchanger类的优点在于能够简洁高效地实现两个线程间的数据交换,通过Exchanger,开发者可以避免复杂的锁和同步机制,降低并发编程的难度,同时,它还提供了线程安全的数据交换保障,使得多线程协作更为可靠、易用性和高效性。
Java并发基础:Exchanger全面解析!
|
7天前
|
存储 缓存 安全
Java并发基础:ConcurrentLinkedDeque全面解析!
ConcurrentLinkedDeque类提供了线程安全的双端队列操作,支持高效的并发访问,因此在多线程环境下,可以放心地在队列的两端添加或移除元素,而不用担心数据的一致性问题。同时,它的内部实现采用了无锁算法,从而避免了传统锁带来的性能开销。
Java并发基础:ConcurrentLinkedDeque全面解析!

热门文章

最新文章

推荐镜像

更多