一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - 詳解Spring Boot Junit單元測試

詳解Spring Boot Junit單元測試

2020-12-02 13:41catoop Java教程

本篇文章主要介紹了詳解Spring Boot Junit單元測試,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

Junit這種老技術(shù),現(xiàn)在又拿出來說,不為別的,某種程度上來說,更是為了要說明它在項目中的重要性。

憑本人的感覺和經(jīng)驗來說,在項目中完全按標(biāo)準(zhǔn)都寫Junit用例覆蓋大部分業(yè)務(wù)代碼的,應(yīng)該不會超過一半。

剛好前段時間寫了一些關(guān)于SpringBoot的帖子,正好現(xiàn)在把Junit再拿出來從幾個方面再說一下,也算是給一些新手參考了。

那么先簡單說一下為什么要寫測試用例

1. 可以避免測試點的遺漏,為了更好的進(jìn)行測試,可以提高測試效率

2. 可以自動測試,可以在項目打包前進(jìn)行測試校驗

3. 可以及時發(fā)現(xiàn)因為修改代碼導(dǎo)致新的問題的出現(xiàn),并及時解決

那么本文從以下幾點來說明怎么使用Junit,Junit4比3要方便很多,細(xì)節(jié)大家可以自己了解下,主要就是版本4中對方法命名格式不再有要求,不再需要繼承TestCase,一切都基于注解實現(xiàn)。

1、SpringBoot Web項目中中如何使用Junit

創(chuàng)建一個普通的Java類,在Junit4中不再需要繼承TestCase類了。

因為我們是Web項目,所以在創(chuàng)建的Java類中添加注解:

?
1
2
3
@RunWith(SpringJUnit4ClassRunner.class) // SpringJUnit支持,由此引入Spring-Test框架支持!
@SpringApplicationConfiguration(classes = SpringBootSampleApplication.class) // 指定我們SpringBoot工程的Application啟動類
@WebAppConfiguration // 由于是Web項目,Junit需要模擬ServletContext,因此我們需要給我們的測試類加上@WebAppConfiguration。

接下來就可以編寫測試方法了,測試方法使用@Test注解標(biāo)注即可。

在該類中我們可以像平常開發(fā)一樣,直接@Autowired來注入我們要測試的類實例。

下面是完整代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
package org.springboot.sample;
 
import static org.junit.Assert.assertArrayEquals;
 
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springboot.sample.service.StudentService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.SpringApplicationConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;
 
/**
 *
 * @author  單紅宇(365384722)
 * @create  2016年2月23日
 */
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = SpringBootSampleApplication.class)
@WebAppConfiguration
public class StudentTest {
 
  @Autowired
  private StudentService studentService;
 
  @Test
  public void likeName() {
    assertArrayEquals(
        new Object[]{
            studentService.likeName("小明2").size() > 0,
            studentService.likeName("壞").size() > 0,
            studentService.likeName("莉莉").size() > 0
          },
        new Object[]{
            true,
            false,
            true
          }
    );
//   assertTrue(studentService.likeName("小明2").size() > 0);
  }
 
}

接下來,你需要新增無數(shù)個測試類,編寫無數(shù)個測試方法來保障我們開發(fā)完的程序的有效性。

2、Junit基本注解介紹

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
//在所有測試方法前執(zhí)行一次,一般在其中寫上整體初始化的代碼
@BeforeClass
 
//在所有測試方法后執(zhí)行一次,一般在其中寫上銷毀和釋放資源的代碼
@AfterClass
 
//在每個測試方法前執(zhí)行,一般用來初始化方法(比如我們在測試別的方法時,類中與其他測試方法共享的值已經(jīng)被改變,為了保證測試結(jié)果的有效性,我們會在@Before注解的方法中重置數(shù)據(jù))
@Before
 
//在每個測試方法后執(zhí)行,在方法執(zhí)行完成后要做的事情
@After
 
// 測試方法執(zhí)行超過1000毫秒后算超時,測試將失敗
@Test(timeout = 1000)
 
// 測試方法期望得到的異常類,如果方法執(zhí)行沒有拋出指定的異常,則測試失敗
@Test(expected = Exception.class)
 
// 執(zhí)行測試時將忽略掉此方法,如果用于修飾類,則忽略整個類
@Ignore(“not ready yet”)
@Test
 
@RunWith

在JUnit中有很多個Runner,他們負(fù)責(zé)調(diào)用你的測試代碼,每一個Runner都有各自的特殊功能,你要根據(jù)需要選擇不同的Runner來運行你的測試代碼。

如果我們只是簡單的做普通Java測試,不涉及spring Web項目,你可以省略@RunWith注解,這樣系統(tǒng)會自動使用默認(rèn)Runner來運行你的代碼。

3、參數(shù)化測試

Junit為我們提供的參數(shù)化測試需要使用 @RunWith(Parameterized.class)

然而因為Junit 使用@RunWith指定一個Runner,在我們更多情況下需要使用@RunWith(SpringJUnit4ClassRunner.class)來測試我們的Spring工程方法,所以我們使用assertArrayEquals 來對方法進(jìn)行多種可能性測試便可。

下面是關(guān)于參數(shù)化測試的一個簡單例子:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package org.springboot.sample;
 
import static org.junit.Assert.assertTrue;
 
import java.util.Arrays;
import java.util.Collection;
 
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
 
@RunWith(Parameterized.class)
public class ParameterTest {
 
  private String name;
  private boolean result;
 
  /**
   * 該構(gòu)造方法的參數(shù)與下面@Parameters注解的方法中的Object數(shù)組中值的順序?qū)?yīng)
   * @param name
   * @param result
   */
  public ParameterTest(String name, boolean result) {
    super();
    this.name = name;
    this.result = result;
  }
 
  @Test
  public void test() {
    assertTrue(name.contains("小") == result);
  }
 
  /**
   * 該方法返回Collection
   *
   * @return
   * @author SHANHY
   * @create 2016年2月26日
   */
  @Parameters
  public static Collection<?> data(){
    // Object 數(shù)組中值的順序注意要和上面的構(gòu)造方法ParameterTest的參數(shù)對應(yīng)
    return Arrays.asList(new Object[][]{
      {"小明2", true},
      {"壞", false},
      {"莉莉", false},
    });
  }
}

4、打包測試

正常情況下我們寫了5個測試類,我們需要一個一個執(zhí)行。

打包測試,就是新增一個類,然后將我們寫好的其他測試類配置在一起,然后直接運行這個類就達(dá)到同時運行其他幾個測試的目的。

代碼如下:

?
1
2
3
4
5
@RunWith(Suite.class)
@SuiteClasses({ATest.class, BTest.class, CTest.class})
public class ABCSuite {
  // 類中不需要編寫代碼
}

5、使用Junit測試HTTP的API接口

我們可以直接使用這個來測試我們的Rest API,如果內(nèi)部單元測試要求不是很嚴(yán)格,我們保證對外的API進(jìn)行完全測試即可,因為API會調(diào)用內(nèi)部的很多方法,姑且把它當(dāng)做是整合測試吧。

下面是一個簡單的例子:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
package org.springboot.sample;
 
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue;
 
import java.util.regex.Matcher;
import java.util.regex.Pattern;
 
import org.hamcrest.Matchers;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Ignore;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.test.SpringApplicationConfiguration;
import org.springframework.boot.test.TestRestTemplate;
import org.springframework.boot.test.WebIntegrationTest;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.util.LinkedMultiValueMap;
import org.springframework.util.MultiValueMap;
import org.springframework.web.client.RestTemplate;
 
/**
 *
 * @author  單紅宇(365384722)
 * @create  2016年2月23日
 */
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = SpringBootSampleApplication.class)
//@WebAppConfiguration // 使用@WebIntegrationTest注解需要將@WebAppConfiguration注釋掉
@WebIntegrationTest("server.port:0")// 使用0表示端口號隨機(jī),也可以具體指定如8888這樣的固定端口
public class HelloControllerTest {
 
  private String dateReg;
  private Pattern pattern;
  private RestTemplate template = new TestRestTemplate();
  @Value("${local.server.port}")// 注入端口號
  private int port;
 
  @Test
  public void test3(){
    String url = "http://localhost:"+port+"/myspringboot/hello/info";
    MultiValueMap<String, Object> map = new LinkedMultiValueMap<String, Object>();
    map.add("name", "Tom");
    map.add("name1", "Lily");
    String result = template.postForObject(url, map, String.class);
    System.out.println(result);
    assertNotNull(result);
    assertThat(result, Matchers.containsString("Tom"));
  }
 
}

6、捕獲輸出

使用 OutputCapture 來捕獲指定方法開始執(zhí)行以后的所有輸出,包括System.out輸出和Log日志。

OutputCapture 需要使用@Rule注解,并且實例化的對象需要使用public修飾,如下代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = SpringBootSampleApplication.class)
//@WebAppConfiguration // 使用@WebIntegrationTest注解需要將@WebAppConfiguration注釋掉
@WebIntegrationTest("server.port:0")// 使用0表示端口號隨機(jī),也可以具體指定如8888這樣的固定端口
public class HelloControllerTest {
 
  @Value("${local.server.port}")// 注入端口號
  private int port;
 
  private static final Logger logger = LoggerFactory.getLogger(StudentController.class);
 
  @Rule
  // 這里注意,使用@Rule注解必須要用public
  public OutputCapture capture = new OutputCapture();
 
  @Test
  public void test4(){
    System.out.println("HelloWorld");
    logger.info("logo日志也會被capture捕獲測試輸出");
    assertThat(capture.toString(), Matchers.containsString("World"));
  }
}

關(guān)于Assert類中的一些斷言方法,都很簡單,本文不再贅述。

但是在新版的Junit中,assertEquals 方法已經(jīng)被廢棄,它建議我們使用assertArrayEquals,旨在讓我們測試一個方法的時候多傳幾種參數(shù)進(jìn)行多種可能性測試。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://blog.csdn.net/catoop/article/details/50752964

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 免费看美女被靠到爽的视频 | 国内老司机精品视频在线播出 | 黑人biglackon10十 | 久久视频精品3线视频在线观看 | 免费在线观看伦理片 | 暖暖 免费 高清 日本 中文 | 久久精品一区二区三区资源网 | 欧美性videossex丝袜 | 草免费视频 | 国产三区二区 | 日本色吧 | 国产高清免费午夜在线视频 | 偷拍自拍校园春色 | 校花被老头夺去第一次动图 | 日本高清va不卡视频在线观看 | 欧美丝袜foot job | 国产欧美一区二区三区久久 | 国产成人精品曰本亚洲78 | 欧美一区二区三区成人看不卡 | 逼123| 亚洲国产精品久久精品成人网站 | 国产美女在线一区二区三区 | 国内久久精品视频 | 免费yjsp妖精com | 午夜福到在线2019 | 国产剧情麻豆刘玥视频 | 亚洲天堂在线视频观看 | 大伊香蕉精品视频一区 | 欧美午夜网站 | 香蕉精品视频 | 久久精品动漫网一区二区 | 亚洲一二三区久久五月天婷婷 | 99国产高清久久久久久网站 | 俄罗斯毛片免费大全 | 男人与雌性宠物交啪啪小说 | 久见久热 这里只有精品 | 国产在线精品一区二区高清不卡 | 国产一区二区视频在线 | 欧美人在线一区二区三区 | 成年人网站免费在线观看 | 日韩精品免费一区二区三区 |