国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Python+Requests實現(xiàn)接口自動化測試

這篇具有很好參考價值的文章主要介紹了Python+Requests實現(xiàn)接口自動化測試。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

一般對于自動化的理解,有兩種方式的自動化。

第一,不需要寫代碼,完全由工具實現(xiàn),這種方式的工具一般是公司自己研發(fā)的,方便黑盒測試人員使用。這種工具的特點是學習成本低,方便使用,但是通用性不強,也就是換了一家公司,就很有可能無法使用之前的工具。

第二,需要自己寫代碼,在別人的框架下編寫代碼測試,或者是需要自己搭建自動化測試框架。這種方式對測試人員的代碼要求高,學習成本高,但是通用性很強,去任何一家都可以用這套東西。
鑒于以上介紹,本文當然是介紹第二種方式了。

接口自動化測試,我們的目的是使用python進行接口測試,并完成輸出測試報告。我們需要用到的東西有如下:python3,unittest,requests。

一、接口項目

我們使用的項目是發(fā)布會簽到系統(tǒng)??偣灿?個接口,雖然不多,但足夠?qū)W習使用。

接口文檔如下:

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

二、接口用例?

軟件測試都需要寫測試用例,不管你做的性能,自動化還是其它任何的測試工作。

真實的工作寫接口的測試用例,可能考慮很多場景,如接口的功能(正常場景),接口的邊界等價,接口的異常場景,接口參數(shù)組合,接口的性能等等。本文采用輸出法分析,根據(jù)出參的不同設計出測試用例。詳細用例參考如下:(用例太小看不清楚,可以查看原圖,然后放大)?

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

三、代碼階段

3.1 框架的設計

我們使用unittest框架,case目錄存放所有的測試用例,lib目錄存放自己封裝的一些代碼,result目錄存放測試結(jié)果和測試日志,runner.py是主程序。

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

3.2 主程序 runner.py

這個主程序跟之前的《selenium unittest實戰(zhàn)》文章類似,不再詳細介紹,不太一樣的地方是使用一個logging模塊。不知道大家有沒有感受,測試接口的時候,想看完整的請求和響應,以便分析定位問題。

import unittest
import time
import os
import logging
from HTMLTestRunner import  HTMLTestRunner

#獲取項目的根目錄
test_dir = os.path.join(os.getcwd())

# 自動搜索項目根目錄下的所有case,構(gòu)造測試集;返回TestSuite對象
discover = unittest.defaultTestLoader.discover(test_dir, pattern='test_*.py')

# 實例化TextTestRunner類
# runner = unittest.TextTestRunner(verbosity=2)

now = time.strftime('%Y-%m-%d %H_%M_%S')  # 獲取當前日期
result = test_dir+ '\\result\\'+now + '_result.html'  # 測試報告的完整路徑
log = test_dir+'\\result\\'+now+'_log.txt'  #日志的完整路徑

logging.basicConfig(filename=log,level=logging.INFO,format = '%(asctime)s - %(name)s - %(levelname)s - %(message)s') #filename 日志文件路徑 level 日志的級別 format 格式

fp = open(result, 'wb')  # wb方式寫入
runner = HTMLTestRunner(stream=fp, title='測試報告', description='aguest_master項目用例執(zhí)行情況',verbosity=2)  #構(gòu)造runner

# 使用run()方法運行測試套件(即運行測試套件中的所有用例)
runner.run(discover)

3.3 測試用例和lib庫

1) 由于總共只有5個接口,所以設計為5個代碼文件,分別為:test_add_event,py,test_add_guest.py,test_get_event_list.py,test_get_guest_list.py,test_user_sign.py。

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

2)我們使用python的requests測試接口,這個庫大名鼎鼎,而且官網(wǎng)還有中文。

官網(wǎng)網(wǎng)址:http://docs.python-requests.org/zh_CN/latest/

3)每個代碼文件都是一個接口,接口的url地址是固定的,所以設計成類屬性,方便后續(xù)測試用例使用。

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

4)每個測試用例都寫明代碼邏輯,方便以后調(diào)試。
5)如果遇到經(jīng)常調(diào)用的東西,如獲取最新發(fā)布會ID,獲取添加發(fā)布會body數(shù)據(jù),都封裝成庫。
6)最后根據(jù)出參的狀態(tài)碼斷言是否成功
7)使用http://logging.info?記錄每個測試用例的日志情況

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

添加發(fā)布會接口代碼文件:test_add_event.py

import requests
import unittest
import logging
import addEventDataTemplate
import getNewID
from urllib import  parse  #使用requests發(fā)送post請求,body的漢字會進行url編碼,即%xx形式。想看到原始body,需要使用parse.unquote進入url解碼
class Test_addEvent(unittest.TestCase):
    '''添加發(fā)布會接口'''
    @classmethod
    def setUpClass(cls):
        cls.url="http://127.0.0.1:8000/api/add_event/"
    @classmethod
    def tearDownClass(cls):
        pass
    def setUp(self):
        pass
    def tearDown(self):
        pass
    def test_00(self):   #代碼邏輯::獲取當前最新發(fā)布會ID,設置入?yún)ⅲ琫id置空,發(fā)送post請求
        '''添加發(fā)布會-eid為空'''
        id=getNewID.getNewID()   #獲取當前最新發(fā)布會ID
        data=addEventDataTemplate.getEventData(id)  #獲取添加發(fā)布會的數(shù)據(jù)模板
        data['eid']=''  #eid為空,即參數(shù)錯誤
        r=requests.post(self.url,data=data)
        status=r.json()['status']
        self.assertEqual(10021,status)
        logging.info(f"case:添加發(fā)布會,eid為空\n請求地址:{r.url}\t請求方式:{r.request.method}\n請求頭:{r.request.headers}\n請求正文:{parse.unquote(r.request.body)}\n響應頭:{r.headers}\n響應正文:{r.text}\n")

    def test_01(self):    #代碼邏輯::獲取當前最新發(fā)布會ID,設置入?yún)?,發(fā)送post請求
        '''添加發(fā)布會-成功'''
        id = getNewID.getNewID()  # 獲取當前最新發(fā)布會ID
        data = addEventDataTemplate.getEventData(id)#獲取添加最新發(fā)布會的數(shù)據(jù)模板
        r=requests.post(self.url,data=data)
        status=r.json()['status']
        self.assertEqual(10000,status)
        logging.info(f"case:添加發(fā)布會,成功\n請求地址:{r.url}\t請求方式:{r.request.method}\n請求頭:{r.request.headers}\n請求正文:{parse.unquote(r.request.body)}\n響應頭:{r.headers}\n響應正文:{r.text}\n")

    def test_02(self):   #代碼邏輯::獲取當前最新發(fā)布會ID,ID-1即為發(fā)布會已經(jīng)存在的ID(發(fā)布會ID是遞增加1)
        '''添加發(fā)布會-發(fā)布會ID已存在'''
        id = getNewID.getNewID()  # 獲取當前最新發(fā)布會ID
        data=addEventDataTemplate.getEventData(id)#獲取添加最新發(fā)布會的數(shù)據(jù)模板
        data['eid']=data['eid']-1  #最新模板ID減一即為重復ID
        r=requests.post(self.url,data=data)
        status = r.json()['status']
        self.assertEqual(10022, status)
        logging.info(f"case:添加發(fā)布會,發(fā)布會ID已存在\n請求地址:{r.url}\t請求方式:{r.request.method}\n請求頭:{r.request.headers}\n請求正文:{parse.unquote(r.request.body)}\n響應頭:{r.headers}\n響應正文:{r.text}\n")
    def test_03(self):   #代碼邏輯::先新增發(fā)布會,再獲取最新發(fā)布會ID,設置入?yún)⒌膎ame為重復。
        '''添加發(fā)布會-發(fā)布會標題已存在'''
        #新增發(fā)布會
        id = getNewID.getNewID()  # 獲取當前最新發(fā)布會ID
        r=requests.post(self.url,data=addEventDataTemplate.getEventData(id))  #先新增一個發(fā)布會

        id = getNewID.getNewID()  # 獲取當前最新發(fā)布會ID
        data = addEventDataTemplate.getEventData(id)#獲取添加最新發(fā)布會的數(shù)據(jù)模板
        data['name']=f'發(fā)布會測試標題{id}' #最新模板ID減一,標題即為重復
        r=requests.post(self.url,data=data)
        status = r.json()['status']
        self.assertEqual(10023,status)
        logging.info(f"case:添加發(fā)布會,發(fā)布會標題已存在\n請求地址:{r.url}\t請求方式:{r.request.method}\n請求頭:{r.request.headers}\n請求正文:{parse.unquote(r.request.body)}\n響應頭:{r.headers}\n響應正文:{r.text}\n")
    def test_04(self):   #代碼邏輯::獲取最新發(fā)布會ID,設置入?yún)ⅲ_始時間:改為-,再提交請求
        '''添加發(fā)布會-發(fā)布會時間錯誤'''
        id = getNewID.getNewID()  # 獲取當前最新發(fā)布會ID
        data = addEventDataTemplate.getEventData(id)#獲取添加最新發(fā)布會的數(shù)據(jù)模板
        data['start_time']=data['start_time'].replace(':','-')  #時間 : 改為 - ,即為時間錯誤
        r = requests.post(self.url, data=data)
        status = r.json()['status']
        self.assertEqual(10024,status)
        logging.info(f"case:添加發(fā)布會,發(fā)布會時間錯誤\n請求地址:{r.url}\t請求方式:{r.request.method}\n請求頭:{r.request.headers}\n請求正文:{parse.unquote(r.request.body)}\n響應頭:{r.headers}\n響應正文:{r.text}\n")
if __name__ == '__main__':
    unittest.main(verbosity=2)
lib庫 getNewID.py:

def getNewID():
    '''獲取最新的(最大的)發(fā)布會編號id'''
    import sqlite3
    con=sqlite3.connect(r'D:\backup\guest2-master\db.sqlite3')
    cur=con.cursor()
    cur.execute("select max(id) from sign_event")
    new_id=cur.fetchone()
    new_id=new_id[0]
    cur.close()
    con.close()
    return new_id
lib庫 addEventDataTemplate.py:

import datetime
def getEventData(id):
    '''添加發(fā)布會 body模板'''
    startTime=(datetime.datetime.now()+datetime.timedelta(days=30)).strftime("%Y-%m-%d %H:%M:00")  #獲得當前時間,并往后30天為發(fā)布會時間

    data={
          'eid':id+1,
          'name':f"發(fā)布會測試標題{id+1}",  #當前發(fā)布會編號加1
          'limit':100,    #默認值
          'status':1,    #默認值
          'address':'新街口金鷹',    #默認值
          'start_time':startTime  #%格式   Y-%m-%d %H:%M:00
        }
    return data

由于篇幅的原因,其它的代碼省略。

最后的測試結(jié)果:

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

日志結(jié)果如下:

python中discover = unittest.defaulttestloader.discover()獲取為空,軟件測試,測試用例,單元測試,壓力測試

總結(jié):在寫代碼的過程中,每個測試用例的代碼邏輯非常重要,不管是什么邏輯,得保證每個測試用例代碼都可以獨立運行,不會產(chǎn)生耦合。還有在測試接口的時候,經(jīng)常與數(shù)據(jù)庫打交道,比如獲取數(shù)據(jù),判斷測試結(jié)果等。

【接口自動化測試】接口自動化測試框架的封裝文章來源地址http://www.zghlxwxcb.cn/news/detail-793280.html

到了這里,關于Python+Requests實現(xiàn)接口自動化測試的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權(quán),不承擔相關法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領支付寶紅包贊助服務器費用

相關文章

  • 【實戰(zhàn)詳解】如何快速搭建接口自動化測試框架?Python + Requests

    【實戰(zhàn)詳解】如何快速搭建接口自動化測試框架?Python + Requests

    本文主要介紹如何使用Python語言和Requests庫進行接口自動化測試,并提供詳細的代碼示例和操作步驟。希望能對讀者有所啟發(fā)和幫助。 隨著移動互聯(lián)網(wǎng)的快速發(fā)展,越來越多的應用程序采用Web API(也稱為RESTful API)作為數(shù)據(jù)交換的主要方式。針對API進行自動化測試已經(jīng)變得非

    2024年02月09日
    瀏覽(24)
  • Python+Requests+PyTest+Excel+Allure 接口自動化測試實戰(zhàn)

    Python+Requests+PyTest+Excel+Allure 接口自動化測試實戰(zhàn)

    本文主要介紹了Python+Requess+PyTest+Excel+Allure 接口自動化測試實戰(zhàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧 Unittest是Python標準庫中自帶的單元測試框架,Unittest有時候也被稱為PyUnit,就像

    2024年02月07日
    瀏覽(100)
  • 一個簡單的接口自動化測試框架:Python+Requests+Pytest+Allure

    一個簡單的接口自動化測試框架:Python+Requests+Pytest+Allure

    project:api_test ——api_keyword ————api_key.py:接口驅(qū)動類 ——case ————test_cases.py:測試套件和測試用例 ——report_allure( 無需創(chuàng)建 ):allure報告 ——result( 無需創(chuàng)建 ):測試用例運行結(jié)果 ——VAR ————VAR.py:常量類 conftest.py:項目級別fixture main.py:主函數(shù)

    2024年02月03日
    瀏覽(95)
  • Python接口自動化測試-篇1(postman+requests+pytest+allure)

    Python接口自動化測試-篇1(postman+requests+pytest+allure)

    Python接口自動化測試是一種使用Python編程語言來編寫腳本以自動執(zhí)行針對應用程序接口(APIs)的測試過程。這種測試方法專注于檢查系統(tǒng)的不同組件或服務之間的交互,確保它們按照預期規(guī)范進行通信,而不涉及用戶界面(UI)的驗證。 目錄 一、接口測試基礎 二、工具實現(xiàn)

    2024年04月17日
    瀏覽(92)
  • python+requests接口自動化框架的實現(xiàn)

    python+requests接口自動化框架的實現(xiàn)

    為什么要做接口自動化框架 1、業(yè)務與配置的分離 2、數(shù)據(jù)與程序的分離;數(shù)據(jù)的變更不影響程序 3、有日志功能,實現(xiàn)無人值守 4、自動發(fā)送測試報告 5、不懂編程的測試人員也可以進行測試 正常接口測試的流程是什么? 確定接口測試使用的工具-----配置需要的接口參數(shù)----

    2024年03月13日
    瀏覽(28)
  • (Python)Requests+Pytest+Allure接口自動化測試框架從0到1搭建

    (Python)Requests+Pytest+Allure接口自動化測試框架從0到1搭建

    前面,已經(jīng)學習了如何用SpringBoot寫接口以及與Mysql數(shù)據(jù)庫進行交互,具體可查閱下面的這篇博客,今天學習一下基于Python的接口自動化測試框架的搭建,主要包括以下內(nèi)容:利用request庫發(fā)送請求,請求數(shù)據(jù)參數(shù)化處理,還涉及到數(shù)據(jù)庫(Mysql+MongDB)方面的交互,包括如何取數(shù)

    2024年02月13日
    瀏覽(721)
  • 接口自動化測試-Python+Requests+Pytest+YAML+Allure配套擼碼(詳細)

    接口自動化測試-Python+Requests+Pytest+YAML+Allure配套擼碼(詳細)

    接口自動化框架:Python+Requests+Pytest+YAML+Allure 通過 Python+Requests 來發(fā)送和處理HTTP協(xié)議的請求接口,使用 Pytest 作為測試執(zhí)行器,使用 YAML 來管理測試數(shù)據(jù),使用 Allure 來生成測試報告。 框架結(jié)構(gòu) api ==== 接口封裝層,如封裝HTTP接口為Python接口 common ==== 各種工具類 core ==== reques

    2024年02月15日
    瀏覽(98)
  • Python+Requests+Pytest+Excel+Allure 接口自動化測試項目實戰(zhàn)【框架之間的對比】

    Python+Requests+Pytest+Excel+Allure 接口自動化測試項目實戰(zhàn)【框架之間的對比】

    ? ? ? ? --------UnitTest框架和PyTest框架的簡單認識對比與項目實戰(zhàn)-------- 定義: Unittest是Python標準庫中自帶的單元測試框架,Unittest有時候也被稱為PyUnit,就像JUnit是Java語言的標準單元測試框架一樣,Unittest則是Python語言的標準單元測試框架。 Pytest是Python的另一個第三方單元測

    2024年02月09日
    瀏覽(94)
  • Python+Requests+Pytest+YAML+Allure實現(xiàn)接口自動化

    Python+Requests+Pytest+YAML+Allure實現(xiàn)接口自動化

    本項目實現(xiàn)接口自動化的技術(shù)選型:Python+Requests+Pytest+YAML+Allure ,主要是針對之前開發(fā)的一個接口項目來進行學習,通過 Python+Requests 來發(fā)送和處理HTTP協(xié)議的請求接口,使用 Pytest 作為測試執(zhí)行器,使用 YAML 來管理測試數(shù)據(jù),使用 Allure 來生成測試報告 本項目在實現(xiàn)過程中,把

    2024年02月11日
    瀏覽(790)
  • 基于python實現(xiàn)Web自動化測試(selenium)、API自動化測試(requests)&附學習視頻

    基于python實現(xiàn)Web自動化測試(selenium)、API自動化測試(requests)&附學習視頻

    另一篇文章 :自動化測試框架(pytest)附學習視頻 學習視頻,學習文檔-白月黑羽 說明: 1緊跟著寫的不加/,不加空格-表示同一級別信息,加空格表示后代 2.css定位tag,id,class時分別有不同的標識,其他屬性都要加[]進行搜索, Xpath所有屬性都要都加【】,tag不用 3. css在使用ta

    2024年02月03日
    瀏覽(24)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包