一、介紹
JUnit是一款優(yōu)秀的開(kāi)源Java單元測(cè)試框架,也是目前使用率最高最流行的測(cè)試框架,開(kāi)發(fā)工具Eclipse和IDEA對(duì)JUnit都有很好的支持,JUnit主要用于白盒測(cè)試和回歸測(cè)試。
白盒測(cè)試:把測(cè)試對(duì)象看作一個(gè)打開(kāi)的盒子,程序內(nèi)部的邏輯結(jié)構(gòu)和其他信息對(duì)測(cè)試人
員是公開(kāi)的;回歸測(cè)試:軟件或環(huán)境修復(fù)或更正后的再測(cè)試;
單元測(cè)試:最小粒度的測(cè)試,以測(cè)試某個(gè)功能或代碼塊。一般由程序員來(lái)做,因?yàn)樗枰纼?nèi)部程序設(shè)計(jì)和編碼的細(xì)節(jié);
JUnit GitHub地址:https://github.com/junit-team
二、JUnit使用
開(kāi)發(fā)環(huán)境:
- Spring Boot 2.0.4 RELEASE
- JUnit 4.12
- Maven
- IDEA 2018.2
2.1 檢測(cè)JUnit依賴
如果是Spring Boot項(xiàng)目默認(rèn)已經(jīng)加入了JUnit框架支持,可在pom.xml中查看:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
如果Maven項(xiàng)目中沒(méi)有添加JUnit依賴,可參照如上代碼,手動(dòng)添加。
2.2 基礎(chǔ)使用
簡(jiǎn)單的測(cè)試代碼如下:
@RunWith(SpringRunner.class)
@SpringBootTest
public class SimpleTest {
@Test
public void doTest() {
int num = new Integer(1);
Assert.assertEquals(num, 1);
}
}
在測(cè)試類中郵件運(yùn)行項(xiàng)目,效果如下:
從控制臺(tái)可以看出測(cè)試通過(guò)了。
2.3 注解說(shuō)明
2.3.1 注解列表
- @RunWith:標(biāo)識(shí)為JUnit的運(yùn)行環(huán)境;
- @SpringBootTest:獲取啟動(dòng)類、加載配置,確定裝載Spring Boot;
- @Test:聲明需要測(cè)試的方法;
- @BeforeClass:針對(duì)所有測(cè)試,只執(zhí)行一次,且必須為static void;
- @AfterClass:針對(duì)所有測(cè)試,只執(zhí)行一次,且必須為static void;
- @Before:每個(gè)測(cè)試方法前都會(huì)執(zhí)行的方法;
- @After:每個(gè)測(cè)試方法前都會(huì)執(zhí)行的方法;
- @Ignore:忽略方法;
2.3.2 超時(shí)測(cè)試
代碼如下,給Test設(shè)置timeout屬性即可,時(shí)間單位為毫秒:
@Test(timeout = 1000)
2.4 斷言測(cè)試
斷言測(cè)試也就是期望值測(cè)試,是單元測(cè)試的核心也就是決定測(cè)試結(jié)果的表達(dá)式,Assert對(duì)象中的斷言方法:
- Assert.assertEquals 對(duì)比兩個(gè)值相等
- Assert.assertNotEquals 對(duì)比兩個(gè)值不相等
- Assert.assertSame 對(duì)比兩個(gè)對(duì)象的引用相等
- Assert.assertArrayEquals 對(duì)比兩個(gè)數(shù)組相等
- Assert.assertTrue 驗(yàn)證返回是否為真
- Assert.assertFlase 驗(yàn)證返回是否為假
- Assert.assertNull 驗(yàn)證null
- Assert.assertNotNull 驗(yàn)證非null
代碼示例如下:
@Test
public void doTest() {
String[] string1 = {"1", "2"};
String[] string2 = string1;
String[] string3 = {"1", "2"};
Assert.assertEquals(string1, string2);
Assert.assertEquals(string2, string3);
Assert.assertSame(string1, string2);
Assert.assertSame(string2, string3); //驗(yàn)證不通過(guò),string2、string3指向的引用不同
}
2.5 Web模擬測(cè)試
在Spring Boot項(xiàng)目里面可以直接使用JUnit對(duì)web項(xiàng)目進(jìn)行測(cè)試,Spring 提供了“TestRestTemplate”對(duì)象,使用這個(gè)對(duì)象可以很方便的進(jìn)行模擬請(qǐng)求。
Web測(cè)試只需要進(jìn)行兩步操作:
- 在@SpringBootTest注解上設(shè)置“ebEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT”隨機(jī)端口;
- 使用TestRestTemplate進(jìn)行post或get請(qǐng)求;
示例代碼如下:
@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
public class UserControllerTest {
@Autowired
private TestRestTemplate restTemplate;
@Test
public void getName() {
String name = restTemplate.getForObject("/name", String.class);
System.out.println(name);
Assert.assertEquals("Adam", name);
}
}
其中g(shù)etForObject的含義代表執(zhí)行g(shù)et請(qǐng)求,并返回Object結(jié)果,第二個(gè)參數(shù)設(shè)置返回結(jié)果為String類型,更多的請(qǐng)求方法:
- getForEntity:Get請(qǐng)求,返回實(shí)體對(duì)象(可以是集合);
- postForEntity:Post請(qǐng)求,返回實(shí)體對(duì)象(可以是集合);
- postForObject:Post請(qǐng)求,返回對(duì)象;
2.6 數(shù)據(jù)庫(kù)測(cè)試
在測(cè)試數(shù)據(jù)操作的時(shí)候,我們不想讓測(cè)試污染數(shù)據(jù)庫(kù),也是可以實(shí)現(xiàn)的,只需要添加給測(cè)試類上添加“@Transactional”即可,這樣既可以測(cè)試數(shù)據(jù)操作方法,又不會(huì)污染數(shù)據(jù)庫(kù)了。
示例代碼如下:
@Test
@Transactional
public void saveTest() {
User user = new User();
user.setName("Adam");
user.setAge(19);
user.setPwd("123456");
userRepository.save(user);
System.out.println("userId:" + user.getId());
Assert.assertTrue(user.getId()>0);
}
執(zhí)行效果如下:
我們可以看到Id有了,也測(cè)試通過(guò)了,說(shuō)明數(shù)據(jù)是添加是正常的,但查看數(shù)據(jù)庫(kù)發(fā)現(xiàn)數(shù)據(jù)里面是沒(méi)有這條數(shù)據(jù)的。
如果把“@Transactional”去掉的話,數(shù)據(jù)庫(kù)就會(huì)正常插入了。
2.7 Idea快速開(kāi)啟測(cè)試
在Idea里面可以快速的添加測(cè)試的方法,只需要在要測(cè)試的類里面右鍵選擇“GoTo”點(diǎn)擊“Test”,選擇你需要測(cè)試的代碼,點(diǎn)擊生成即可,如果是Windows 用戶可以使用默認(rèn)快捷鍵“Ctrl + Shift + T”,效果如下圖:
選完方法之后,點(diǎn)擊OK按鈕,就生成了對(duì)應(yīng)的測(cè)試代碼,用戶只需要完善框架里面的具體測(cè)試邏輯就可以了。