JUnit的各种断言

转自:http://dongbiying.iteye.com/blog/1002188

 JUnit为我们提供了一些辅助函数,他们用来帮助我们确定被测试的方法是否按照预期的效果正常工作,通常,把这些辅助函数称为断言。下面我们来介绍一下JUnit的各种断言。 

   1、assertEquals 

  函数原型1:assertEquals([String message],expected,actual) 

参数说明: 

message是个可选的消息,假如提供,将会在发生错误时报告这个消息。 

  expected是期望值,通常都是用户指定的内容。 

actual是被测试的代码返回的实际值。 

例:assertEquals("equals","1","1"); 

  函数原型2:assertEquals([String message],expected,actual,tolerance) 

参数说明: 

message是个可选的消息,假如提供,将会在发生错误时报告这个消息。 

  expected是期望值,通常都是用户指定的内容。 

  actual是被测试的代码返回的实际值。 

  tolerance是误差参数,参加比较的两个浮点数在这个误差之内则会被认为是 

  相等的。 

  例:assertEquals ("yes",5.8,11.0/2.0,0.5); 

  2、assertTrue 

   函数原型:assertTrue ([String message],Boolean condition) 

   参数说明: 

message是个可选的消息,假如提供,将会在发生错误时报告这个消息。 

       condition是待验证的布尔型值。 

   该断言用来验证给定的布尔型值是否为真,假如结果为假,则验证失败。当然,更有验证为假的测试条件: 

          函数原型:assertFalse([String message],Boolean condition) 

          该断言用来验证给定的布尔型值是否为假,假如结果为真,则验证失败。 

       例: assertTrue("true",1==1); 

              assertFalse("false",2==1); 

  3、assertNull 

  函数原型:assertNull([String message],Object object) 

参数说明: 

message是个可选的消息,假如提供,将会在发生错误时报告这个消息。 

  object是待验证的对象。 

  该断言用来验证给定的对象是否为null,假如不为null,则验证失败。相应地,还存在能够验证非null的断言: 

  函数原型:assertNotNull([String message],Object object) 

该断言用来验证给定的对象是否为非null,假如为null,则验证失败。 

例:assertNull("null",null); 

       assertNotNull("not null",new String()); 

  4、assertSame 

  函数原型:assertSame ([String message], expected,actual) 

参数说明: 

message是个可选的消息,假如提供,将会在发生错误时报告这个消息。 

  expected是期望值。 

  actual是被测试的代码返回的实际值。 

  该断言用来验证expected参数和actual参数所引用的是否是同一个对象,假如不是,则验证失败。相应地,也存在验证不是同一个对象的断言: 

  函数原型:assertNotSame ([String message], expected,actual) 

该断言用来验证expected参数和actual参数所引用的是否是不同对象,假如所引用的对象相同,则验证失败。 

例:assertSame("same",2,4-2); 

        assertNotSame("not same",2,4-3); 

  5、Fail 

  函数原型:Fail([String message]) 

参数说明: 

message是个可选的消息,假如提供,将会在发生错误时报告这个消息。 

  该断言会使测试立即失败,通常用在测试不能达到的分支上(如异常)。 

JUnit是一个用于编写和运行可重复测试的开源框架,是Java语言中非常流行的单元测试框架。JUnit4是JUnit框架的一个重要版本,引入了许多新特性,包括新的断言方法。以下是JUnit4中一些常用的断言方法: 1. assertEquals(expected, actual) 检查两个值是否相等。 2. assertNotEquals(unexpected, actual) 检查两个值是否不相等。 3. assertTrue(condition) 检查条件是否为真。 4. assertFalse(condition) 检查条件是否为假。 5. assertNull(object) 检查对象是否为null。 6. assertNotNull(object) 检查对象是否不为null。 7. assertSame(expected, actual) 检查两个对象引用是否指向同一个对象。 8. assertNotSame(unexpected, actual) 检查两个对象引用是否不指向同一个对象。 9. fail() 使测试立即失败。 10. assertArrayEquals(expectedArray, actualArray) 检查两个数组是否相等。 11. assertThat(actual, matcher) 使用Hamcrest匹配器进行更复杂的断言。 使用示例: ```java import org.junit.Test; import static org.junit.Assert.*; public class MyTest { @Test public void testAddition() { int result = 2 + 2; assertEquals(4, result); } @Test public void testString() { String str = "Hello, World!"; assertTrue(str.startsWith("Hello")); assertFalse(str.isEmpty()); assertNotNull(str); } @Test public void testArray() { int[] expected = {1, 2, 3}; int[] actual = {1, 2, 3}; assertArrayEquals(expected, actual); } @Test public void testException() { try { throw new Exception("Some error"); fail("Expected exception was not thrown"); } catch (Exception e) { assertEquals("Some error", e.getMessage()); } } } ``` JUnit4的断言方法使得编写测试用例变得更加简单和直观。它们帮助开发者验证代码的正确性,确保软件质量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值