zoukankan      html  css  js  c++  java
  • Junit使用教程(二)

    二、核心——断言

    断言是编写测试用例的核心实现方式,即期望值是多少,测试的结果是多少,以此来判断测试是否通过。

    1. 断言核心方法

    assertArrayEquals(expecteds, actuals) 查看两个数组是否相等。
    assertEquals(expected, actual) 查看两个对象是否相等。类似于字符串比较使用的equals()方法
    assertNotEquals(first, second) 查看两个对象是否不相等。
    assertNull(object) 查看对象是否为空。
    assertNotNull(object) 查看对象是否不为空。
    assertSame(expected, actual) 查看两个对象的引用是否相等。类似于使用“==”比较两个对象
    assertNotSame(unexpected, actual) 查看两个对象的引用是否不相等。类似于使用“!=”比较两个对象
    assertTrue(condition) 查看运行结果是否为true。
    assertFalse(condition) 查看运行结果是否为false。
    assertThat(actual, matcher) 查看实际值是否满足指定的条件
    fail() 让测试失败

    2. 示例

    [java] view plaincopy
     
    1. package test;  
    2.   
    3. import static org.hamcrest.CoreMatchers.*;  
    4. import static org.junit.Assert.*;  
    5.   
    6. import java.util.Arrays;  
    7.   
    8. import org.hamcrest.core.CombinableMatcher;  
    9. import org.junit.Test;  
    10.   
    11. public class AssertTests {  
    12.   
    13.       @Test  
    14.       public void testAssertArrayEquals() {  
    15.         byte[] expected = "trial".getBytes();  
    16.         byte[] actual = "trial".getBytes();  
    17.         org.junit.Assert.assertArrayEquals("failure - byte arrays not same", expected, actual);  
    18.       }  
    19.   
    20.       @Test  
    21.       public void testAssertEquals() {  
    22.         org.junit.Assert.assertEquals("failure - strings not same", 5l, 5l);  
    23.       }  
    24.   
    25.       @Test  
    26.       public void testAssertFalse() {  
    27.         org.junit.Assert.assertFalse("failure - should be false", false);  
    28.       }  
    29.   
    30.       @Test  
    31.       public void testAssertNotNull() {  
    32.         org.junit.Assert.assertNotNull("should not be null", new Object());  
    33.       }  
    34.   
    35.       @Test  
    36.       public void testAssertNotSame() {  
    37.         org.junit.Assert.assertNotSame("should not be same Object", new Object(), new Object());  
    38.       }  
    39.   
    40.       @Test  
    41.       public void testAssertNull() {  
    42.         org.junit.Assert.assertNull("should be null", null);  
    43.       }  
    44.   
    45.       @Test  
    46.       public void testAssertSame() {  
    47.         Integer aNumber = Integer.valueOf(768);  
    48.         org.junit.Assert.assertSame("should be same", aNumber, aNumber);  
    49.       }  
    50.   
    51.       // JUnit Matchers assertThat  
    52.       @Test  
    53.       public void testAssertThatBothContainsString() {  
    54.         org.junit.Assert.assertThat("albumen", both(containsString("a")).and(containsString("b")));  
    55.       }  
    56.   
    57.       @Test  
    58.       public void testAssertThathasItemsContainsString() {  
    59.         org.junit.Assert.assertThat(Arrays.asList("one", "two", "three"), hasItems("one", "three"));  
    60.       }  
    61.   
    62.       @Test  
    63.       public void testAssertThatEveryItemContainsString() {  
    64.         org.junit.Assert.assertThat(Arrays.asList(new String[] { "fun", "ban", "net" }), everyItem(containsString("n")));  
    65.       }  
    66.   
    67.       // Core Hamcrest Matchers with assertThat  
    68.       @Test  
    69.       public void testAssertThatHamcrestCoreMatchers() {  
    70.         assertThat("good", allOf(equalTo("good"), startsWith("good")));  
    71.         assertThat("good", not(allOf(equalTo("bad"), equalTo("good"))));  
    72.         assertThat("good", anyOf(equalTo("bad"), equalTo("good")));  
    73.         assertThat(7, not(CombinableMatcher.<Integer> either(equalTo(3)).or(equalTo(4))));  
    74.         assertThat(new Object(), not(sameInstance(new Object())));  
    75.       }  
    76. }  

    三、核心——注解

    1. 说明

    @Before 初始化方法
    @After 释放资源
    @Test 测试方法,在这里可以测试期望异常和超时时间
    @Ignore 忽略的测试方法
    @BeforeClass 针对所有测试,只执行一次,且必须为static void
    @AfterClass 针对所有测试,只执行一次,且必须为static void
    @RunWith 指定测试类使用某个运行器
    @Parameters 指定测试类的测试数据集合
    @Rule 允许灵活添加或重新定义测试类中的每个测试方法的行为
    @FixMethodOrder 指定测试方法的执行顺序

    2. 执行顺序

    一个测试类单元测试的执行顺序为:

    @BeforeClass –> @Before –> @Test –> @After –> @AfterClass

    每一个测试方法的调用顺序为:

    @Before –> @Test –> @After

    3. 示例

    [java] view plaincopy
     
    1. package test;  
    2.   
    3. import static org.junit.Assert.*;  
    4.   
    5. import org.junit.*;  
    6.   
    7. public class JDemoTest {  
    8.   
    9.     @BeforeClass  
    10.     public static void setUpBeforeClass() throws Exception {  
    11.         System.out.println("in BeforeClass================");  
    12.     }  
    13.   
    14.     @AfterClass  
    15.     public static void tearDownAfterClass() throws Exception {  
    16.         System.out.println("in AfterClass=================");  
    17.     }  
    18.   
    19.     @Before  
    20.     public void before() {  
    21.         System.out.println("in Before");  
    22.     }  
    23.   
    24.     @After  
    25.     public void after() {  
    26.         System.out.println("in After");  
    27.     }  
    28.   
    29.     @Test(timeout = 10000)  
    30.     public void testadd() {  
    31.         JDemo a = new JDemo();  
    32.         assertEquals(6, a.add(3, 3));  
    33.         System.out.println("in Test ----Add");  
    34.     }  
    35.   
    36.     @Test  
    37.     public void testdivision() {  
    38.         JDemo a = new JDemo();  
    39.         assertEquals(3, a.division(6, 2));  
    40.         System.out.println("in Test ----Division");  
    41.     }  
    42.   
    43.     @Ignore  
    44.     @Test  
    45.     public void test_ignore() {  
    46.         JDemo a = new JDemo();  
    47.         assertEquals(6, a.add(1, 5));  
    48.         System.out.println("in test_ignore");  
    49.     }  
    50.   
    51.     @Test  
    52.     public void teest_fail() {  
    53.         fail();  
    54.     }  
    55. }  
    56.   
    57. class JDemo extends Thread {  
    58.   
    59.     int result;  
    60.   
    61.     public int add(int a, int b) {  
    62.         try {  
    63.             sleep(1000);  
    64.             result = a + b;  
    65.         } catch (InterruptedException e) {  
    66.         }  
    67.         return result;  
    68.     }  
    69.   
    70.     public int division(int a, int b) {  
    71.         return result = a / b;  
    72.     }  
    73. }  

    执行结果:

    [plain] view plaincopy
     
    1. in BeforeClass================  
    2. in Before  
    3. in Test ----Add  
    4. in After  
    5. in Before  
    6. in Test ----Division  
    7. in After  
    8. in AfterClass=================  

     

    图中左上红框中部分表示Junit运行结果,5个成功(1个忽略),1个错误,1个失败。(注意错误和失败不是一回事,错误说明代码有错误,而失败表示该测试方法测试失败)

    左下红框中则表示出了各个测试方法的运行状态,可以看到成功、错误、失败、失败各自的图标是不一样的,还可以看到运行时间。

    右边部分则是异常堆栈,可查看异常信息。

    下篇中我们给出更多示例还继续介绍Junit

  • 相关阅读:
    带参数的装饰器
    python清空文件夹
    sqlalchemy的filter使用
    git pull命令的用法
    通过jenkins打包ipa包报错:Command CodeSign failed with a nonzero exit code(errSecInternalComponent)
    postman上传图片,及接口上传图片
    liunx中crontab没有生效
    liunx正则危险符号“*”星号
    rqalpha的改造工作
    Qt浅谈之一:内存泄露(总结)
  • 原文地址:https://www.cnblogs.com/daxiong2014/p/4511522.html
Copyright © 2011-2022 走看看