av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

Java基于rest assured實現接口測試過程解析

瀏覽:60日期:2022-09-04 14:36:44

背景

java程序員一般寫的是后端服務是JavaWeb類型的項目,主要包括Http接口和dubbo接口,Http接口一般采用的rest風格,那么如何快速的對rest接口在第三方的測試框架上進行測試呢?

rest-assured框架是一個不錯的工具。

使用之前,需要熟悉一下最基礎的使用方法,在寫完幾個接口的測試用例之后,好比你可以使用你的三棱軍刺熟練的進行基礎的攻擊了。

快速的來一個hello world吧!

假設你寫了一個接口: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] }]}}

如何快速的驗證接口是否返回正常值呢?

get('/lotto').then().body('lotto.winners.winnerId', hasItems(23, 54));

使用簡單吧!

引入

不多說,直接maven的方式引入:注意,我直接按照默認的scope引入的,不是test;

主要引入以下2個依賴,原因如下:

rest-assured: 主要測試基本的http的rest風格接口,這個是最基礎的依賴;

json-path: 主流的接口主要返回json,對接口進行測試用例測試,主要也是判斷json返回某路徑下的數據;

<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進行接口測試了。

使用要點

先上簡單代碼吧!

先準備測試數據:

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()); }

做的事情很簡單,就是拿一個登錄接口來實際的試一下:

login接口接受一個json的參數,LoginRestReq對下轉換之后得到;然后返回數據,數據中有一個用戶id,路徑是 data.id,如果id大于0,標識登錄操作成功,登錄接口正常。

很好的完成了接口的測試,如果失敗,會拋出錯誤,捕獲錯誤,然后輸出信息,標識測試用例不通過,提示到界面或者發送郵件給到開發人員,即完成了接口的自動化測試。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 日本乱轮视频 | 日韩毛片在线观看 | 青青草视频污 | 亚洲欧美国产毛片在线 | 99热最新网址| 成人黄色一级片 | xxxx色 | www色| 少妇一级淫片免费放 | 男人操女人视频网站 | 亚洲午夜剧场 | 曰本一级片 | 一区二区三区高清 | 久久性| 亚洲国产精品成人无久久精品 | 懂色av一区二区夜夜嗨 | 欧美日韩在线视频观看 | 国产伦精品一区二区三区免.费 | 婷色 | 日本黄色视 | 久久狠狠干| 日本一级黄色 | 欧美成人久久 | 日韩成人精品 | 国产黄色在线观看 | 欧美精品二区三区四区免费看视频 | 欧美精品一区二区三区四区 | av网站免费观看 | 欧美日韩视频在线 | 国产精品久久视频 | 麻豆精品一区二区 | 欧美又粗又长 | 伊人影院久久 | 亚洲精品久久 | 欧美日韩成人在线观看 | 国产精品视频一区二区三区 | 国产日韩欧美一区 | 日韩欧美高清视频 | 国产黄色在线观看 | 国产欧美一区二区精品性色超碰 | 加勒比一区二区三区 |