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