Python+Requests+PyTest+Excel+Allure?接口自動化測試實戰(zhàn)
Unittest是Python標準庫中自帶的單元測試框架,Unittest有時候也被稱為PyUnit,就像JUnit是Java語言的標準單元測試框架一樣,Unittest則是Python語言的標準單元測試框架。
Pytest是Python的另一個第三方單元測試庫。它的目的是讓單元測試變得更容易,并且也能擴展到支持應用層面復雜的功能測試。
兩者對比:
Pytest項目實戰(zhàn):
第一步、搭建項目框架(創(chuàng)建Gwyc_Api_Script_Pytest項目目錄)
依次創(chuàng)建子目錄如下:base:存放一些最底層的方法封裝,協(xié)議,請求發(fā)送等。common:存放一些公共方法。config:存放配置文件。data:存放測試數(shù)據(jù)。 log:存放日志。report:存放報告。tests:存放用例。utils:存放公共類。 readme:用于說明文檔。requirements.txt: 用于記錄所有依賴包極其版本號,便于環(huán)境部署,可以通過pip命令自動生成和安裝。
第二步、封裝請求方法(base目錄下面創(chuàng)建method.py)
封裝有兩種方法:
第一種:直接調(diào)用requests庫下面的request方法,并將所有需要用到的參數(shù)定義進去,分為實參和行參,實參調(diào)用必須要傳參,行參可給默認值,調(diào)用時可重新賦值也可以使用默認值。這種方法代碼量少,不用做判斷,request會自動根據(jù)傳入的參數(shù)進行發(fā)送請求到服務器。
第二種:分別對各個請求方式按函數(shù)的形式封裝,分別調(diào)用requests進行發(fā)送請求。以get和post為例:put,delete請求按一樣方法封裝,各個請求方式封裝完成以后再定義一個主方法,直接調(diào)用主方法會自動根據(jù)請求方式進行判斷調(diào)用各個請求函數(shù),這里也可以不對請求方式匯總封裝,直接調(diào)用各個函數(shù)進行發(fā)送請求也是可以的。這種方法封裝涉及代碼量較多,也沒有能夠很好的用上requests庫,因此推薦使用第一種方法。
第三步、封裝讀取文件的方法(common目錄下創(chuàng)建public.py):
1、這里需要用到python的os庫,os 庫是Python標準庫,包含幾百個函數(shù),常用的有路徑操作、進程管理、環(huán)境參數(shù)等。
2、分別對獲取目錄和獲取目錄下文件進行了封裝,直接調(diào)用并傳入相應的參數(shù)即可使用。如下圖:
第四步、準備數(shù)據(jù)(data目錄下創(chuàng)建data.xlsx)
將接口寫入excel表,將接口需要用到的字段都寫進excel然后直接進行讀取。
第五步、封裝讀取文件方法(utils目錄下面創(chuàng)建operationExcel.py)
定義一個文件類分別再定義一個方法獲取Sheet表,定義一個方法獲取出所有數(shù)據(jù)存放進列表。
第六步、封裝登錄方法(common目錄下面創(chuàng)建login.py)
獲取token提供給接口使用,使用@pytest.fixture裝飾器每次執(zhí)行所有用例前執(zhí)行一遍登錄方法獲取到token并返回。
第七步、對表頭定義全局變量,可以定義在utils目錄下面的operationExcel.py文件中
第八步、封裝用例(tests目錄下面創(chuàng)建test_gwyc_api_all.py)
需要用到@pytest.mark.parametrize()裝飾器進行封裝用例,調(diào)用getExceldatas()將讀取出來的用例存放進裝飾器,"data"為別名。如下圖,分別請求頭和參數(shù)做了為空判斷,并將token插入到headers里面,這樣每一個接口都能使用到登錄返回的token,不用每次都去調(diào)用獲取token。
第九步、利用allure生成測試報告。
allure是Pytest的插件包需要下載安裝,并將allure里面的bin目錄所在的路徑配置到PATH環(huán)境變量中就可以直接使用報告。
將生成的json文件存放到用例所在的目錄下面執(zhí)行完成以后會在tests目錄下面生成一個report目錄,下面包含result目錄和html目錄,前者是存放json文件,后者存放讀取后生成的html報告
第十步、封裝日志方法(log目錄下面創(chuàng)建log.py)
日志在自動化測試中起到的參考作用相對較小以測試報告為準,直接按相應規(guī)則配置好直接調(diào)用即可。
到此這篇關于Python+Requests+PyTest+Excel+Allure 接口自動化測試實戰(zhàn)的文章就介紹到這了,更多相關Requests PyTest Excel Allure自動化測試內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
利用python腳本提取Abaqus場輸出數(shù)據(jù)的代碼
這篇文章主要介紹了利用python腳本提取Abaqus場輸出數(shù)據(jù),利用python腳本對Abaqus進行數(shù)據(jù)提取時,要對python腳本做前步的導入處理,本文通過實例代碼詳細講解需要的朋友可以參考下2022-11-11無需邀請碼!Manus復刻開源版OpenManus下載安裝與體驗
Manus的完美復刻開源版OpenManus安裝與體驗,無需邀請碼,手把手教你如何在本地安裝與配置Manus的開源版OpenManus2025-03-03Python pyecharts實現(xiàn)繪制中國地圖的實例詳解
pyecharts是一個用于生成 Echarts 圖表的類庫。Echarts 是百度開源的一個數(shù)據(jù)可視化 JS 庫。用 Echarts 生成的圖可視化效果非常棒。本文將通過pyecharts繪制中國地圖,需要的可以學習一下2022-01-01用openCV和Python 實現(xiàn)圖片對比,并標識出不同點的方式
今天小編就為大家分享一篇用openCV和Python 實現(xiàn)圖片對比,并標識出不同點的方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12