本文章轉(zhuǎn)載于搜狗測(cè)試
被測(cè)試服務(wù)請(qǐng)求第三方服務(wù)荣赶,針對(duì)第三方服務(wù)的響應(yīng)進(jìn)行異常容錯(cuò)測(cè)試是后端服務(wù)典型的測(cè)試場(chǎng)景。測(cè)試環(huán)境直接搭建第三方服務(wù)刽虹,從被測(cè)服務(wù)發(fā)送請(qǐng)求給第三方服務(wù)模擬異常情況十分困難酗捌。因此,測(cè)試通常采用直接配置Json文件或PHP跳轉(zhuǎn)到Json文件的方式模擬第三方服務(wù)返回異常數(shù)據(jù)涌哲;一方面胖缤,不同第三方服務(wù)需要配置不同的Json文件,管理多種Json文件路徑十分麻煩阀圾;另一方面哪廓,部分場(chǎng)景下被測(cè)服務(wù)認(rèn)為PHP跳轉(zhuǎn)的方式為失敗的情況與預(yù)期測(cè)試結(jié)果不符,需要通過(guò)其他方式解決初烘。為了解決上述問(wèn)題涡真,本文引入WireMock工具模擬第三方服務(wù)響應(yīng)。
WireMock有兩種使用方法肾筐,即在測(cè)試代碼中引用WireMock的庫(kù)文件和Jar包的方式使用哆料。Jar包的方式比較輕便,本文主要介紹WireMockjar包的使用方法局齿。
一剧劝、 搭建wiremock環(huán)境
1.下載wiremock-1.57-standalone.jar
2.啟動(dòng)wiremock
執(zhí)行命令 java -jar wiremock-1.57-standalone.jar -port 9999 –verbose
相關(guān)參數(shù)說(shuō)明:
–port: 用來(lái)設(shè)置wiremock監(jiān)聽(tīng)端口號(hào)橄登,不指定端口的話默認(rèn)是8080
-verbose: 打印日志用的
執(zhí)行命令啟動(dòng)后抓歼,可以看到打印的日志,如下圖拢锹。
啟動(dòng)后在同目錄下會(huì)生成兩個(gè)空的文件夾:files和mappings谣妻。mappings文件夾放匹配第三方服務(wù)的匹配規(guī)則,files文件夾放滿足某個(gè)規(guī)則后具體第三方服務(wù)的返回?cái)?shù)據(jù)卒稳。
注意mapping文件有改動(dòng)后蹋半,都需要重啟服務(wù)才能生效。
二充坑、 wiremock使用實(shí)例
Wiremock支持的HTTP方法比較廣泛减江,包括GET, POST, PUT, DELETE, HEAD, TRACE, OPTIONS等染突,自定義頭、數(shù)據(jù)模板(bodyPatterns辈灼,如不符合份企,拋出404錯(cuò)誤),URL Template巡莹,Query參數(shù)匹配司志,顯示指定文件內(nèi)容等。本文總結(jié)了幾種實(shí)用的方法降宅,具體如下:
1.mappings文件夾用法
Mappings文件夾下可以直接創(chuàng)建以.json結(jié)尾的文件骂远,用來(lái)匹配第三方url并返回具體響應(yīng)數(shù)據(jù)。mappings文件夾下json文件如下圖:
mappings主要由2部分構(gòu)成:request腰根、response激才。request是要匹配的請(qǐng)求信息,根據(jù)需要一般包括url(請(qǐng)求url)额嘿、method(請(qǐng)求方式)和header(請(qǐng)求頭)等贸营。response是匹配后返回的響應(yīng)信息,一般包括status(響應(yīng)狀態(tài)碼)和body(響應(yīng)內(nèi)容)等岩睁。
Url匹配規(guī)則有url完全匹配和url不完全匹配钞脂。假設(shè)啟動(dòng)wiremock監(jiān)聽(tīng)端口是9999。
1) url完全匹配:
{
"request": {
"url":"/gethomepagechannel_rec?mid=4f62f2ecb30f62f10ee61091fc2e35eabc0deac229ed",
"method":"POST"
},
"response": {
"status":200,
"body":""
}
}
會(huì)匹配url:http://host:9999/gethomepagechannel_rec?mid=4f62f2ecb30f62f10ee61091fc2e35
eabc0deac229ed的請(qǐng)求捕儒,對(duì)應(yīng)響應(yīng)就會(huì)返回response的body內(nèi)容冰啃。
2) url不完全匹配:
案例1:
{
"request": {
"urlPattern":"/gethomepagechannel_rec\\?mid=.*",
"method":"POST"
},
"response": {
"status":200,
"body":""
}
}
會(huì)匹配url:http://host:9999/gethomepagechannel_rec?mid=任意值
案例2(url匹配范圍更大):
{
"request": {
"urlPattern":"/gethomepagechannel_rec.*",
"method":"POST"
},
"response": {
"status":200,
"body":""
}
}
會(huì)匹配url:http://host:9999/gethomepagechannel_rec+任意值
比如:1:http://host:9999/gethomepagechannel_rec?e=ok
2:http://host:9999/gethomepagechannel_rec
3:http://host:9999/gethomepagechannel_rec/1?p=0
響應(yīng)body的設(shè)置有2種方式:body直接匹配和body配置成文件。
1) body直接匹配:
{
"request": {
"url":"/gethomepagechannel_rec2?mid=4f62f2ecb30f62f10ee61091fc2e35eabc0deac229ed",
"method":"POST"
},
"response": {
"status":200,
"body":"{\"status\":1,\"msg\":\"\",\"result\":{\"ranks\":[{\"channel_id\":\"1\",\"appendix\":\"1 |0|9|9|android\"},{\"channel_id\":\"1\",\"appendix\":\"2|1|9|9|android\"}],\"more\":{\"channel_id\":\"1024\",\"appendix\":\"1024|更多|1024|9|9|android\"}}}"
}
}
當(dāng)請(qǐng)求匹配上了url刘莹,就會(huì)返回body的內(nèi)容作為響應(yīng)阎毅。
用這種方法時(shí)需要注意,body的取值不是直接放上第三方響應(yīng)內(nèi)容点弯,而是需要把其轉(zhuǎn)成字符串并且轉(zhuǎn)義(推薦使用這個(gè)工具h(yuǎn)ttp://www.bejson.com/zhuanyi/?扇调,進(jìn)入后點(diǎn)擊壓縮并轉(zhuǎn)義即可)。
2) body配置成文件:使用bodyFileName參數(shù)抢肛。
{
"request": {
"urlPattern":"/gethomepagechannel_rec\\?mid=.*",
"method":"POST"
},
"response": {
"status":200,
"bodyFileName":"homepagechannel_rec.json"
}
}
當(dāng)請(qǐng)求匹配上了url狼钮,就會(huì)返回homepagechannel_rec.json的內(nèi)容作為響應(yīng)。
使用該參數(shù)的好處是捡絮,可以直接把第三方服務(wù)的響應(yīng)拿過(guò)來(lái)用熬芜,不需要轉(zhuǎn)成字符串并轉(zhuǎn)義。
模擬服務(wù)超時(shí):使用參數(shù)fixedDelayMilliseconds(單位毫秒)
{
"priority":1,
"request": {
"urlPattern":"/channel_rec\\?mid=2.*",
"method":"POST"
},
"response": {
"status":504,
"fixedDelayMilliseconds":400
}
}
模擬服務(wù)返回404:
{
"priority":1,
"request": {
"urlPattern":"/channel_rec\\?mid=1.*",
"method":"POST"
},
"response": {
"status":404,
"jsonBody": {"status":"Error","message":"Endpoint not found"},
"headers": {
"Content-Type":"application/json"
}
}
}
2.__files文件夾用法
files主要配合mappings使用福稳,當(dāng)mappings文件夾下配置bodyFileName參數(shù)時(shí)涎拉,其值即files文件夾下具體響應(yīng)數(shù)據(jù)文件的相對(duì)路徑。
比如mappings文件夾下某json文件:
{
"priority":1,
"request": {
"urlPattern":"/channel_rec\\?mid=8.*",
"method":"POST"
},
"response": {
"status":200,
"bodyFileName":"homepagechannelrec/homepagechannel_rec.json"
}
}
這時(shí)要把文件homepagechannel_rec.json放在__files/ homepagechannelrec目錄下。