您好,登錄后才能下訂單哦!
前言
之前介紹了接口測試中需要關注得測試點,現在我們來看看如何進行接口測試,現在接口測試工具有很多種,例如:postman,soapui,jemter等等,對于簡單接口而言,或者我們只想調試一下,使用工具是非常便捷而且快速得,但是對于更復雜得場景,這些工具雖然也能實現,但是難度要比寫代碼更大,而且定制化受到工具得功能影響,會
遇到一些障礙,當然我們還要實現自動化等等,鑒于以上因素,我們還是要學會使用代碼進行接口測試,便于維護與擴展,或者算是我們知識得補充把~
requests庫是python用來發起http/https請求得第三方庫,支持get,post,put,delete等,requests特點是簡單便捷、功能豐富,能夠滿足日常測試需求,所以我們選取requests庫進行接口測試
運行環境:
接口為自己編寫得測試接口,測試請使用自己得接口
第一部分:安裝
1.安裝python(自行安裝),不會的朋友們可以參考這篇文章:https://www.jb51.net/article/112486.htm
2.安裝requests(linux和mac os可能會遇到權限問題,sudo安裝即可)
pip install -U requests
3.驗證
localhost:~ mac$ python3 Python 3.6.4 (v3.6.4:d48ecebad5, Dec 18 2017, 21:07:28) [GCC 4.2.1 (Apple Inc. build 5666) (dot 3)] on darwin Type "help", "copyright", "credits" or "license" for more information. >>> import requests >>>
沒有報錯說明python與requests環境都沒問題
第二部分:基礎部分
以一個簡單的get接口為例
import requests #導入requests模塊 response=requests.get("http://localhost:5000/hello")#對hello接口進行get請求,并獲取響應信息
1.響應信息(response)解析
print(response.text) print(response.content) ##輸出 你好 b'\xe4\xbd\xa0\xe5\xa5\xbd'
response.text是以str得形式返回得響應信息
response.content是以bytes形式返回
實際使用中根據自己得情況進行選擇
2.獲取狀態碼
print(response.status_code) ##輸出 200
3.獲取headers信息
print(response.headers) ##輸出 {'Content-Type': 'text/html; charset=utf-8', 'Content-Length': '6', 'Server': 'Werkzeug/0.14.1 Python/3.6.4', 'Date': 'Sun, 24 Jun 2018 02:55:27 GMT'}
4.獲取cookies信息
print(response.cookies) ##輸出 <RequestsCookieJar[]>
注意:這里與其他部分稍有不同,返回cookies的信息為cookies對象,而不是像前面部分返回得是字符串或者字典,cookies解析部分在后面會進行單獨說明
5.獲取請求url
print(response.url) ###輸出 http://localhost:5000/hello
6.獲取反序列化后的得信息:
print(response.json()) ###輸出: {'name': 'john'}
注意:只有在返回信息為json格式時才能使用,否則會報json異常
7.獲取響應時間
print(response.elapsed) print(response.elapsed.microseconds) print(response.elapsed.seconds) print(response.elapsed.total_seconds()) ##輸出 0:00:00.003773 3773 0 0.003773
第三部分:進階部分
通常我們要想獲取正確得響應信息需要傳遞一些參數,針對不同得請求,傳參方式稍有不通,下面我們來看一下
這里我部署了一個get接口和一個post接口,功能都是講獲取得請求參數返回回來,以便我們查看效果
1.get請求傳遞參數
params={"name":"john","age":17} response=requests.get("http://localhost:5000/get_params",params=params) print(response.text) print(response.url) ##輸出 {"name": "john", "age": "17"} http://localhost:5000/get_params?name=john&age=17
說明:
這里做了三件事,先定義一個參數字典p,然后將參數字典以params參數傳遞給get方法,最后將響應信息打印出來,從響應信息可以看到參數被正確得傳遞進去,requests幫我們把參數組合到了url里面
2.post請求傳遞參數
post傳遞參數和get有所不同,根據服務端取值方式進行不同方式得傳遞
如果是傳遞得json格式得參數
p={"name":"john","age":17} response=requests.post("http://localhost:5000/post_params",json=p) print(response.text) ###輸出: {"name": "john", "age": 17}
如果是以html中form得形式傳遞參數,
response=requests.post("http://localhost:5000/post_params",data=p) print(response.text)
如果form傳遞得是json格式需要以下面得方式
import json response=requests.post("http://localhost:5000/post_params",data=json.dumps(p)) print(response.text)
說明:
需要將字典行駛得參數轉換為json格式,再進行傳遞
根據服務端得情況選中一種方式進行傳遞參數,通常情況下這三種情況可以滿足測試需求
第四部分:高級部分
1.操作cookies
有時候由于服務端需要取得cookies信息來進行用戶身份驗證, 或者另外一些用戶信息來進行邏輯處理,這時候我們在測試接口時需要手動獲取cookies信息和添加cookies信息到請求中
先看設置cookies信息
注:我這里部署了一個set_cookies接口,將cookies信息作為響應信息返回
my_cookies={"name":"john"} response=requests.get("http://localhost:5000/set_cookies",cookies=my_cookies) print(response.text) ##輸出 {"name": "john"}
說明:
這段代碼先定義了一個cookies字典,然后通過get方法,以cookies參數傳入,最后打印出響應信息,可以看到cookies被成功種入請求中
我們再說說如何獲取cookies并解析cookies信息
注:這里我部署了一個get_cookies接口,將{"name":"john"}作為cookies置入響應中
response=requests.get("http://localhost:5000/get_cookies") cookies=response.cookies print(cookies["name"]) ##輸出: john
說明:
獲取cookies對象得信息,我們只需要像獲取字段得value一樣即可,可以看到我們成功獲取到了john
2.headers
看完了cookies之后,header就一目了然了,但是我還是同樣部署兩個接口(一個set_headers,一個get_headers)
#設置headers my_headers={"name":"john"} response=requests.get("http://localhost:5000/set_headers",headers=my_headers) print(response.text) #獲取headers response=requests.get("http://localhost:5000/get_headers") print(response.headers.get("name")) ##輸出: {"name": "john"} john
3.session
session可以理解為一段對話,而這段對話會紀錄這次會話中得一些內容和狀態,當中斷這段對話,這些信息與狀態就丟失了session對象讓你能夠跨請求保持某些參數。它也會在同一個 Session 實例發出的所有請求之間保持 cookie, 期間使用 urllib3 的 connection pooling 功能。所以如果你向同一主機發送多個請求,底層的 TCP 連接將會被重用,從而帶來顯著的性能提升
使用方法
注:我這里部署兩個接口,一個hello接口(用來演示使用全局cookies,將請求cookies返回),一個world接口(用來演示使用全局headers,將請求headers返回)
#設置headers my_info={"name":"john"} #創建全局session對象 my_session=requests.session() #設置全局cookies信息 my_session.cookies.set("name","john") #設置全局headers信息 my_session.headers.update(my_info) #演示全局cookies使用 response=my_session.get("http://localhost:5000/hello") print(response.text) #演示全局headers使用 response=my_session.get("http://localhost:5000/world") print(response.text) ##輸出 {"name": "john"} {"Host": "localhost:5000", "User-Agent": "python-requests/2.19.1", "Accept-Encoding": "gzip, deflate", "Accept": "*/*", "Connection": "keep-alive", "Name": "john", "Cookie": "name=john"}
4.設置timeout
通常接口都是為上游服務得,由于上游不能夠長時間等待接口返回信息,都會設置一個超時時間,超過了這個時間,會將這個結果丟棄,如果我們要監控線上接口有沒有超時情況,這時候我們發起請求的時候就需要設置一個超時時間,如果超過這個時間,就會拋出一個異常
response=requests.get("http://www.baidu.com",timeout=5)
說明:
將5這個超時時間以timeout參數傳入,這里得單位是秒
如果要想將連接(connect)與讀取(read)都進行設置,則需要傳入一個元組,第一個元素為connect超時事件,第二個元素為read超時時間
response=requests.get("http://www.baidu.com",timeout=(1,2))
5.hook
太晚了,先睡覺,明天補上~~
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。