Java基于rest assured實(shí)現(xiàn)接口測試過程解析
背景
java程序員一般寫的是后端服務(wù)是JavaWeb類型的項(xiàng)目,主要包括Http接口和dubbo接口,Http接口一般采用的rest風(fēng)格,那么如何快速的對rest接口在第三方的測試框架上進(jìn)行測試呢?
rest-assured框架是一個(gè)不錯(cuò)的工具。
使用之前,需要熟悉一下最基礎(chǔ)的使用方法,在寫完幾個(gè)接口的測試用例之后,好比你可以使用你的三棱軍刺熟練的進(jìn)行基礎(chǔ)的攻擊了。
快速的來一個(gè)hello world吧!
假設(shè)你寫了一個(gè)接口:lotto,訪問路徑是: http://localhost:8080/lotto
接口返回值是:
{
"lotto":{
"lottoId":5,
"winning-numbers":[2,45,34,23,7,5,3],
"winners":[{
"winnerId":23,
"numbers":[2,45,34,23,3,5]
},{
"winnerId":54,
"numbers":[52,3,12,11,18,22]
}]
}
}
如何快速的驗(yàn)證接口是否返回正常值呢?
get("/lotto").then().body("lotto.winners.winnerId", hasItems(23, 54));
使用簡單吧!
引入
不多說,直接maven的方式引入:注意,我直接按照默認(rèn)的scope引入的,不是test;
主要引入以下2個(gè)依賴,原因如下:
rest-assured: 主要測試基本的http的rest風(fēng)格接口,這個(gè)是最基礎(chǔ)的依賴;
json-path: 主流的接口主要返回json,對接口進(jìn)行測試用例測試,主要也是判斷json返回某路徑下的數(shù)據(jù);
<dependency> <groupId>io.rest-assured</groupId> <artifactId>rest-assured</artifactId> <version>4.2.0</version> </dependency> <dependency> <groupId>io.rest-assured</groupId> <artifactId>json-path</artifactId> <version>4.2.0</version> </dependency>
然后你就可以愉快的編寫測試用例,然后使用rest-assured進(jìn)行接口測試了。
使用要點(diǎn)
先上簡單代碼吧!
先準(zhǔn)備測試數(shù)據(jù):
final TestCaseDataModel<LoginRestReq> testCaseDataModel = new TestCaseDataModel<>();
final LoginRestReq loginRestReq = LoginRestReq.builder()
.appId("2a6bf452219cfe44c7f78231e3c80a13072b6727")
.nonce("123456")
.timestamp(System.currentTimeMillis())
.userId("lxlifuchun")
.userName("李福春")
.build();
String appSecret = "91e47f584dae551170ade272b2c7a69f";
loginRestReq.setChecksum(SignUtils.generateCheckSum(loginRestReq.getAppId(), appSecret, loginRestReq.getTimestamp(), loginRestReq.getNonce()));
testCaseDataModel.setInputParam(loginRestReq);
ExpectModel expectModel = new ExpectModel();
expectModel.setPath("data.id");
expectModel.setMatcher(Matchers.lessThan(0));
testCaseDataModel.setExpectResult(Arrays.asList(expectModel));
RestAssured.baseURI = "https://rest-beta.xxx.com";
final ValidatableResponse validatableResponse = given().contentType(ContentType.JSON)
.header("requestId", UUID.randomUUID().toString())
.body(testCaseData.getInputParam()).
post("/user_service/user/login")
.then().contentType(ContentType.JSON);
for (Object obj : testCaseData.getExpectResult()) {
ExpectModel item = (ExpectModel) obj;
validatableResponse.body(item.getPath(), item.getMatcher());
}
做的事情很簡單,就是拿一個(gè)登錄接口來實(shí)際的試一下:
login接口接受一個(gè)json的參數(shù),LoginRestReq對下轉(zhuǎn)換之后得到;
然后返回?cái)?shù)據(jù),數(shù)據(jù)中有一個(gè)用戶id,路徑是 data.id,如果id大于0,標(biāo)識登錄操作成功,登錄接口正常。
很好的完成了接口的測試,如果失敗,會(huì)拋出錯(cuò)誤,捕獲錯(cuò)誤,然后輸出信息,標(biāo)識測試用例不通過,提示到界面或者發(fā)送郵件給到開發(fā)人員,即完成了接口的自動(dòng)化測試。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Boot 部署過程解析(jar or war)
這篇文章主要介紹了Spring Boot 部署過程解析(jar or war),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
Java 程序里transient關(guān)鍵字使用方法示例
這篇文章主要為大家介紹了Java 程序里transient關(guān)鍵字使用方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11
Java多線程 Callable、Future 和FutureTask
這篇文章主要介紹Java多線程中的 Callable、Future 以及FutureTask,下面文章圍繞Java多線程的相關(guān)資料展開全文詳細(xì)內(nèi)容,需要的朋友可以參考一下2021-10-10
SpringBoot實(shí)現(xiàn)權(quán)限驗(yàn)證的示例步驟
權(quán)限驗(yàn)證是一種用于控制對系統(tǒng)資源和操作的訪問的機(jī)制。它允許開發(fā)人員定義誰可以執(zhí)行特定操作或訪問特定資源,并確保只有經(jīng)過授權(quán)的用戶才能執(zhí)行這些操作,這篇文章主要介紹了SpringBoot實(shí)現(xiàn)權(quán)限驗(yàn)證,需要的朋友可以參考下2023-08-08
SpringBoot整合POI導(dǎo)出通用Excel的方法示例
這篇文章主要介紹了SpringBoot整合POI導(dǎo)出通用Excel的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
Spring+SpringMVC+MyBatis深入學(xué)習(xí)及搭建(三)之MyBatis全局配置文件解析
這篇文章主要介紹了Spring+SpringMVC+MyBatis深入學(xué)習(xí)及搭建(三)之MyBatis全局配置文件解析,需要的朋友可以參考下2017-05-05
解讀jdk動(dòng)態(tài)代理為什么必須實(shí)現(xiàn)接口
這篇文章主要介紹了解讀jdk動(dòng)態(tài)代理為什么必須實(shí)現(xiàn)接口問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
淺析fastjson2時(shí)間序列化和反序列化的簡單使用
在項(xiàng)目中將fastjson升級為fastjson2后,我們遇到了一些與fastjson不完全兼容的問題,所以本文就來探討下fastjson2的時(shí)間序列化和反序列化的簡單使用吧2025-01-01
java中volatile關(guān)鍵字的作用與實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于java中volatile關(guān)鍵字的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04

