什么是參數關聯?
參數關聯,也叫接口關聯,即接口之間存在參數的聯系或依賴。在完成某一功能業務時,有時需要按順序請求多個接口,此時在某些接口之間可能會存在關聯關系。比如: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 pytestdef 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).texttradeNo = 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).textres_pay = json.loads(res_pay)# 斷言assert res_pay["code"]==0assert res_pay["data"]["payNo"]assert res_pay["data"]["certificate"]if __name__ == '__main__':pytest.main()
上面的代碼只是流水式的進行調用,我們還可以先將每個接口請求封裝成單獨的函數,在測試用例中只需按照順序調用這些函數即可,這個我們會在后續的文章中進行說明。
2. 使用Fixture
函數
pytest中Fixture
函數
定義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).texttradeNo = json.loads(res_order)["tradeNo"]yield tradeNo
在測試函數中調用上面定義的fixture函數,代碼示例如下:
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).textres_pay = json.loads(res_pay)# 斷言assert res_pay["code"] == 0assert res_pay["data"]["payNo"]assert res_pay["data"]["certificate"]
三. 總結
參數關聯在接口自動化測試中是必然會遇到的場景,設計關聯參數的用例會直接影響到用例的維護,當然這也是在接口自動化項目的架構設計時就需要考慮的問題。
對于剛入門的同學而言,我們需要明白的是,什么是參數關聯,以及可以怎樣去處理它。
總結:
感謝每一個認真閱讀我文章的人!!!
作為一位過來人也是希望大家少走一些彎路,如果你不想再體驗一次學習時找不到資料,沒人解答問題,堅持幾天便放棄的感受的話,在這里我給大家分享一些自動化測試的學習資源,希望能給你前進的路上帶來幫助。
軟件測試面試文檔
我們學習必然是為了找到高薪的工作,下面這些面試題是來自阿里、騰訊、字節等一線互聯網大廠最新的面試資料,并且有字節大佬給出了權威的解答,刷完這一套面試資料相信大家都能找到滿意的工作。
?
文檔獲取方式:
加入我的軟件測試交流群:822269834免費獲取~(同行大佬一起學術交流,每晚都有大佬直播分享技術知識點)
這份文檔,對于想從事【軟件測試】的朋友來說應該是最全面最完整的備戰倉庫,這個倉庫也陪伴我走過了最艱難的路程,希望也能幫助到你!
以上均可以分享,只需要你搜索vx公眾號:程序員雨果,即可免費領取