日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

前端请求接口post_接口自动化测试-WEB资讯专栏-DMOZ中文网站分类目录

發(fā)布時(shí)間:2024/9/27 HTML 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 前端请求接口post_接口自动化测试-WEB资讯专栏-DMOZ中文网站分类目录 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

為什么UI自動(dòng)化維護(hù)成本更高?因?yàn)榍岸隧撁孀兓?#xff0c;而且UI自動(dòng)化比較耗時(shí)(比如等待頁面元素的加載、添加等待時(shí)間、定位元素、操作元素、模擬頁面動(dòng)作這些都需要時(shí)間)為什么接口自動(dòng)化維護(hù)成本較低?因?yàn)榻涌谳^穩(wěn)定,接口的響應(yīng)時(shí)間基本上都是秒級(jí)、毫

(1)接口自動(dòng)化測(cè)試的意義、前后端分離思想

接口自動(dòng)化測(cè)試的優(yōu)缺點(diǎn):

優(yōu)點(diǎn):

  • 測(cè)試復(fù)用性。

  • 維護(hù)成本相對(duì)UI自動(dòng)化低一些。

    為什么UI自動(dòng)化維護(hù)成本更高? 因?yàn)榍岸隧撁孀兓?#xff0c;而且UI自動(dòng)化比較耗時(shí)(比如等待頁面元素的加載、添加等待時(shí)間、定位元素、操作元素、模擬頁面動(dòng)作這些都需要時(shí)間)為什么接口自動(dòng)化維護(hù)成本較低? 因?yàn)榻涌谳^穩(wěn)定,接口的響應(yīng)時(shí)間基本上都是秒級(jí)、毫秒級(jí)別的,速度快,并且接口自動(dòng)化本身也可以做一些有關(guān)聯(lián)的操作、全流程的操作(比如:注冊(cè) --> 登錄 --> 修改個(gè)人信息)。
  • 回歸方便。

  • 可以運(yùn)行更多更繁瑣的測(cè)試。自動(dòng)化的一個(gè)明顯的好處是可以在較少的時(shí)間內(nèi)運(yùn)行更多的測(cè)試。

    優(yōu)點(diǎn)1、優(yōu)點(diǎn)3、優(yōu)點(diǎn)4是接口自動(dòng)化和UI自動(dòng)化公有的優(yōu)點(diǎn)。
  • 缺點(diǎn):

  • 不能完全取代手工測(cè)試。(自動(dòng)化永遠(yuǎn)不能替代手工測(cè)試,只是提高測(cè)試效率)
  • 手工測(cè)試比自動(dòng)化測(cè)試發(fā)現(xiàn)的缺陷更多,自動(dòng)化測(cè)試不容易發(fā)現(xiàn)新的BUG。
  • GET請(qǐng)求和POST請(qǐng)求的區(qū)別:

  • GET請(qǐng)求一般是從后臺(tái)服務(wù)器上獲取數(shù)據(jù)用于前端頁面的展示(例如:看到列表頁面等),POST請(qǐng)求是向服務(wù)器傳送數(shù)據(jù)(登錄、注冊(cè)、上傳文件、發(fā)布文章)。什么時(shí)候用GET,什么時(shí)候用POST取決于開發(fā)。無論用POST請(qǐng)求還是GET請(qǐng)求,都能完成對(duì)數(shù)據(jù)的增刪改查,分不同的請(qǐng)求方式更多的是一種約定。
  • GET請(qǐng)求的請(qǐng)求參數(shù)是拼接在url后面的,只能以文本的形式傳遞參數(shù),請(qǐng)求參數(shù)會(huì)顯示在地址欄,數(shù)據(jù)長度受限于url的長度,傳遞的數(shù)據(jù)量小(4KB左右,不同瀏覽器會(huì)有差異),POST請(qǐng)求的請(qǐng)求參數(shù)是放在request body里面,傳遞數(shù)據(jù)量大(默認(rèn)8M),對(duì)數(shù)據(jù)長度也沒有要求。GET請(qǐng)求可以在瀏覽器中直接訪問,而POST請(qǐng)求只能借助工具完成(比如:postman、jmeter)。
  • GET請(qǐng)求速度快,安全性不高;POST請(qǐng)求一般用于像登錄這種安全性要求高的場(chǎng)合,請(qǐng)求不會(huì)被緩存,也不會(huì)保留在瀏覽器的歷史記錄中。
  • 以前:get 查詢;post 新增;put 編輯;delete 刪除 現(xiàn)在:get 查詢;post 新增 + 編輯 + 刪除 或者:純post走天下

    前后端分離

    開發(fā)模式

    以前老的方式:

    • 產(chǎn)品經(jīng)理 / 領(lǐng)導(dǎo) / 客戶提出需求(提出文字需求)

    • UI做出設(shè)計(jì)圖

    • 前端工程師做html頁面(用戶能看到的頁面)

    • 后端工程師將html頁面套成jsp頁面(前后端強(qiáng)依賴,后端必須要等到前端的html頁面做好才能套jsp。如果html發(fā)生變更,就很麻煩,開發(fā)效率低)

      比如云商系統(tǒng):

    • 集成出現(xiàn)問題

    • 前端返工

    • 后端返工

    • 二次集成

    • 集成成功

    • 交付

    新的方式:

    • 產(chǎn)品經(jīng)理 / 領(lǐng)導(dǎo) / 客戶提出需求(提出文字需求)
    • UI做出設(shè)計(jì)圖
    • 前后端約定接口 & 數(shù)據(jù) & 參數(shù)
    • 前后端并行開發(fā)(無強(qiáng)依賴,可前后端并行開發(fā),如果需求變更,只要接口 & 參數(shù)不變,就不用兩邊都修改代碼,開發(fā)效率高)
    • 前后端集成
    • 前端頁面調(diào)整
    • 集成成功
    • 交付

    ??通過F12打開瀏覽器開發(fā)者工具進(jìn)行抓包,返回?cái)?shù)據(jù)是json格式的就是前后端分離,返回時(shí)html頁面就是沒有前后端分離。

    微服務(wù)的概念:

    將大模塊切分成小模塊。減少代碼的耦合度,從而降低模塊與模塊之間的影響。原先是一個(gè)jar包里面包含所有模塊,改一個(gè)模塊就有可能影響其他模塊,現(xiàn)在是將一個(gè)一個(gè)的模塊都打成一個(gè)一個(gè)的jar包,模塊與模塊之間的交互通過接口,哪個(gè)模塊出了問題,只需要修改那個(gè)模塊的jar包,避免因?yàn)樾薷囊粋€(gè)模塊的代碼導(dǎo)致其他模塊出錯(cuò)。

    (2)Python requests框架講解

    接口自動(dòng)化requests環(huán)境搭建

    接口自動(dòng)化核心庫:requests

    安裝requests庫的方法:

    方法一:

    命令行安裝,打開cmd或者終端,輸入以下命令:

    pip install requests -i

    方法二:
    在pycharm中安裝,settings --> Project --> Project Interpreter --> 點(diǎn)擊“+”號(hào) --> 輸入request安裝

    測(cè)試環(huán)境是否ok

    # -*- coding:utf-8 -*- # 作者:IT小學(xué)生蔡坨坨 # 時(shí)間: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!")

    響應(yīng)超時(shí)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:已發(fā)表 0:回收站 2:草稿箱"page": 1, # 顯示第1頁"count": 6, # 每頁顯示6條"keywords": "" # 包含的關(guān)鍵字} keywords = ["大橘貓", "跑男", "牙"] for keyword in keywords:article_params["keywords"] = keyword# headers和params是不定長的,根據(jù)定義的字典傳參# timeout超時(shí),單位為秒# 通過設(shè)置超時(shí)時(shí)間,告訴requests在經(jīng)過多久后停止等待響應(yīng)result = (url_v_article, headers=v_headers, params=article_params, timeout=30)print(())

    JSON、URL、text、encoding、status_code、encoding、cookies

    print(()) # 響應(yīng)結(jié)果以json的形式打印輸出 print() # 打印url地址 print() # 以文本格式打印服務(wù)器響應(yīng)的內(nèi)容 print() # 響應(yīng)狀態(tài)碼 print() # 編碼格式 print() # cookie

    JSON(JavaScript Object Notation, JS 對(duì)象簡譜) 是一種輕量級(jí)的數(shù)據(jù)交換格式。它基于 ECMAScript (歐洲計(jì)算機(jī)協(xié)會(huì)制定的js規(guī)范)的一個(gè)子集,采用完全獨(dú)立于編程語言的文本格式來存儲(chǔ)和表示數(shù)據(jù)。簡潔和清晰的層次結(jié)構(gòu)使得 JSON 成為理想的數(shù)據(jù)交換語言。 易于人閱讀和編寫,同時(shí)也易于機(jī)器解析和生成,并有效地提升網(wǎng)絡(luò)傳輸效率。

    JSON格式在Python里面相當(dāng)于字典類型。

    JSON格式化:http://www.bejson.com/jsonviewernew/

    url在線編碼轉(zhuǎn)換:

    (3)get、post、put、delete請(qǐng)求方式的自動(dòng)化實(shí)現(xiàn)

    GET請(qǐng)求方式

    # -*- coding:utf-8 -*- # 作者:IT小學(xué)生蔡坨坨 # 時(shí)間: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!")運(yùn)行結(jié)果: {"message": "success", "err_no": 0, "data": [{"comment": {"id": 6914864825282215951, "id_str": "6914864825282215951", "text": "藁城出國打工的人很多,重點(diǎn)檢查藁城區(qū)!", "content_rich_span": "{"links":[]}", "user_id": 940799526971408, "user_name": "華晨金杯汽車花朵朵",}, "post_count": 0, "stick_toast": 1, "stable": True} 華晨金杯汽車花朵朵 pass!

    POST請(qǐng)求方式

    # -*- coding:utf-8 -*- # 作者:IT小學(xué)生蔡坨坨 # 時(shí)間:2021/1/9 22:51import requestsurl_v_login = "" # 定義參數(shù),字典格式 payload = {"username": "sang", "password": "123"} # Content-Type: application/json --> json # Content-Type: application/x-www-form-urlencoded --> data result = (url_v_login, data=payload) # 將返回結(jié)果轉(zhuǎn)為json格式 result_json = () print(result_json) # {"status": "success", "msg": "登錄成功"} # 獲取RequestsCookieJar result_cookie = print(result_cookie, type(result_cookie)) # RequestsCookieJar # 將RequestsCookieJar轉(zhuǎn)化為字典格式 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請(qǐng)求方式

    # V部落_編輯欄目# 定義請(qǐng)求頭,自動(dòng)獲取cookie的方法詳情請(qǐng)看下文 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請(qǐng)求方式

    # 刪除欄目 result = .delete("" + “2010”, headers=headers) print(()) # {"status": "success", "msg": "刪除成功!"} ("刪除成功!", ()["msg"])

    (4)接口自動(dòng)化測(cè)試過程中cookie的處理

    手動(dòng)傳入cookie的值(每次通過瀏覽器F12抓包,然后復(fù)制request header里面的cookie)

    # -*- coding:utf-8 -*- # 作者:IT小學(xué)生蔡坨坨 # 時(shí)間:2021/1/7 22:25import requests# V部落查詢欄目 url_v_category = "all" # 定制請(qǐng)求頭 # 如果你想為請(qǐng)求添加HTTP頭部,只要簡單地傳遞一個(gè)字典給headers參數(shù)就可以了 v_headers = {"cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"} result = (url_v_category, headers=v_headers) # 打印json格式的響應(yīng)結(jié)果 print(())

    cookie自動(dòng)獲取

    # -*- coding:utf-8 -*- # 作者:IT小學(xué)生蔡坨坨 # 時(shí)間:2021/1/9 22:51import requestsurl_v_login = "" # 定義參數(shù),字典格式 payload = {"username": "sang", "password": "123"} # Content-Type: application/json --> json # Content-Type: application/x-www-form-urlencoded --> data result = (url_v_login, data=payload) # 將返回結(jié)果轉(zhuǎn)為json格式 result_json = () print(result_json) # {"status": "success", "msg": "登錄成功"} # 獲取RequestsCookieJar result_cookie = print(result_cookie, type(result_cookie)) # RequestsCookieJar # 將RequestsCookieJar轉(zhuǎn)化為字典格式 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小學(xué)生蔡坨坨 # 時(shí)間:2021/1/9 23:26import requestsdef get_cookie(username, password):"""通過考試系統(tǒng)學(xué)生登錄獲取單個(gè)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轉(zhuǎn)化為字典格式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小學(xué)生蔡坨坨 # 時(shí)間:2021/1/9 23:23from test01.demo04_student_login import get_cookie import osdef get_batch_cookies():"""批量獲取cookie"""# 獲取cookie之前,先將文件內(nèi)容清空# 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(",")# 調(diào)用獲取單個(gè)cookies的方法,傳入注冊(cè)好的用戶名和密碼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")# 調(diào)用方法 get_batch_cookies() (前提是這些賬號(hào)和密碼都是已經(jīng)注冊(cè)過的,可以直接登錄)poopoo001,123456,1 poopoo002,123457,2 poopoo003,123458,3 poopoo004,123459,4 ...... SESSION=ZmE3YmU4ZDctNDExZS00MDdhLWE0YjEtMjAyZjQxOTMxYmUx SESSION=YjdkNTZhNTUtNGFmMi00MjVkLWEyNjctOTNiMmRmOTY1YTdm SESSION=ZTJmMTYzMWEtZjUzOS00NTlhLWI0OWQtMzBmN2RkYmU4YmRi SESSION=YTM0ZGRhOTctZjk5Ni00OWZhLTg1YTItZjUyMTMwZGE2MjVi ......

    (5)不同類型請(qǐng)求參數(shù)的處理

    # -*- coding:utf-8 -*- # 作者:IT小學(xué)生蔡坨坨 # 時(shí)間: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參數(shù),定義一個(gè)字典,將參數(shù)拆分,再將字典傳遞給params變量即可 article_params = {"state": 1, # -1:全部文章 1:已發(fā)表 0:回收站 2:草稿箱"page": 1, # 顯示第1頁"count": 6, # 每頁顯示6條"keywords": "" # 包含的關(guān)鍵字} keywords = ["大橘貓", "跑男", "牙"] for keyword in keywords:article_params["keywords"] = keyword# headers和params是不定長的,根據(jù)定義的字典傳參result = (url_v_article, headers=v_headers, params=article_params)print(())

    (6)結(jié)合Python+Requests+Unittest框架做接口自動(dòng)化測(cè)試

    unittest框架結(jié)構(gòu):

    代碼地址:https://github.com/itcaituotuo/unittest_api

    if _name_ == "__main__":

    if __name__ == "__main__"的意思是:

    • 當(dāng).py文件被直接運(yùn)行時(shí),if __name__ == "__main__"下的代碼塊將被運(yùn)行;
    • 當(dāng).py文件以模塊形式被導(dǎo)入時(shí),if __name__ == "__main__"下的代碼塊不被運(yùn)行。

    (7)接口自動(dòng)化測(cè)試過程中高級(jí)斷言

    閉環(huán)斷言(新增 --> 查詢 --> 修改 --> 查詢 --> 刪除 -->查詢)

    def test_article(self):# ①V部落_新增文章now_time = ("%Y%m%d%H%M%S", (()))title = "蔡坨坨" + now_timepayload = {"id": -1, "title": title, "mdContent": "文章內(nèi)容", "state": 1, "htmlContent": "<p>文章內(nèi)容</p>","dynamicTags": "", "cid": 62}headers = {"Cookie": VBlog().get_cookie()}result = self.("", headers=headers, data=payload)# ②查詢文章url_v_article = ""article_params = {"state": 1, # -1:全部文章 1:已發(fā)表 0:回收站 2:草稿箱"page": 1, # 顯示第1頁"count": 6, # 每頁顯示6條"keywords": title # 包含的關(guān)鍵字title}result = (url_v_article, headers=headers, params=article_params, timeout=30)print(()) # 響應(yīng)結(jié)果以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": "修改內(nèi)容", "state": 1, "htmlContent": "<p>修改內(nèi)容</p>","dynamicTags": "", "cid": 62}headers = {"Cookie": VBlog().get_cookie()}self.("", headers=headers, data=payload)# 編輯完,查詢文章url_v_article = ""article_params = {"state": 1, # -1:全部文章 1:已發(fā)表 0:回收站 2:草稿箱"page": 1, # 顯示第1頁"count": 6, # 每頁顯示6條"keywords": title # 包含的關(guān)鍵字title}result = (url_v_article, headers=headers, params=article_params, timeout=30)print(()) # 響應(yīng)結(jié)果以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測(cè)試報(bào)告

    百度網(wǎng)盤鏈接:

    鏈接:
    提取碼:p20c

    # -*- coding:utf-8 -*- # 作者:IT小學(xué)生蔡坨坨 # 時(shí)間:2021/1/10 13:45from reports import HTMLTestRunner from case.exam_case.teacher_case import TeacherCase import unittest import os import time# 創(chuàng)建測(cè)試套件 suite = ()# 添加測(cè)試用例,根據(jù)添加順序執(zhí)行 # 添加單個(gè)測(cè)試用例 # (TeacherCase("test_001_admin_login"))# 添加多個(gè)測(cè)試用例 s([TeacherCase("test_001_admin_login"),TeacherCase("test_002_insert_paper"),TeacherCase("test_003_select_paper"),])# 定義測(cè)試報(bào)告的存放的路徑 path = r"D:\Desktop\Testman_Study\unittest_exam_system\reports" # 判斷路徑是否存在 if not os.path.exists(path):# 如果不存在,則創(chuàng)建一個(gè)(path) else:pass # 定義一個(gè)時(shí)間戳用于測(cè)試報(bào)告命名 now_time = ("%Y-%m-%d-%H-%M-%S", (())) reports_path = path + "\\" + now_time + "(exam_report).html" reports_title = u"考試系統(tǒng)&V部落——測(cè)試報(bào)告" desc = u"考試系統(tǒng)&V部落——接口自動(dòng)化測(cè)試報(bào)告" # 二進(jìn)制寫 fp = open(reports_path, "wb") runner = (stream=fp, title=reports_title, description=desc) # 運(yùn)行 (suite)

    postman、JMeter、requests總結(jié):

    • postman:接口功能測(cè)試

    • JMeter:接口性能測(cè)試

    • requests:接口自動(dòng)化

    • ??三個(gè)的共同特點(diǎn):都能完成接口功能測(cè)試。

    以上信息來源于網(wǎng)絡(luò),如有侵權(quán),請(qǐng)聯(lián)系站長刪除。

    TAG:接口測(cè)試

    總結(jié)

    以上是生活随笔為你收集整理的前端请求接口post_接口自动化测试-WEB资讯专栏-DMOZ中文网站分类目录的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。