一、什麼是參數關聯?
參數關聯,也叫接口關聯,即接口之間存在參數的聯系或依賴。在完成某一功能業務時,有時需要按順序請求多個接口,此時在某些接口之間可能會存在關聯關系。比如:B接口的某個或某些請求參數是通過調用A接口擷取的,即需要先請求A接口,從A接口的傳回資料中拿到需要的字段值,在請求B接口時作為請求參數傳入。
二、有哪些場景?
最常見的場景之一便是:請求登入接口後擷取到token值,後續其他接口請求時需要将token作為請求參數傳入。
再比如下單-->支付場景,調用下單接口生成訂單後會傳回訂單号,訂單号傳給支付接口進行支付。
三、參數關聯場景
以最常見的網上購物為例,對應的場景及請求我們可以大緻簡化如下(可聯想某寶購物流程):
- 使用者在購物車選擇商品點選【去結算】進入訂單确認頁,訂單确認頁點選【送出訂單】這時會先請求下單接口建立訂單
- 緊接着會拿建立的訂單去請求擷取支付憑證接口,這個接口會調起支付頁面,也就是輸入密碼的支付界面
- 輸入支付密碼後會請求支付服務的支付接口進行實際支付,支付的結果會傳回給請求方,告知是否支付成功
這個流程中涉及到的接口其實都是有關聯的,我們要對整個流程進行測試那麼就需要按順序調用所有這些涉及到的接口。
但這裡我們隻需要弄明白參數關聯,那麼以下單接口和擷取支付憑證接口為例,舉例說明就夠了,即先請求下單接口生成訂單号,再拿這個訂單号去請求擷取支付憑證接口,才能調起支付界面并進行支付。
下單接口如下:
- 接口位址:<伺服器>/trade/order/purchase
- 請求類型:post
請求參數:
{
"goodsId": 10, //商品id
"goodsSkuId": 33, //sku id
"num": 2, //購買數量
"tradePromotion": { //選擇的優惠項
"type": 1, //類型<1:優惠券>
"promotionId": 1 //優惠id
}
}
傳回值data:
{
"code": 0,
"msg": "成功",
"data": {
"tradeNo": "0020220116204344962706666" //交易訂單号
},
"t": 1639658625474
}
擷取支付憑證接口如下:
- 接口位址:<伺服器>/pay/pre/consum
- 請求類型:post
請求參數:
{
"orderNo":"0020220116204344962706666", //交易訂單号
"product":"alipayWapClient" //支付管道<alipayWapClient:支付寶手機網頁支付>
}
傳回值 data:
{
"code": 0,
"msg": "成功",
"data": {
"payNo":"123213213219379213",
"certificate": "<form name=\"punchout_form\" method=\"post\" action=\"https://openapi.alipay.com/gateway.do?charset=UTF-8&method=alipay.trade.wap.pay&sign=aTKlfEnYgR7x9xs1Eyjipo0S%2BFtQ6AKu9d%2Brb7iieMThz2Dq7zp4h8QH4lelTKovOloT%2FPiNXR5miwKgOWW3K6pl0TFO5XX5NSZNBmU%2BPd5ogeo0YT0vCqWUM60rqbYLNtZmvyx%2BAR4Z2SOnqs0CYqVIbZAhpn1Bd5HsdcCCYVgsgOdbEE60Cfu3LG3Z%2FQ0GQIdW24uTyr%2BojRc25ipOC9NIYwtba8UjRw18Z3e7sj75qoIg%2FipICH7FCJBJEdlgBGlNxIjKzhYj4OBg93D&return_url=https%3A%2F%2Fblog.csdn.net%2Fa032788aotify_url=http%3A%2F%2F82.157.145.132%3A8089%2Ftest%2Fnotify%2Fgateway&version=1.0&app_id=2021001105644746&sign_type=RSA2×tamp=2021-150&alipay_sdk=alipay-sdk-java-4.9.5.ALL&format=json\">\n<input type=\"hidden\" name=\"biz_content\" value=\"{"time_expire":"2022-12-31 22:00:00","out_trade_no":"123213213219379213","total_amount":0.01,"subject":"測試商品","product_code":"QUICK_WAP_WAY"}\">\n<input type=\"submit\" value=\"立即支付\" style=\"display:none\" >\n</form>\n<script>document.forms[0].submit();</script>"
},
"t": 1639659171031
}
其中orderNo字段使這兩個接口關聯了起來。因為每次生成的訂單号都不一樣,是以在測試這個場景的時候,就需要使這兩個接口的參數進行關聯,才能走通。
四、腳本編寫
那麼在pytest架構的自動化測試中,參數關聯可以怎樣處理呢?這裡提供兩種思路,如下:
- 根據業務場景的調用時序,在用例中按順序調用接口
- 将依賴的接口編寫成fixture函數,并使用yield傳回下個接口需要的參數
1、在用例中按順序調用
代碼示例如下:
import requests
import json
import pytest
def test_order_pay():
'''
建立訂單->擷取支付憑證,調起支付界面
:return:
'''
# 先調用下單接口生成訂單
url_order = "https://gouwu.com/trade/order/purchase"
data_order = {
"goodsId": 10,
"goodsSkuId": 33,
"num": 2,
"tradePromotion": {
"type": 1,
"promotionId": 1
},
"tradeDirectionArticle": {
"articleId": 1
}
}
res_order = requests.post(url=url_order, json=data_order).text
tradeNo = json.loads(res_order)["tradeNo"]
# 再請求擷取支付憑證接口
url_pay = "https://gouwu.com/pay/pre/consum"
data_pay = {
"orderNo": tradeNo, # tradeNo通過下單接口擷取
"product": "alipayWapClient"
}
res_pay = requests.post(url=url_pay, json=data_pay).text
res_pay = json.loads(res_pay)
# 斷言
assert res_pay["code"]==0
assert res_pay["data"]["payNo"]
assert res_pay["data"]["certificate"]
if __name__ == '__main__':
pytest.main()
2、 使用Fixture函數
@pytest.fixture()
def get_order():
'''
請求下單接口,建立訂單
:return:
'''
url_order = "https://gouwu.com/trade/order/purchase"
data_order = {
"goodsId": 10,
"goodsSkuId": 33,
"num": 2,
"tradePromotion": {
"type": 1,
"promotionId": 1
},
"tradeDirectionArticle": {
"articleId": 1
}
}
res_order = requests.post(url=url_order, json=data_order).text
tradeNo = json.loads(res_order)["tradeNo"]
yield tradeNo
def test_pay(get_order):
'''
下單->支付場景校驗
:param get_order: 調用上面的Fixture函數,函數名get_order即傳回的tradeNo
:return:
'''
url_pay = "https://gouwu.com/pay/pre/consum"
data_pay = {
"orderNo": get_order, # get_order即為上面定義的fixture函數傳回值
"product": "alipayWapClient"
}
res_pay = requests.post(url=url_pay, json=data_pay).text
res_pay = json.loads(res_pay)
# 斷言
assert res_pay["code"] == 0
assert res_pay["data"]["payNo"]
assert res_pay["data"]["certificate"]