SpringBoot+TestNG單元測(cè)試的實(shí)現(xiàn)
背景
由于開發(fā)任務(wù)進(jìn)度緊張,接口及基礎(chǔ)數(shù)據(jù)提供不全,即使設(shè)計(jì)全面的接口測(cè)試用例也無法全面有效的進(jìn)行覆蓋測(cè)試;且又因?yàn)閱谓涌跍y(cè)試用例設(shè)計(jì)的方向是入?yún)⒑统鰠?,從入?yún)⒅志褪菂?shù)必填校驗(yàn)、參數(shù)類型及參數(shù)邊界值,再有入?yún)⒌慕M合入?yún)ⅲ缫粋€(gè)接口5個(gè)參數(shù),3個(gè)必填,2個(gè)非必填,數(shù)據(jù)類型有string、int等,還有字符長(zhǎng)度限制條件,那么這樣的單接口測(cè)試用例數(shù)設(shè)計(jì)起來那就有,嗯......數(shù)不過來,如果入?yún)€(gè)數(shù)及參數(shù)類型變得多起來,那么這個(gè)數(shù)量就不可言喻了,所以,這就需要考量測(cè)試人員對(duì)于接口測(cè)試用例設(shè)計(jì)的方法掌握程度。
接口測(cè)試用例,針對(duì)入?yún)⑦M(jìn)行設(shè)計(jì):
1、數(shù)值類型的參數(shù)
等價(jià)類劃分:取值范圍內(nèi)、取值范圍外,這個(gè)怎么理解?
如果接口文檔有描述這個(gè)參數(shù)應(yīng)該取哪幾個(gè)值或區(qū)間,就在這里規(guī)定的范圍內(nèi)外取舍
邊界值分析:最大最小剛剛好、最大+1、最小-1,這是從取值范圍找邊界,其中最大最小是數(shù)據(jù)類型邊界
特殊值設(shè)計(jì):0或非正數(shù)、可能設(shè)計(jì)小數(shù)
遍歷:無捷徑,窮盡其取值區(qū)間,這個(gè)一般會(huì)被等價(jià)類、邊界值給過濾掉,不必窮盡;
2、字符串類型
字符串長(zhǎng)度
等價(jià)類:取值區(qū)間內(nèi)外
邊界值:規(guī)定范圍邊界;類型邊界
特殊值:這個(gè)需要與字符串類型的特殊字符區(qū)分,這里指的是0或空字符串、null
字符串內(nèi)容
特定類型:中英文、大小寫、簡(jiǎn)繁體
特殊字符:emoji表情符、標(biāo)點(diǎn)符號(hào)運(yùn)算符號(hào)、輸入法的其他特殊字符
3、少見的數(shù)組或鏈表類型:例如list類型,可能是int[]\也可以是string[],他的設(shè)計(jì)方法也逃不過上面的幾種,這里就不再贅述了。
針對(duì)業(yè)務(wù)邏輯進(jìn)行設(shè)計(jì)、針對(duì)出參進(jìn)行設(shè)計(jì)等這些方面,尤其是業(yè)務(wù)邏輯一般采取正向用例設(shè)計(jì),少量通過入?yún)⒃O(shè)計(jì)異常場(chǎng)景,出參的設(shè)計(jì)幾乎在入?yún)⒃O(shè)計(jì)都能得到期望結(jié)果。
言歸正傳!
1、本地使用eclipse作為java開發(fā)工具,同時(shí)支持python環(huán)境編程,所以不想同時(shí)使用Pycharm和IDEA;
<!-- 首先創(chuàng)建springboot框架的maven項(xiàng)目pom添加如下依賴,ide可以安裝插件:spring assistant,一鍵創(chuàng)建springboot框架的maven項(xiàng)目 --> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.4.0</version><!-- 2.3.0.RELEASE版本可選 --> <relativePath/> <!-- lookup parent from repository --> </parent> <!-- springboot框架的主要依賴 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.4.0</version> </dependency>
tips:@SpringBootApplication\@RestController\@RequestMapping等等注解
2、導(dǎo)入本地開發(fā)環(huán)境,eclipse需要外部安裝lombok插件,eclipse配置文件eclipse.ini最下添加參數(shù):-javaagent:lombok.jar,附下載地址,除了安裝以外,且java團(tuán)隊(duì)是否在pom中配置了依賴
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
<optional>true</optional>
</dependency>
3、我是測(cè)試人員,原來的環(huán)境中已經(jīng)安裝了jacoco插件,所以在maven項(xiàng)目中也增加了插件<順帶提一下做java測(cè)試代碼覆蓋率的另一個(gè)依賴cobertura>:
<!-- 順帶提一下的另一個(gè)做代碼覆蓋率檢測(cè)的插件 -->
<dependency>
<groupId>org.codehaus.mojo</groupId>
<artifactId>cobertura-maven-plugin</artifactId>
<version>2.7</version>
</dependency>
<plugin>
<groupId>org.jacoco</groupId>
<artifactId>jacoco-maven-plugin</artifactId>
<version>0.8.3</version>
<configuration>
<!--指定生成 .exec 文件的存放位置 -->
<destFile>target/coverage-reports/jacoco-unit.exec</destFile>
<!--Jacoco 是根據(jù) .exec 文件生成最終的報(bào)告,所以需指定 .exec 的存放路徑 -->
<dataFile>target/coverage-reports/jacoco-unit.exec</dataFile>
</configuration>
<executions>
<execution>
<id>jacoco-initialize</id>
<goals>
<goal>prepare-agent</goal>
</goals>
</execution>
<execution>
<id>jacoco-site</id>
<phase>package</phase>
<goals>
<goal>report</goal>
</goals>
</execution>
</executions>
</plugin>
<!-- tips:jacoco在maven中執(zhí)行的命令是:mvn clean jacoco:prepare-agent install jacoco:report -Dmaven.test.failure.ignore=true -->
4、之前使用java輔助jmeter測(cè)試的時(shí)候,習(xí)慣了testng單元測(cè)試框架,并且還沒在springboot框架上做單元測(cè)試,所以pom文件中還需添加如下依賴:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/org.testng/testng -->
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.9.10</version>
</dependency>
<!-- 右鍵選擇Coverage as 執(zhí)行框架即可,運(yùn)行完在指定目錄或當(dāng)前控制臺(tái)查看覆蓋率 -->
5、開發(fā)習(xí)慣使用junit4.x做單元測(cè)試,其中也是會(huì)使用spring-boot-starter-test這個(gè)插件,只是繼承的類不一樣;
# junit4.x是如下使用:
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
@SpringBootTest
@RunWith(SpringRunner.class)
public class BaseTest {
}
# 而換成testng就是如下使用:
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.testng.AbstractTestNGSpringContextTests;
@SpringBootTest
public class BaseTest extends AbstractTestNGSpringContextTests {
}
# 同樣是使用@SpringBootTest注解,但是它啟動(dòng)sprintboot服務(wù)不一樣,testng必須繼承AbstractTestNGSpringContextTests使用;
# 擴(kuò)展:還可以是繼承AbstractTransactionalTestNGSpringContextTests類,二選一;
# @SpringBootTest(classes={是你的SpringBoot啟動(dòng)app類}),例如:@SpringBootTest(classes=UserApplication.class)
6、至此,就可以在eclipse上按Ctrl+1,將junit框架的測(cè)試用例轉(zhuǎn)換成testng框架愉快的測(cè)試了:Convert to TestNG(Annotations);
7、拓展:添加swagger依賴,生成接口文檔;lombok依賴支持聲明字段的getter和setter方法,同樣有集成Log日志等工具。
剩下的就不要看我這邊文章了,要看你自己的發(fā)揮了,單元測(cè)試案例如下:
package com.text;
import xxx.xxx.xxx
public TestSampler extends BaseTest{
@BeforeClass
void bf(){
// 測(cè)試寫測(cè)試的前置條件,那些只需要執(zhí)行一次的數(shù)據(jù)
}
@Test
void test_add(){
// 這里寫需要測(cè)試的代碼
}
// 。。。
}
到此這篇關(guān)于SpringBoot+TestNG單元測(cè)試的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)SpringBoot TestNG單元測(cè)試內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
logback的AsyncAppender高效日志處理方式源碼解析
這篇文章主要為大家介紹了logback的AsyncAppender高效日志處理方式源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10
利用maven命令指定配置文件打包springboot項(xiàng)目
這篇文章主要介紹了利用maven命令指定配置文件打包springboot項(xiàng)目,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
Spring?Boot如何通過Actuator顯示git和build的信息
這篇文章主要介紹了Spring?Boot通過Actuator顯示git和build的信息,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01
Java后臺(tái)通過Collections獲取list集合中最大數(shù),最小數(shù)代碼
這篇文章主要介紹了Java后臺(tái)通過Collections獲取list集合中最大數(shù),最小數(shù)代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-08-08

