使用python進行接口測試(二)


    之前使用過urllib和urllib2做接口測試,在做的途中,感覺使用urllib2直接進行的get,post 請求並沒有那么好用。作為測試人員,所需要的測試工具應當以方便為第一要務,測試的耗時只要是真正的無人值守,耗時不是太久的都可以接受。所以,本人又嘗試了一個新的包:requests。  

  Requests 是用Python語言編寫,基於 urllib,采用 Apache2 Licensed 開源協議的 HTTP 庫。它比 urllib 更加方便,可以節約我們大量的工作,完全滿足 HTTP 測試需求。Requests 的哲學是以 PEP 20 的習語為中心開發的,所以它比 urllib 更加 Pythoner。更重要的一點是它支持 Python3 !推薦一篇文章,上面有該包的詳細說明 傳送門,以下只會寫到我用到的部分,所以更多的了解需要自己去搜資料

   好了,我們開始吧!!

  接口測試中重要的部分:

       1.get和post方法

     2.用到的參數

     3.請求頭

     4.cookie

     5.日志輸出

     6.如何調試你的程序--借助fiddler

  按照以上的順序,我將一一說明我的搞法,因為編碼能力有限,所以可能看着很low

一、get和post

  requests包很好的實現了post和get方法,示例:

1 import requests
2 response_get = requests.get(url, data, headers, cookies)
3 response_post = requests.post(url, data, headers, cookies)

  其他的訪問方式如put,head等等,用法幾乎都是如此,因為沒用到,所以省略

  現在一般的接口返回值有頁面和json倆種,按照需求,可以分別使用response.text或者response.content獲取,text獲取的是unicode類型的返回值,而content返回值是str類型,所以我一般使用content來獲取返回值,因為這樣獲取的返回值可以直接使用正則或者in的方式來驗證返回值結果是否正確。

     我自己為了實現接口的自動訪問,所以又在requests上面加了一層封裝,就像下面這樣:

 1 def main_get(list_result, cookies):
 2     """
 3     用於模擬get請求,返回結果
 4     :param list_result:空列表,用於存儲結果
 5     :param cookies: 登陸后的cookie
 6     :return:訪問結果
 7     """
 8     # List_interface_get寫在接口文件里,文件是py格式,然而它本身是字典類型
 9     for key in List_interface_get:
10         try:
11             f1 = requests.get(key, cookies=cookies)
12             if f1:
13                 print f1.content
14                 print List_interface_get[key]+'接口訪問成功'
15                 split_line()
16             list_result.append(f1.content+'||'+key)
17             # print f1.read()
18         except AssertionError:
19             print 'One Error in get'
20             pass
21     return list_result
22 
23 
24 def main_post(result_list, url_list, param_list, payload_list, note_list, cookies):
25     """
26     模擬post請求
27     :param result_list: 結果字典
28     :param url_list: 接口字典
29     :param param_list: 入參字典
30     :param payload_list: header字典
31     :param notelist: 描述字典
32     :param cookies: 登錄獲取的cookie
33     :return:填充完成的結果列表
34     """
35 
36     # post這塊寫的比較low,最好自己搞一個數據結構把它搞定
37     for key in range(1, 9):
38         a = requests.post(url=url_list[key], data=param_list[key], headers=payload_list[key], cookies=cookies)
39         try:
40             if a.content:
41                 print a.content
42                 print note_list[key]+'接口訪問成功'
43                 split_line()
44             result_list.append(a.content+'||'+url_list[key])
45         except AssertionError:
46             print 'One Error in post'
47             pass
48     return result_list

 

二、用到的參數以及請求頭

  我用的方法是把這些都存放於一個py文件中,當然也可以使用excel或者xml文件,甚至於使用DB。項目緊急,湊合了一下,這里的數據結構主要為了符合上面封裝的函數,直接上代碼看吧

 1 BaseURL = 'https://******.com'  # 測試環境
 2 # 使用什么數據結構不重要,關鍵看實現方法中怎么解析你的測試數據
 3 List_interface_get = {
 4     BaseURL+'/api/****/****/****?****=1&****=375': '描述'
 5 }
 6 # 以下是用於post的接口
 7 List_interface_post = {
 8     1: BaseURL+'/api/****/****/****/****'
 9 }
10 # 以下是用於post的數據
11 List_post_param = {
12     1: 'new=222222&old=111111'
13 }
14 # 以下是post接口的描述,它是干嘛的
15 List_post_note = {
16     1: '修改密碼'
17 }
18 # 以下是post用到的請求頭
19 List_post_header= {
20     1: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'}
21 }

 

  三、cookie

  一款產品的接口測試中必定會使用登錄狀態,需要使用cookie實現,之前寫過使用cookiejar獲取cookie,requests中獲取cookie的方法更為簡單,不過首先你得知道是哪個接口set了cookie,不過一般是登錄啦。登錄接口訪問之后set了cookie,那好,就去調用登錄接口,然后拿到搞回來的cookie:

# 只需要這樣!!
login = requests.post(login_url, data=login_data, headers=login_header)
cookie = login.cookies

這個cookie就是登錄狀態了,拿着隨便用,需要登錄的就直接cookies=cookies

     四、日志輸出

  這里注意看第二步中接口數據,有接口描述,也有接口是啥,第一步中又把content做成返回值了,具體拼接方式自己想吧,東西全有了,想寫啥寫啥,還可以加上獲取本地時間的api獲取接口運行時間,log文件該長啥樣是門學問,這里就不獻丑了。

   五、借用fiddler調試你的腳本

     requests允許使用代理訪問,這有啥用,真有!fiddler是一款截包改包的工具,而且通過擴展可以進行請求間的比對,這樣讓你的程序訪問的請求和真正正確的請求作對比,為啥我的程序訪問出錯?是不是缺了請求頭?參數是不是丟了?cookie是不是少了?很容易看出來。寫法如下:

proxies = {
     "http": "http://127.0.0.1:8888",
     "https": "http://127.0.0.1:8888"
}
requests.post(url, proxies=proxies)

這樣就可以走代理了,除fiddler以外還有charles和burp suite可以使用,具體看個人喜好吧。

 

 

                                                           好了,就這樣,菜鳥一枚,歡迎指正

                                                                                                                                                                            -------首席小學生


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM