1、什么是接口Mock測試?
應用場景思考?1.在前后端分離的項目中,假如后端代碼還未開發完,前端代碼需要調用后端接口進行調試,該怎么辦?2.本公司的電商平臺需要對接第三方支付接口,如何測試支付失敗的場景?
1.1、概念
Mock:模擬的、仿制的、虛假的
Mock測試:在測試過程中,對于某些不容易構造或者不容易獲取的對象,可以用一個虛擬的對象來代替的測試方法。接口Mock測試:在接口測試過程中,對于某些不容易構造或者不容易獲取的接口,可以用一個模擬接口來代替。
1.2、作用
- 可以用來解除測試對象對外部服務的依賴,使得測試用例可以獨立運行
- 替換外部服務調用或一些速度較慢的操作,提升測試用例的運行速度
- 模擬異常邏輯,異常邏輯往往很難觸發,通過Mock可以人為的控制觸發異常邏輯
- 團隊可以并行工作
1.3、實現方式
接口mock實現的核心思想是搭建一個Mock Server,通過該服務提供mock接口。常見的實現方式有:
- 使用第三方mock平臺
- 自己開發mock服務
- 使用mock框架搭建mock服務
2. Moco框架
2.1、Moco簡介
- Moco是一個簡單搭建模擬服務器的框架(工具),可以模擬http、https、socket等協議
- 基于Java開發的開源項目,Github地址:https://github.com/dreamhead/moco
- 原理:Moco會根據一些配置,啟動一個真正的HTTP服務(會監聽本地的某個端口)。當發起的請求滿足某個條件時,就會返回指定的響應數據
2.2、環境搭建
Moco運行時所需環境包括:
Java運行環境
安裝JDK,并配置環境變量
moco-runner-1.1.0-standalone.jar
2.3、如何運行Moco
1>創建配置文件創建配置文件test.json,并輸入如下內容:
[
{
"description": "首頁",
"request": {
"uri": "/index"
},
"response": {
"text": "hello world"
}
}
]
2>啟動http服務啟動命令:
示例:
java -jar moco-runner-1.1.0-standalone.jar http -p 9090 -c test.json
- <path-to-moco-runner>:jar包的路徑
- <monitor-port>:http服務監聽的端口
- <configuration-file>:配置文件路徑
3>接口訪問打開瀏覽器,在瀏覽器地址欄中輸入
2.4、Moco常用配置參數
1.定義請求方式,通過method參數定義
[
{
"description": "首頁",
"request": {
"uri": "/index",
"method": "post"
},
"response": {
"text": "hello world"
}
}
]
2.定義請求參數,通過queries參數定義
[
{
"description": "首頁",
"request": {
"uri": "/index",
"method": "get",
"queries": {
"area": "010",
"kw": "hello"
}
},
"response": {
"text": "hello world"
}
}
]
3.定義請求頭,通過headers參數定義
[
{
"description": "登錄",
"request": {
"uri": "/login",
"method": "post",
"headers": {
"area": "010"
}
},
"response": {
"text": "hello world"
}
}
]
4.定義表單請求體,通過forms參數定義
[
{
"description": "登錄",
"request": {
"uri": "/login",
"method": "post",
"forms": {
"username": "tom",
"password": "123456"
}
},
"response": {
"text": "login success"
}
}
]
5.定義JSON請求體,通過json參數定義
[
{
"description": "登錄",
"request": {
"uri": "/login",
"method": "post",
"headers": {
"Content-Type": "application/json"
},
"json": {
"username": "tom",
"password": "123456"
}
},
"response": {
"text": "hello world66666"
}
}
]
6.定義HTTP響應狀態碼,通過status參數定義
[
{
"description": "首頁",
"request": {
"uri": "/index2"
},
"response": {
"status": 500,
"text": "error"
}
}
]
7.定義JSON響應數據,通過json參數定義
[
{
"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支持在配置文件中引入其他配置文件,這樣可以分服務/模塊定義配置文件,便于對配置文件的管理。實現步驟:1.分服務/模塊定義配置文件,如分別定義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.啟動服務
java -jar moco-runner-1.1.0-standalone.jar http -p 8989 -g config.json
注意:通過-g config.json指定配置文件
- 更多測試技術分享、學習資源以及一些其他福利可關注公眾號:【Coding測試】獲取: