目錄
Mock 介紹
什麼是 Mock?
Mock 的意思是模擬,就是在測試過程中,對於某些不容易構造或者不容易獲取的物件,用一個虛擬的物件來建立以便測試的測試方法。
應用場景
這裡分為兩類測試:一類是前端對介面的 Mock,一類是後端單元測試中涉及的 Mock。
-
前端對介面返回資料的 Mock:
- 繞過前端限制,模擬不同場景或條件下的異常測試。
- 有些系統不支援重複請求,或有訪問訪問頻次限制。如不可重複支付,獲取敏感資訊的介面訪問頻次不可高於 xx 等。
-
後端單元測試或介面的 Mock:
- 某依賴介面或模組還未開發完成,就需要對被測系統進行測試。
- 無法控制第三方系統某介面的返回。
實現方式
- 使用第三方的 Mock 平臺來實現 Mock(收費)
- 自己開發一個 Mock 平臺(如 python + flask 實現)
- 使用 Mock 工具搭建一個 Mock 平臺(如使用 moco 工具實現 Mock 平臺)
Python + Flask 搭建 Mock 平臺
介紹:Flask 是一個基於 Python 開發的輕量級 Web 應用程式框架。
安裝 Flask:
- 安裝:pip install Flask
- 驗證:flask --version
演示案例
- 編寫 Flask 伺服器:
import json
from flask import Flask, request
# 建立一個應用物件
app = Flask(__name__)
# 定義“首頁”檢視函式,設定路由規則
@app.route("/index")
def index():
print("訪問的index主頁")
return "hello mock" # 預設返回"hello mock"給客戶端
# 定義“登入頁”檢視函式
# 假設請求資料為:{"mobile":"13800000002", "password":"123456"}
@app.route("/api/sys/login", methods=["POST"])
def login():
# 將JSON請求資料轉換成字典物件
result = json.loads(request.get_data().decode("utf-8"))
mobile = result.get("mobile")
password = result.get("password")
# 校驗登入手機號和密碼
if mobile == "13800000002" and password == "123456":
data = {
"success": True,
"code": 10000,
"message":"操作成功!",
"token": "ajsdfj-12312-szs-fd-dfs"
}
else:
data = {
"success": False,
"code": 99999,
"message": "抱歉,手機號或密碼有誤,請重試",
"token": None
}
return data # 返回校驗結果給客戶端
if __name__ == '__main__':
# 啟動WEB伺服器
app.run()
-
啟動伺服器:
- python py檔名
- pycharm“執行”
-
訪問伺服器:
- get 訪問 /index 首頁(瀏覽器)
- post 訪問 /login 登入頁(postman)
Moco 框架
介紹
Moco 是一個簡單搭建模擬伺服器的框架(工具):
- 可以模擬 http、https、socket 等協議。
- 是基於 Java 開發的開源專案。(Github 地址:https://github.com/dreamhead/moco)
原理
- Moco 會根據一些配置,啟動一個真正的 HTTP 服務(會監聽本地的某個埠)。
- 當發起的請求滿足某個條件時,就會返回指定的響應資料。
環境搭建
- 安裝:JDK
- 下載:訪問 moco 下載地址,選擇下載“moco-runner-0.10.0-standalone.jar”
執行示例
- 建立配置檔案:
[{
"description": "首頁",
"request": {
"uri": "/index"
},
"response": {
"text": "hello world"
}
}]
- 啟動 HTTP 服務:
java -jar <path-to-moco-runner> http -p <monitor-port> -c <configuration-file>
- <path-to-moco-runner>:jar 包的路徑
- <monitor-port>:http 服務監聽的埠
- <configuration-file>:配置檔案路徑
- 訪問所配置的介面。
常用配置引數
定義請求方法
通過 method 引數指定:
[{
"description": "首頁",
"request": {
"uri": "/index",
"method": "post"
},
"response": {
"text": "post請求的hello world"
}
}]
定義查詢引數
通過 queries 引數定義:
[{
"description": "首頁",
"request": {
"uri": "/index",
"method": "get",
"queries": {
"area": "010",
"kw": "hello"
}
},
"response": {
"text": "query params: hello world"
}
}]
定義請求頭
通過 headers 引數定義:
[{
"description": "登入",
"request": {
"uri": "/login",
"method": "post",
"headers": {
"area": "010"
}
},
"response": {
"text": "set headers: hello world"
}
}]
定義 form 格式的請求體
通過 forms 引數定義表單格式的請求體:
[{
"description": "登入",
"request": {
"uri": "/login",
"method": "post",
"forms": {
"username": "tom",
"password": "123456"
}
},
"response": {
"text": "login success"
}
}]
定義 json 格式的請求體
通過 json 引數定義 json 格式的請求體:
[{
"description": "登入",
"request": {
"uri": "/login",
"method": "post",
"headers": {
"Content-Type": "application/json"
},
"json": {
"username": "tom",
"password": "123456"
}
},
"response": {
"text": "hello world66666"
}
}]
定義響應狀態碼
[{
"description": "首頁",
"request": {
"uri": "/index2"
},
"response": {
"status": 500,
"text": "error"
}
}]
定義 json 格式的響應體
[{
"description": "登入",
"request": {
"uri": "/login"
},
"response": {
"headers": {
"Content-Type": "application/json;charset=UTF-8"
},
"json": {
"code": "10000",
"msg": "操作成功",
"data": {
"uid": 2,
"token": "xxx"
}
}
}
}]
解決中文亂碼問題
定義響應的 Content-Type 型別為 charset=gbk:
[{
"description": "登入",
"request": {
"uri": "/login"
},
"response": {
"headers": {
"Content-Type": "application/json;charset=gbk"
},
"json": {
"code": "10000",
"msg": "操作成功",
"data": {
"uid": 2,
"token": "xxx"
}
}
}
}]
Moco 引入配置檔案
1)首先需要定義被依賴的多個配置檔案,如下 2 個:
login.json 檔案:
[{
"description": "登入",
"request": {
"uri": "/login"
},
"response": {
"text": "success"
}
}]
index.json 檔案:
[{
"description": "首頁",
"request": {
"uri": "/index"
},
"response": {
"text": "hello world"
}
}]
2)定義 config.json 配置檔案,關聯 2 個 json 檔案:
[
{
"include": "index.json"
},
{
"include": "login.json"
}
]
3)根據 config.json 中自定義的相對路徑,把上述 3 個檔案放在同一目錄,並通過 -g 引數指定 config.json 啟動服務:
java -jar moco-runner-0.11.0-standalone.jar http -p 8092 -g config.json