java void方法单测断言的三种实现示例
目录
- 1. 验证状态变化(最常用)
- 2. 验证行为交互(使用 Mockito)
- 3. 验证异常抛出
- 最佳实践建议:
- 完整测试示例:
在 javascriptJava 中对 void 方法进行单元测试断言,主要通过以下三种策略实现(以 JUnit 和 AssertJ 为例):
1. 验证状态变化(最常用)
测试方法执行后对象或系统状编程态的改变:
@Test void reset_shouldClearCounter() { Counter counter = new Counter(); cohVFUlLjVnXunter.increment(); // 初始值+1 // 执行 void 方法 counter.reset(); // 验证内部状态 assertEquals(0, counter.getCount()); // 使用 AssertJ 更优雅的断言 assertThat(counter.getCount()).isZero(); }
2. 验证行为交互(使用 Mockito)
当 void 方法依赖其他对象时,验证是否正确调用协作对象:
@Test void notifyUser_shouldTriggerNotificationService() { // 创建依赖项的 mock NotificationService mockService = mock(NotificationService.class); UserService userService = new UserService(mockService); // 执行 void 方法 userService.notifyUser("user123"); // 验证是否调用了依赖对象的特定方法 verify(mockService).sendNotification(eq("user123")); // 验证调用次数 verify(mockService, times(1)).sendNotification(any()); }
3. 验证异常抛出
测试方法在非法输入时的异常行为:
@Test void withdraw_shouldThrowExceptionWhenOverdraft() { Account account = new Account(100); // 验证异常断言 (JUnit 5) assertThrows(InsufficientFundsException.class, () -> { account.withdraw(200); // void 方法 }); // AssertJ 异常断言 assertThatThrownBy(() -> account.withdraw(200)) .isInstanceOf(InsufficientFundsException.class) .hasMessage("余额不足"); }
最佳实践建议:
状态优先原则:优先验证对象状态变化而非内部行为
行为验证场景:
- 当调用外部系统接口(如发送邮件)
- 需要确认调用顺序或次数(如多次调用)
自定义验证器:复杂状态可封装验证逻辑
@Test void updateProfile_shouldChangeMultipleFields() { User user = new User(); user.updateProfile("Alice", 30, "alice@email.com"); // 自定义断言方法 assertUserProfile(user, "Alice", 30, "alice@email.com"); } private void assertUserProfile(User user, String name, int age, String email) { assertThat(user.getName()).isEqualTo(name); assertThat(user.getAge()).isEqualTo(age); assertThat(user.getEmail()).isEqualTo(emai编程l); }
完整测试示例:
public class ShoppingCartTest { @Test void clear_shouldRemoveAllItems() { // 准备 ShoppingCart cart = new ShoppingCart(); cart.addItem(new Item("Book", 15.99)); cart.addItem(new Item("Pen", 1.99)); // 执行 cart.clear(); // 验证 assertThat(cart.isEmpty()) .as("购物车应在清空后为空") .isTrue(); } @Test void processOrder_shouldPersistToDatabase() { // 准备 OrderDao mockDao = mock(OrderDao.class); OrderService service = new OrderService(mockDao); Order order = new Order("ORDER-123"); // 执行 serphpvice.processOrder(order); // 验证数据库交互 verify(mockDao).save(order); } @Test void setDiscount_shouldThrowForInvalidValue() { Product product = new Product(); assertThatThrownBy(() -> product.setDiscount(-10)) .isInstanceOf(IllegalArgumentException.class) .hasMessageContaining("折扣值非法"); } }
关键结论:
- Void 方法通过间接验证状态变化或检查方法行为进行断言
- 优先使用 assertEquals/assertThat 检查状态变化
- 对依赖交互使用 Mockito 的 verify
- 异常场景用 assertThrows/assertThatThrownBy
- 复杂断言使用自定义断言方法保持可读性
对于现代 Java 测试,推荐使用 AssertJ 提供的丰富断言(如 assertThat().isEmpty()
)和 Mockito 进行行为验证,比传统的 JUnit 断言更具表达力。
到此这篇关于java void方法单测断言的三种实现示例的文章就介绍到这了,更多相关java void断言内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!
精彩评论