主頁 >  其他 > 領導看了給你加薪!python +ddt+excel 一招鮮,介面自動化測驗輕松搞定,測驗報告驚艷四座!

領導看了給你加薪!python +ddt+excel 一招鮮,介面自動化測驗輕松搞定,測驗報告驚艷四座!

2023-06-08 08:10:29 其他

 介面自動化測驗是指通過撰寫代碼或使用工具,模擬用戶發送請求,驗證介面是否符合設計規范和功能需求的程序,

如何用 python +ddt+excel 實作介面自動化測驗

介面自動化測驗可以提高測驗效率和質量,節省測驗成本和時間,保證測驗覆寫率和可維護性,

讓勇哥帶你入門如何用 python +ddt+excel 實作介面自動化測驗,請瞧如下內容:

一、準備作業

1. 安裝 python 環境

python 是一種簡潔、優雅、易學的編程語言,它有豐富的第三方庫和社區支持,非常適合用來進行介面自動化測驗,安裝 python 的3.0以上的版本),并配置好環境變數,以便在命令列中使用 python 命令,

2. 安裝相關庫

為了進行介面自動化測驗,我們需要安裝以下幾個庫:

  • requests:用來發送 HTTP 請求,支持各種方法、引數、頭部、身份驗證等,

  • xlrd:用來讀取 excel 檔案中的資料,支持 xls 和 xlsx 格式,

  • openpyxl:用來寫入 excel 檔案中的資料,支持 xlsx 格式,

  • ddt:用來實作資料驅動測驗,可以從 excel 檔案中讀取多組資料,并生成多個測驗用例,

  • unittest:用來撰寫和執行測驗用例,支持斷言、前置后置條件、測驗套件等,

  • HTMLTestRunner_api:用來生成 HTML 格式的測驗報告,支持圖表、日志、截圖等,

我們可以使用 pip 命令來安裝這些庫,例如:

pip install requests

二、設計測驗

1. 撰寫 excel 檔案

我們需要在 excel 檔案中填寫介面的相關資訊,包括:

  • 介面名稱

  • 請求地址

  • 請求方法

  • 請求引數

  • 預期結果

例如:

我們可以將這個 excel 檔案保存為 test_data.xlsx,并放在專案的 test_datas 目錄下,

2. 封裝 excel 操作

為了方便地讀取和寫入 excel 檔案中的資料,我們需要封裝一些 excel 操作的函式,例如:

  • 打開表單

  • 獲取表頭

  • 獲取所有資料

  • 寫入資料

我們可以將這些函式定義在一個類中,并保存為 excel_handler.py,并放在專案的 Lib 目錄下,具體代碼如下:

from openpyxl import load_workbook
from openpyxl.worksheet.worksheet import Worksheet

class ExcelHandler():
    '''操作Excel'''
    def __init__(self, file):
        '''初始化函式'''
        self.file = file
    
    def open_sheet(self, sheet_name) -> Worksheet:
        '''打開表單'''
        wb = load_workbook(self.file)
        sheet = wb[sheet_name]
        return sheet
    
    def read_rows(self,sheet_name):
        '''讀取除表頭外所有資料(除第一行外的所有資料)'''
        sheet = self.open_sheet(sheet_name)
        rows = list(sheet.rows)[1:]
        data = https://www.cnblogs.com/Nephalem-262667641/p/[]
        for row in rows:
            row_data = []
            for cell in row:
                row_data.append(cell.value)
            data.append(row_data)
        return data
     def read_key_value(self,sheet_name):
        '''獲取所有資料,將表頭與內容結合整....'''                ...
        return data

3. 封裝 requests 請求

為了方便地發送 HTTP 請求,我們需要封裝一些 requests 請求的函式,例如:

  • 初始化 session

  • 發送請求

  • 關閉 session

我們可以將這些函式定義在一個類中,并保存為 requests_handler.py,并放在專案的 Lib 目錄下,具體代碼如下:

import requests

class HTTPHandler:
    # 初始化
    def __init__(self):
        self.session = requests.Session()
    
    # 定義一個方法,接收訪問http請求的方式
    def visit(self, url, method, params=None, data=https://www.cnblogs.com/Nephalem-262667641/p/None, json=None, **kwargs):
        res = self.session.request(method, url, params=params, data=data, json=json, **kwargs)
        try:
            return res.json()
        except ValueError:
            print('return not json')
    
    # 關閉session會話
    def close_session(self):
        self.session.close()

三、執行測驗

1. 撰寫測驗用例

我們需要使用 unittest 和 ddt 來撰寫和執行測驗用例,具體步驟如下:

  • 匯入相關庫和模塊

  • 定義一個測驗類,繼承 unittest.TestCase

  • 定義一個類方法,用來初始化 session 和讀取 excel 檔案中的資料

  • 使用 @ddt.data 裝飾器,傳入 excel 檔案中的資料

  • 定義一個測驗方法,用來發送請求,并斷言回應結果是否符合預期

我們可以將這些代碼保存為 test_api.py,并放在專案的 test_cases 目錄下,具體代碼如下:

from Lib.excel_handler import ExcelHandler
from Lib.requests_handler import HTTPHandler
import requests
import ddt
import unittest

data = https://www.cnblogs.com/Nephalem-262667641/p/ExcelHandler('test_datas/test_data.xlsx').read_key_value('Sheet1')

@ddt.ddt
class TestAPI(unittest.TestCase):
    @classmethod
    def setUpClass(cls):
        cls.s = HTTPHandler()
    
    @ddt.data(*data)
    def test_api(self,params):
        print('params:%s' % params)
        case_name = params.get('介面名稱')
        url = params.get('請求地址')
        args = eval(params.get('請求引數')) if isinstance(params.get('請求引數'), str) else params.get('請求引數')
        method = params.get('請求方法')
        expct_res1 = params.get('預期結果')
        
        # 發起請求,獲取回傳資料
        result = self.s.visit(url, method, params=args)

        # 分析回傳資料
        response_data = https://www.cnblogs.com/Nephalem-262667641/p/result['name']

        
        # 斷言回應結果是否符合預期
        self.assertEqual(expct_res1, response_data)

    @classmethod
    def tearDownClass(cls):
       cls.s.close_session()

2. 生成測驗報告

我們需要使用 HTMLTestRunner_api 來生成 HTML 格式的測驗報告,具體步驟如下:

  • 匯入相關庫和模塊

  • 定義一個測驗套件,添加測驗用例

  • 定義一個測驗報告的檔案名和路徑

  • 定義一個測驗運行器,傳入測驗報告的檔案物件和相關引數

  • 使用測驗運行器來運行測驗套件

我們可以將這些代碼保存為 run.py,并放在專案的根目錄下,具體代碼如下:

import unittest
from HTMLTestRunner_api import HTMLTestRunner
from test_cases.test_api import TestAPI

# 定義一個測驗套件
suite = unittest.TestSuite()
# 添加測驗用例
suite.addTest(unittest.makeSuite(TestAPI))

# 定義一個測驗報告的檔案名和路徑
report_file = 'reports/test_report.html'

# 定義一個測驗運行器,傳入測驗報告的檔案物件和相關引數
with open(report_file, 'wb') as f:
    runner = HTMLTestRunner(f, title='介面自動化測驗報告', description='用例執行情況')
    # 使用測驗運行器來運行測驗套件
    runner.run(suite)

四、查看結果

運行 run.py 檔案后,我們可以在 reports 目錄下看到生成的 test_report.html 檔案,打開它,我們可以看到以下內容:

我們可以看到,共有 11 個測驗用例,通過 6 個,失敗 5 個,我們還可以看到每個測驗用例的詳細資訊,包括用例名稱、請求地址、請求引數、預期結果、實際結果等,我們還可以看到一些圖表、日志、截圖等,

這樣,我們就完成了用 python +ddt+excel 實作介面自動化測驗的程序,

 

總結

以上就是勇哥今天為各位小伙伴準備的內容,如果你想了解更多關于Python自動化測驗的知識和技巧,歡迎關注:

我的公眾號:百態測驗

博客(奈非天的主頁 - 博客園 (cnblogs.com))

我會不定期地分享更多的精彩內容,感謝你的閱讀和支持!

本文來自博客園,作者:奈非天,轉載請注明原文鏈接:https://www.cnblogs.com/Nephalem-262667641/p/17460169.html

本文來自博客園,作者:奈非天,轉載請注明原文鏈接:https://www.cnblogs.com/Nephalem-262667641/p/17463255.html

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/554555.html

標籤:其他

上一篇:用我這5年多的經歷告訴你:一些無力吐槽的自動化現狀……好自為之

下一篇:返回列表

標籤雲
其他(160536) Python(38215) JavaScript(25478) Java(18209) C(15237) 區塊鏈(8270) C#(7972) AI(7469) 爪哇(7425) MySQL(7235) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5873) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4585) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2434) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1983) 功能(1967) HtmlCss(1952) Web開發(1951) C++(1933) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1879) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 領導看了給你加薪!python +ddt+excel 一招鮮,介面自動化測驗輕松搞

    “ 介面自動化測驗是指通過撰寫代碼或使用工具,模擬用戶發送請求,驗證介面是否符合設計規范和功能需求的程序。” 如何用 python +ddt+excel 實作介面自動化測驗 介面自動化測驗可以提高測驗效率和質量,節省測驗成本和時間,保證測驗覆寫率和可維護性。 讓勇哥帶你入門如何用 python +d ......

    uj5u.com 2023-06-08 08:10:29 more
  • 用我這5年多的經歷告訴你:一些無力吐槽的自動化現狀……好自為之

    接觸自動化至今,已經有5年了,從剛接觸UI自動化(unittest+selenium)到接觸介面自動化(unittest+requests)再到自己撰寫自動化平臺(后臺使用python的flask,前端使用element+vue,沒有第三方自動化框架),不斷的學習成長,加深了對自動化測驗的理解,這邊... ......

    uj5u.com 2023-06-08 08:10:21 more
  • 5.1 檔案操作(讀寫、追加等)

    在 Python 中,檔案操作是一項常用的任務。本節將介紹如何執行基本的檔案操作,如讀取、寫入和追加資料。我們將通過實體代碼詳細講解每個知識點。 ### 5.1.1 打開檔案 在對檔案進行操作之前,我們需要使用 `open()` 函式打開它。`open()` 函式接受兩個引數:檔案名(包括路徑)和模 ......

    uj5u.com 2023-06-08 08:10:05 more
  • 頂象發布《車企App安全研究白皮書》,剖析品牌汽車App的兩大類風險

    ![圖片](https://mmbiz.qpic.cn/mmbiz_gif/Qk5wiatq1gWMXM8AD19laQkHjALvSLERCKS7IXrSPgFzqwL6MjQgTicZLyliasVbn5UfjXp0ClKyNt3APmvAVradQ/640?wx_fmt=gif&wxfrom= ......

    uj5u.com 2023-06-08 08:09:59 more
  • 健康食物功效大全ACCESS資料庫

    記得之前采集過一個叫《近2千條日常食物營養表ACCESS資料庫》的資料庫,今天從一個叫營養師健康飲食的產品中獲得了《健康食物功效大全ACCESS資料庫》,感覺這個強勁很多。有食物主表、食物介紹、食物功效三個表。 食物主表屬性欄位有:水分、酒精(克)、能量(卡)、蛋白質(克)、脂肪(克)、碳水化合物( ......

    uj5u.com 2023-06-07 09:36:50 more
  • 2.3. 介面與抽象類

    介面和抽象類是 Java 中兩種實作抽象和多型的方法。它們之間有一些區別,但也有一些相似之處。這一節我們將通過詳細的例子來更深入地了解介面和抽象類。 #### 2.3.1. 介面 介面可以定義一組方法簽名,但不能包含方法的實作。一個類可以實作多個介面,實作介面的類必須實作介面中定義的所有方法。 定義 ......

    uj5u.com 2023-06-07 09:36:17 more
  • 健康食物功效大全ACCESS資料庫

    記得之前采集過一個叫《近2千條日常食物營養表ACCESS資料庫》的資料庫,今天從一個叫營養師健康飲食的產品中獲得了《健康食物功效大全ACCESS資料庫》,感覺這個強勁很多。有食物主表、食物介紹、食物功效三個表。 食物主表屬性欄位有:水分、酒精(克)、能量(卡)、蛋白質(克)、脂肪(克)、碳水化合物( ......

    uj5u.com 2023-06-07 09:21:24 more
  • 手把手教你用Stable Diffusion寫好提示詞

    Stable Diffusion 技術把 AI 影像生成提高到了一個全新高度,文生圖 Text to image 生成質量很大程度上取決于你的提示詞 Prompt 好不好。本文從“如何寫好提示詞”出發,從提示詞構成、調整規則和 chatGPT 輔助工具等角度,對文生圖的提示詞輸入進行歸納總結。 ......

    uj5u.com 2023-06-07 08:09:21 more
  • 讀資料壓縮入門筆記04_統計編碼

    一種新的精確熵編碼方法,所得到的結果可以和最優熵任意接近,它的壓縮率與算術編碼接近,而性能則與哈夫曼編碼相當 ......

    uj5u.com 2023-06-07 08:08:47 more
  • k8s實戰案例之部署redis單機和redis cluster

    redis是一款基于BSD協議,開源的非關系型資料庫(nosql資料庫),作者是意大利開發者Salvatore Sanfilippo在2009年發布,使用C語言撰寫;redis是基于記憶體存盤,而且是目前比較流行的鍵值資料庫(key-value database),它提供將記憶體通過網路遠程共享的一種服... ......

    uj5u.com 2023-06-07 08:07:54 more