展开
拓展 关闭
订阅号推广码
GitHub
视频
公告栏 关闭

断言

  • 简介
断言(assertions)是测试方法中的核心部分,用来对测试需要满足的条件进行验证。这些断言方法都是 org.junit.jupiter.api.Assertions 的静态方法
检查业务逻辑返回的数据是否合理。
所有的测试运行结束以后,会有一个详细的测试报告
  • 简单断言

  • 案例

# 当前面执行的断言失败后,后面的断言不会执行
@Test
@DisplayName("simple assertion")
public void simple() {
// 测试2个对象是否相等,第1个参数为期望值,第2个参数为计算值,第3个参数为自定义的异常语句
assertEquals(3, 1 + 2, "simple math");
// 测试2个对象是否不相等
assertNotEquals(3, 1 + 1);
// 判断两个对象引用是否指向同一个对象
assertNotSame(new Object(), new Object());
Object obj = new Object();
assertSame(obj, obj);
// 判断给定的布尔值是否为 false
assertFalse(1 > 2);
// 判断给定的布尔值是否为 true
assertTrue(1 < 2);
// 判断给定的布尔值是否为 false
assertNull(null);
// 判断给定的对象引用是否不为 null
assertNotNull(new Object());
}
  • 数组断言
# 通过 assertArrayEquals 方法来判断两个对象或原始类型的数组是否相等
@Test
@DisplayName("array assertion")
public void array() {
assertArrayEquals(new int[]{1, 2}, new int[] {1, 2});
}
  • 组合断言
# assertAll 方法接受多个 org.junit.jupiter.api.Executable 函数式接口的实例作为要验证的断言,可以通过 lambda 表达式很容易的提供这些断言
@Test
@DisplayName("assert all")
public void all() {
assertAll("Math",
() -> assertEquals(2, 1 + 1),
() -> assertTrue(1 > 0)
);
}
  • 异常断言
# 断言一定会抛出某种异常
@Test
@DisplayName("异常测试")
public void exceptionTest() {
ArithmeticException exception = Assertions.assertThrows(
//扔出断言异常
ArithmeticException.class, () -> System.out.println(1 % 0));
}
  • 超时断言
@Test
@DisplayName("超时测试")
public void timeoutTest() {
//如果测试方法时间超过1s将会异常
Assertions.assertTimeout(Duration.ofMillis(1000), () -> Thread.sleep(500));
}
  • 快速失败
# 通过 fail 方法直接使得测试失败
@Test
@DisplayName("fail")
public void shouldFail() {
fail("This should fail");
}
posted @   DogLeftover  阅读(59)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示