Mock

Juno3550發表於2021-09-01

Mock 介紹

什麼是 Mock?

Mock 的意思是模擬,就是在測試過程中,對於某些不容易構造或者不容易獲取的物件,用一個虛擬的物件來建立以便測試的測試方法。

應用場景

這裡分為兩類測試:一類是前端對介面的 Mock,一類是後端單元測試中涉及的 Mock。

  1. 前端對介面返回資料的 Mock:

    • 繞過前端限制,模擬不同場景或條件下的異常測試。
    • 有些系統不支援重複請求,或有訪問訪問頻次限制。如不可重複支付,獲取敏感資訊的介面訪問頻次不可高於 xx 等。
  2. 後端單元測試或介面的 Mock:

    • 某依賴介面或模組還未開發完成,就需要對被測系統進行測試。
    • 無法控制第三方系統某介面的返回。

實現方式

  1. 使用第三方的 Mock 平臺來實現 Mock(收費)
  2. 自己開發一個 Mock 平臺(如 python + flask 實現)
  3. 使用 Mock 工具搭建一個 Mock 平臺(如使用 moco 工具實現 Mock 平臺)

Python + Flask 搭建 Mock 平臺

介紹:Flask 是一個基於 Python 開發的輕量級 Web 應用程式框架。

安裝 Flask:

  • 安裝:pip install Flask
  • 驗證:flask --version

演示案例

  1. 編寫 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()
  1. 啟動伺服器:

    • python py檔名
    • pycharm“執行”
  2. 訪問伺服器:

  • get 訪問 /index 首頁(瀏覽器)
  • post 訪問 /login 登入頁(postman)

image

Moco 框架

介紹

Moco 是一個簡單搭建模擬伺服器的框架(工具):

原理

  • Moco 會根據一些配置,啟動一個真正的 HTTP 服務(會監聽本地的某個埠)。
  • 當發起的請求滿足某個條件時,就會返回指定的響應資料。

環境搭建

  • 安裝:JDK
  • 下載:訪問 moco 下載地址,選擇下載“moco-runner-0.10.0-standalone.jar”

執行示例

  1. 建立配置檔案:
[{
	"description": "首頁",
	"request": {
		"uri": "/index"
	},
	"response": {
	"text": "hello world"
	}
}]
  1. 啟動 HTTP 服務:
java -jar <path-to-moco-runner> http -p <monitor-port> -c <configuration-file>
  • <path-to-moco-runner>:jar 包的路徑
  • <monitor-port>:http 服務監聽的埠
  • <configuration-file>:配置檔案路徑
  1. 訪問所配置的介面。

常用配置引數

定義請求方法

通過 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

相關文章