引言
前面講過三篇文章:
1、Python 接口測試之Excel表格數據操作方法封裝 ;
既然我們接口測試用例寫好了,測試數據也拿到了,那么就是模擬調用接口的方法了,方法有get,post,put,delete,具體是選擇哪種,我們需要根據不同接口規定好請求方法來調用。為了方便,將四種方法封裝到一個類中,每次只需訪問類中某個方法,到達請求的目的。
請求方法封裝
下面就直接附上代碼:
__author__ = 'Leo' import requests import json class ApiRequest(object): """ 請求方法 """ # 請求方法get def get_method(self,url,data=None,header=None): if header is not None: res = requests.get(url,params=data,headers=header) else: res = requests.get(url,params=data) return res.json() # 請求方法post def post_method(self,url,data=None,header=None): global res if header is not None: res = requests.post(url,json=data,headers=header) else: res = requests.post(url,json=data) if str(res) == "<Response [200]>": return res.json() else: return res.text # 請求方法put def put_method(self,url,data=None,header=None): if header is not None: res = requests.put(url,json=data,headers=header) else: res = requests.delete(url, json=data) return res.json() # 請求方法delete def delete_method(self, url, data=None, header=None): if header is not None: res = requests.delete(url, json=data, headers=header) else: res = requests.delete(url, json=data) return res.json() # 主方法 def run_method(self,method,url,data=None,header=None): if method == 'get' or method == 'GET': res = self.get_method(url,data,header) elif method == 'post' or method =='POST': res = self.post_method(url,data,header) elif method == 'put' or method == 'PUT': res = self.post_method(url,data,header) elif method == 'delete' or method == 'DELETE': res = self.post_method(url,data,header) else: res = "你的請求方式不正確!" # return res return json.dumps(res, ensure_ascii=False, indent=4, sort_keys=True,separators=(',', ':'))
簡單的解釋一下相關知識點:
ensure_ascii:默認值True,如果dict內含有non-ASCII的字符,則會類似\uXXXX的顯示數據,設置成False后,就能正常顯示。 indent:應該是一個非負的整型,如果是0,或者為空,則一行顯示數據,否則會換行且按照indent的數量顯示前面的空白,這樣打印出來的json數據也叫pretty-printed json。 separators:分隔符,實際上是(item_separator, dict_separator)的一個元組,默認的就是(‘,’,’:’);這表示dictionary內keys之間用“,”隔開,而KEY和value之間用“:”隔開。 encoding:默認是UTF-8,設置json數據的編碼方式。 sort_keys:將數據根據keys的值進行排序。
執行測試
方法已經封裝好,既然接口數據有了,請求方法也有了,我們不妨測試一下之前封裝好的代碼,用實際行動來檢驗一下:
# get請求 if __name__ == '__main__': url = "http://httpbin.org/get" ir = ApiRequest() result = ir.run_method(url=url,method='get') print(result)
運行結果:
# post請求 url2 = "http://httpbin.org/post" ir2 = ApiRequest() data = {'id': '測試'} result = ir2.run_method(url=url2,method='post',data=data) print(result)
運行結果:
有些細心人可能有疑問,這里沒有使用excel中的接口測試數據,下面我就演示一下,調用excel中維護的接口測試數據,先維護數據:
from basic_method import get_excelData get_data = get_excelData.getData() print("獲取是否運行key: ",get_data.get_is_run(1)) print("獲取接口url: ",get_data.get_url(1)) print("獲取接口請求方法: ",get_data.get_method(1)) print("獲取接口請求數據: ",get_data.get_data(1)) url2 = get_data.get_url(1) method = get_data.get_method(1) data = get_data.get_data(1) ir2 = ApiRequest() result = ir2.run_method(url=url2,method=method,data=data) print(result)
運行結果:
這次就是調用過程是從excel拿的數據,並且通過封裝好的方法請求模擬請求接口。證明此前封裝好的代碼是可以正常運行。
這里獻上另一種請求方法:
總結
上面對接口請求方法封裝已經完成了,並且將之前寫的封裝代碼一起使用,實現了自動化測試框架中核心的代碼,對自動化測試,測試開發感興趣的朋友,同學可以加入QQ測試開發交流群:696400122。相互學習,共同進步!