前端请求接口post_接口自动化测试-WEB资讯专栏-DMOZ中文网站分类目录
為什么UI自動化維護成本更高?因為前端頁面變化太快,而且UI自動化比較耗時(比如等待頁面元素的加載、添加等待時間、定位元素、操作元素、模擬頁面動作這些都需要時間)為什么接口自動化維護成本較低?因為接口較穩定,接口的響應時間基本上都是秒級、毫
(1)接口自動化測試的意義、前后端分離思想
接口自動化測試的優缺點:
優點:
測試復用性。
維護成本相對UI自動化低一些。
為什么UI自動化維護成本更高? 因為前端頁面變化太快,而且UI自動化比較耗時(比如等待頁面元素的加載、添加等待時間、定位元素、操作元素、模擬頁面動作這些都需要時間)為什么接口自動化維護成本較低? 因為接口較穩定,接口的響應時間基本上都是秒級、毫秒級別的,速度快,并且接口自動化本身也可以做一些有關聯的操作、全流程的操作(比如:注冊 --> 登錄 --> 修改個人信息)。回歸方便。
可以運行更多更繁瑣的測試。自動化的一個明顯的好處是可以在較少的時間內運行更多的測試。
優點1、優點3、優點4是接口自動化和UI自動化公有的優點。缺點:
GET請求和POST請求的區別:
前后端分離
開發模式
以前老的方式:
產品經理 / 領導 / 客戶提出需求(提出文字需求)
UI做出設計圖
前端工程師做html頁面(用戶能看到的頁面)
后端工程師將html頁面套成jsp頁面(前后端強依賴,后端必須要等到前端的html頁面做好才能套jsp。如果html發生變更,就很麻煩,開發效率低)
比如云商系統:
集成出現問題
前端返工
后端返工
二次集成
集成成功
交付
新的方式:
- 產品經理 / 領導 / 客戶提出需求(提出文字需求)
- UI做出設計圖
- 前后端約定接口 & 數據 & 參數
- 前后端并行開發(無強依賴,可前后端并行開發,如果需求變更,只要接口 & 參數不變,就不用兩邊都修改代碼,開發效率高)
- 前后端集成
- 前端頁面調整
- 集成成功
- 交付
??通過F12打開瀏覽器開發者工具進行抓包,返回數據是json格式的就是前后端分離,返回時html頁面就是沒有前后端分離。
微服務的概念:
將大模塊切分成小模塊。減少代碼的耦合度,從而降低模塊與模塊之間的影響。原先是一個jar包里面包含所有模塊,改一個模塊就有可能影響其他模塊,現在是將一個一個的模塊都打成一個一個的jar包,模塊與模塊之間的交互通過接口,哪個模塊出了問題,只需要修改那個模塊的jar包,避免因為修改一個模塊的代碼導致其他模塊出錯。
(2)Python requests框架講解
接口自動化requests環境搭建
接口自動化核心庫:requests
安裝requests庫的方法:
方法一:
命令行安裝,打開cmd或者終端,輸入以下命令:
pip install requests -i方法二:
在pycharm中安裝,settings --> Project --> Project Interpreter --> 點擊“+”號 --> 輸入request安裝
測試環境是否ok
# -*- coding:utf-8 -*- # 作者:IT小學生蔡坨坨 # 時間:2021/1/7 21:48import requestsurl_toutiao = "" # 方式一: # result_toutiao = (url_toutiao)# 方式二: result_toutiao = (url=url_toutiao)# 方式三: # result_toutiao = ( # "")# print(()) # print(type(())) # <class "dict"> result = () print(result) expect_result = "華晨金杯汽車花朵朵" actual_result = result["data"][0]["comment"]["user_name"] print(actual_result) if expect_result == actual_result:print("pass!") else:print("failed!")響應超時timeout
import requests# V部落:http://182.92.178.83:8081/index.html # 文章列表 url_v_article = "" v_headers = {"Cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"} article_params = {"state": 1, # -1:全部文章 1:已發表 0:回收站 2:草稿箱"page": 1, # 顯示第1頁"count": 6, # 每頁顯示6條"keywords": "" # 包含的關鍵字} keywords = ["大橘貓", "跑男", "牙"] for keyword in keywords:article_params["keywords"] = keyword# headers和params是不定長的,根據定義的字典傳參# timeout超時,單位為秒# 通過設置超時時間,告訴requests在經過多久后停止等待響應result = (url_v_article, headers=v_headers, params=article_params, timeout=30)print(())JSON、URL、text、encoding、status_code、encoding、cookies
print(()) # 響應結果以json的形式打印輸出 print() # 打印url地址 print() # 以文本格式打印服務器響應的內容 print() # 響應狀態碼 print() # 編碼格式 print() # cookieJSON(JavaScript Object Notation, JS 對象簡譜) 是一種輕量級的數據交換格式。它基于 ECMAScript (歐洲計算機協會制定的js規范)的一個子集,采用完全獨立于編程語言的文本格式來存儲和表示數據。簡潔和清晰的層次結構使得 JSON 成為理想的數據交換語言。 易于人閱讀和編寫,同時也易于機器解析和生成,并有效地提升網絡傳輸效率。
JSON格式在Python里面相當于字典類型。
JSON格式化:http://www.bejson.com/jsonviewernew/
url在線編碼轉換:
(3)get、post、put、delete請求方式的自動化實現
GET請求方式
# -*- coding:utf-8 -*- # 作者:IT小學生蔡坨坨 # 時間:2021/1/7 21:48import requestsurl_toutiao = "" # 方式一: # result_toutiao = (url_toutiao)# 方式二: result_toutiao = (url=url_toutiao)# 方式三: # result_toutiao = ( # "")# print(()) # print(type(())) # <class "dict"> result = () print(result) expect_result = "華晨金杯汽車花朵朵" actual_result = result["data"][0]["comment"]["user_name"] print(actual_result) if expect_result == actual_result:print("pass!") else:print("failed!")運行結果: {"message": "success", "err_no": 0, "data": [{"comment": {"id": 6914864825282215951, "id_str": "6914864825282215951", "text": "藁城出國打工的人很多,重點檢查藁城區!", "content_rich_span": "{"links":[]}", "user_id": 940799526971408, "user_name": "華晨金杯汽車花朵朵",}, "post_count": 0, "stick_toast": 1, "stable": True} 華晨金杯汽車花朵朵 pass!POST請求方式
# -*- coding:utf-8 -*- # 作者:IT小學生蔡坨坨 # 時間:2021/1/9 22:51import requestsurl_v_login = "" # 定義參數,字典格式 payload = {"username": "sang", "password": "123"} # Content-Type: application/json --> json # Content-Type: application/x-www-form-urlencoded --> data result = (url_v_login, data=payload) # 將返回結果轉為json格式 result_json = () print(result_json) # {"status": "success", "msg": "登錄成功"} # 獲取RequestsCookieJar result_cookie = print(result_cookie, type(result_cookie)) # RequestsCookieJar # 將RequestsCookieJar轉化為字典格式 result_cookie_dic = (result_cookie) print(result_cookie_dic) # {"JSESSIONID": "D042C5FE4CFF337806D545B0001E7197"} # 獲取SESSION final_cookie = "JSESSIONID=" + result_cookie_dic["JSESSIONID"] # SJSESSIONID=D042C5FE4CFF337806D545B0001E7197 print(final_cookie)PUT請求方式
# V部落_編輯欄目# 定義請求頭,自動獲取cookie的方法詳情請看下文 headers = {"Cookie": "VBlog().get_cookie()"} new_now_time = ("%Y%m%d%H%M%S", (())) new_category_name = "更新欄目" + new_now_time payload = {"id": 2010, "cateName": new_category_name} .put("", headers=headers, data=payload)DELETE請求方式
# 刪除欄目 result = .delete("" + “2010”, headers=headers) print(()) # {"status": "success", "msg": "刪除成功!"} ("刪除成功!", ()["msg"])(4)接口自動化測試過程中cookie的處理
手動傳入cookie的值(每次通過瀏覽器F12抓包,然后復制request header里面的cookie)
# -*- coding:utf-8 -*- # 作者:IT小學生蔡坨坨 # 時間:2021/1/7 22:25import requests# V部落查詢欄目 url_v_category = "all" # 定制請求頭 # 如果你想為請求添加HTTP頭部,只要簡單地傳遞一個字典給headers參數就可以了 v_headers = {"cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"} result = (url_v_category, headers=v_headers) # 打印json格式的響應結果 print(())cookie自動獲取
# -*- coding:utf-8 -*- # 作者:IT小學生蔡坨坨 # 時間:2021/1/9 22:51import requestsurl_v_login = "" # 定義參數,字典格式 payload = {"username": "sang", "password": "123"} # Content-Type: application/json --> json # Content-Type: application/x-www-form-urlencoded --> data result = (url_v_login, data=payload) # 將返回結果轉為json格式 result_json = () print(result_json) # {"status": "success", "msg": "登錄成功"} # 獲取RequestsCookieJar result_cookie = print(result_cookie, type(result_cookie)) # RequestsCookieJar # 將RequestsCookieJar轉化為字典格式 result_cookie_dic = (result_cookie) print(result_cookie_dic) # {"JSESSIONID": "D042C5FE4CFF337806D545B0001E7197"} # 獲取SESSION final_cookie = "JSESSIONID=" + result_cookie_dic["JSESSIONID"] # SJSESSIONID=D042C5FE4CFF337806D545B0001E7197 print(final_cookie)批量獲取cookie腳本
# -*- coding:utf-8 -*- # 作者:IT小學生蔡坨坨 # 時間:2021/1/9 23:26import requestsdef get_cookie(username, password):"""通過考試系統學生登錄獲取單個cookie"""url_login = ""payload = {"userName": username, "password": password, "remember": False}result = (url_login, json=payload)# result_json = ()# print(result_json)# 獲取RequestsCookieJarresult_cookie = # print(result_cookie, type(result_cookie)) # RequestsCookieJar# 將RequestsCookieJar轉化為字典格式result_cookie_dic = (result_cookie)# print(result_cookie_dic) # {"SESSION": "YzFkM2IzN2QtZWY1OC00Nzc4LTgyOWYtNjg5OGRiZDZlM2E4"}# 獲取SESSIONfinal_cookie = "SESSION=" + result_cookie_dic["SESSION"] # SESSION=Mzc2...return final_cookie # -*- coding:utf-8 -*- # 作者:IT小學生蔡坨坨 # 時間:2021/1/9 23:23from test01.demo04_student_login import get_cookie import osdef get_batch_cookies():"""批量獲取cookie"""# 獲取cookie之前,先將文件內容清空# with open(r"D:\Desktop\Testman_Study\API_auto\file\", "w") as cookies_info:# ("")# 或者將文件刪除(r"D:\Desktop\Testman_Study\API_auto\file\")# 讀取csv文件with open(r"D:\Desktop\Testman_Study\API_auto\file\", "r") as user_info:for user in user_info:user_list = ().split(",")# 調用獲取單個cookies的方法,傳入注冊好的用戶名和密碼cookies = get_cookie(user_list[0], user_list[1])# 將cookie追加寫入文件with open(r"D:\Desktop\Testman_Study\API_auto\file\", "a") as cookies_info:(cookies + "\n")# 調用方法 get_batch_cookies() (前提是這些賬號和密碼都是已經注冊過的,可以直接登錄)poopoo001,123456,1 poopoo002,123457,2 poopoo003,123458,3 poopoo004,123459,4 ...... SESSION=ZmE3YmU4ZDctNDExZS00MDdhLWE0YjEtMjAyZjQxOTMxYmUx SESSION=YjdkNTZhNTUtNGFmMi00MjVkLWEyNjctOTNiMmRmOTY1YTdm SESSION=ZTJmMTYzMWEtZjUzOS00NTlhLWI0OWQtMzBmN2RkYmU4YmRi SESSION=YTM0ZGRhOTctZjk5Ni00OWZhLTg1YTItZjUyMTMwZGE2MjVi ......(5)不同類型請求參數的處理
# -*- coding:utf-8 -*- # 作者:IT小學生蔡坨坨 # 時間:2021/1/7 22:25import requests# 文章列表 url_v_article = "" v_headers = {"Cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"}# 自定義url參數,定義一個字典,將參數拆分,再將字典傳遞給params變量即可 article_params = {"state": 1, # -1:全部文章 1:已發表 0:回收站 2:草稿箱"page": 1, # 顯示第1頁"count": 6, # 每頁顯示6條"keywords": "" # 包含的關鍵字} keywords = ["大橘貓", "跑男", "牙"] for keyword in keywords:article_params["keywords"] = keyword# headers和params是不定長的,根據定義的字典傳參result = (url_v_article, headers=v_headers, params=article_params)print(())(6)結合Python+Requests+Unittest框架做接口自動化測試
unittest框架結構:
代碼地址:https://github.com/itcaituotuo/unittest_api
if _name_ == "__main__":
if __name__ == "__main__"的意思是:
- 當.py文件被直接運行時,if __name__ == "__main__"下的代碼塊將被運行;
- 當.py文件以模塊形式被導入時,if __name__ == "__main__"下的代碼塊不被運行。
(7)接口自動化測試過程中高級斷言
閉環斷言(新增 --> 查詢 --> 修改 --> 查詢 --> 刪除 -->查詢)
def test_article(self):# ①V部落_新增文章now_time = ("%Y%m%d%H%M%S", (()))title = "蔡坨坨" + now_timepayload = {"id": -1, "title": title, "mdContent": "文章內容", "state": 1, "htmlContent": "<p>文章內容</p>","dynamicTags": "", "cid": 62}headers = {"Cookie": VBlog().get_cookie()}result = self.("", headers=headers, data=payload)# ②查詢文章url_v_article = ""article_params = {"state": 1, # -1:全部文章 1:已發表 0:回收站 2:草稿箱"page": 1, # 顯示第1頁"count": 6, # 每頁顯示6條"keywords": title # 包含的關鍵字title}result = (url_v_article, headers=headers, params=article_params, timeout=30)print(()) # 響應結果以json的形式打印輸出ls = ()["articles"]act = 123# 查到新增的文章,說明新增成功for l in range(0, len(ls)):if ls[l]["title"] == title:act = "ok"article_id = ls[l]["id"]("ok", act)# ③編輯文章now_time = ("%Y%m%d%H%M%S", (()))title = "修改文章" + now_timepayload = {"id": article_id, "title": title, "mdContent": "修改內容", "state": 1, "htmlContent": "<p>修改內容</p>","dynamicTags": "", "cid": 62}headers = {"Cookie": VBlog().get_cookie()}self.("", headers=headers, data=payload)# 編輯完,查詢文章url_v_article = ""article_params = {"state": 1, # -1:全部文章 1:已發表 0:回收站 2:草稿箱"page": 1, # 顯示第1頁"count": 6, # 每頁顯示6條"keywords": title # 包含的關鍵字title}result = (url_v_article, headers=headers, params=article_params, timeout=30)print(()) # 響應結果以json的形式打印輸出ls = ()["articles"]act = 123# 查到修改過的文章,說明編輯成功for l in range(0, len(ls)):if ls[l]["title"] == title:act = "ok"article_id = ls[l]["id"]("ok", act)# ④查看文章詳情article_id = str(article_id)result = self.("" + article_id, headers=headers)print(())if ()["title"] == title:act = "ok"(act, "ok")# ⑤刪除文章payload = {"aids": article_id, "state": 1}result = .put("dustbin", headers=headers, data=payload)print(())act = ()["msg"](act, "刪除成功!")(8)通過生成可視化HTML測試報告
百度網盤鏈接:
鏈接:
提取碼:p20c
postman、JMeter、requests總結:
postman:接口功能測試
JMeter:接口性能測試
requests:接口自動化
??三個的共同特點:都能完成接口功能測試。
TAG:接口測試
總結
以上是生活随笔為你收集整理的前端请求接口post_接口自动化测试-WEB资讯专栏-DMOZ中文网站分类目录的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: alibaba 实体转json_com.
- 下一篇: HTML用css让input无法使用,h