更新時間:2020年07月14日16時18分 來源:傳智播客 瀏覽次數(shù):
1、什么是接口Mock測試?
應(yīng)用場景思考?
1.在前后端分離的項目中,假如后端代碼還未開發(fā)完,前端代碼需要調(diào)用后端接口進(jìn)行調(diào)試,該怎么辦?
2.本公司的電商平臺需要對接第三方支付接口,如何測試支付失敗的場景?
1.1 概念
Mock:模擬的、仿制的、虛假的
Mock測試:在測試過程中,對于某些不容易構(gòu)造或者不容易獲取的對象,可以用一個虛擬的對象來代替的測試方法。
接口Mock測試:在接口測試過程中,對于某些不容易構(gòu)造或者不容易獲取的接口,可以用一個模擬接口來代替。
1.2 作用
可以用來解除測試對象對外部服務(wù)的依賴,使得測試用例可以獨立運行
替換外部服務(wù)調(diào)用或一些速度較慢的操作,提升測試用例的運行速度
模擬異常邏輯,異常邏輯往往很難觸發(fā),通過Mock可以人為的控制觸發(fā)異常邏輯
團(tuán)隊可以并行工作
1.3 實現(xiàn)方式
接口mock實現(xiàn)的核心思想是搭建一個Mock Server,通過該服務(wù)提供mock接口。常見的實現(xiàn)方式有:
使用第三方mock平臺
自己開發(fā)mock服務(wù)
使用mock框架搭建mock服務(wù)
2. Moco框架
2.1 Moco簡介
Moco是一個簡單搭建模擬服務(wù)器的框架(工具),可以模擬http、https、socket等協(xié)議
基于Java開發(fā)的開源項目,Github地址:https://github.com/dreamhead/moco
原理:Moco會根據(jù)一些配置,啟動一個真正的HTTP服務(wù)(會監(jiān)聽本地的某個端口)。當(dāng)發(fā)起的請求滿足某個條件時,就會返回指定的響應(yīng)數(shù)據(jù)。
2.2 環(huán)境搭建
Moco運行時所需環(huán)境包括:
Java運行環(huán)境
安裝JDK,并配置環(huán)境變量
moco-runner-1.1.0-standalone.jar
下載地址:https://repo1.maven.org/maven2/com/github/dreamhead/moco-runner/1.1.0/moco-runner-1.1.0-standalone.jar
2.3 如何運行Moco
1>創(chuàng)建配置文件
創(chuàng)建配置文件test.json,并輸入如下內(nèi)容:
[
{
"description": "首頁",
"request": {
"uri": "/index"
},
"response": {
"text": "hello world"
}
}
]
2>啟動http服務(wù)
啟動命令:
java -jar <path-to-moco-runner> http -p <monitor-port> -c <configuration-file>
示例:
java -jar moco-runner-1.1.0-standalone.jar http -p 9090 -c test.json
3>接口訪問
打開瀏覽器,在瀏覽器地址欄中輸入:http://localhost:9090/index
2.4 Moco常用配置參數(shù)
1.定義請求方式,通過method參數(shù)定義
[
{
"description": "首頁",
"request": {
"uri": "/index",
"method": "post"
},
"response": {
"text": "hello world"
}
}
]
2.定義請求參數(shù),通過queries參數(shù)定義
[
{
"description": "首頁",
"request": {
"uri": "/index",
"method": "get",
"queries": {
"area": "010",
"kw": "hello"
}
},
"response": {
"text": "hello world"
}
}
]
3.定義請求頭,通過headers參數(shù)定義
[
{
"description": "登錄",
"request": {
"uri": "/login",
"method": "post",
"headers": {
"area": "010"
}
},
"response": {
"text": "hello world"
}
}
]
4、定義表單請求體,通過`forms`參數(shù)定義
[
{
"description": "登錄",
"request": {
"uri": "/login",
"method": "post",
"forms": {
"username": "tom",
"password": "123456"
}
},
"response": {
"text": "login success"
}
}
]
5、定義JSON請求體,通過`json`參數(shù)定義
[
{
"description": "登錄",
"request": {
"uri": "/login",
"method": "post",
"headers": {
"Content-Type": "application/json"
},
"json": {
"username": "tom",
"password": "123456"
}
},
"response": {
"text": "hello world66666"
}
}
]
6、定義HTTP響應(yīng)狀態(tài)碼,通過`status`參數(shù)定義
[
{
"description": "首頁",
"request": {
"uri": "/index2"
},
"response": {
"status": 500,
"text": "error"
}
}
]
7、定義JSON響應(yīng)數(shù)據(jù),通過json參數(shù)定義
[
{
"description": "登錄",
"request": {
"uri": "/login"
},
"response": {
"headers": {
"Content-Type": "application/json;charset=UTF-8"
},
"json": {
"code": "10000",
"msg": "操作成功",
"data": {
"uid": 2,
"token": "xxx"
}
}
}
}
]
2.5 Moco引入配置文件
moco支持在配置文件中引入其他配置文件,這樣可以分服務(wù)/模塊定義配置文件,便于對配置文件的管理。
實現(xiàn)步驟:
1.分服務(wù)/模塊定義配置文件,如分別定義index.json和login.json文件
[
{
"description": "首頁",
"request": {
"uri": "/index"
},
"response": {
"text": "hello world"
}
}
]
[
{
"description": "登錄",
"request": {
"uri": "/login"
},
"response": {
"text": "success"
}
}
]
2.定義啟動配置文件,如config.json并引入其他配置文件
[
{"include": "index.json"},
{"include": "login.json"}
]
3.啟動服務(wù)
java -jar moco-runner-1.1.0-standalone.jar http -p 9090 -g config.json
注意:通過"-g config.json"指定配置文件
猜你喜歡:
軟件測試培訓(xùn)課程
什么是關(guān)系型數(shù)據(jù)庫?看這張圖就懂了
最全的軟件測試面試題(含答案)