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

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

2023-06-08 08:23:22 其他

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

如何用 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/archive/2023/06/07/[]
        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/archive/2023/06/07/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/archive/2023/06/07/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/archive/2023/06/07/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/554579.html

標籤:其他

上一篇:位元組技術面都過了,薪資都談好了20K*13結果還是被刷了,問HR,原因是。。

下一篇:返回列表

標籤雲
其他(160560) 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:23:22 more
  • 位元組技術面都過了,薪資都談好了20K*13結果還是被刷了,問HR,原因

    分享下自己的求職小故事。在一家公司軟體測驗技術面試已經過了,然后和最終面試官溝通了下,面試官提出來一個薪資數字,我接受了這個提議并和hr同步了這個數字。再然后被拒了,理由就是期望薪資和職級不匹配。我詢問后有郵件回復我為什么面試官和面試的地區公司hr說了不算。不知道這是不是大家都曾經遇到過的情況,心情... ......

    uj5u.com 2023-06-08 08:22:36 more
  • CodeGeeX 2.0版本重大升級:通過聊天對話的方式直接操作代碼

    CodeGeeX 2.0版本正式上線!從命名上看這是一次大版本的升級。 上個月,**[CodeGeeX](https://codegeex.cn/)**在VSCode和JetBrains IDEs的插件中,加入了智能問答(Ask CodeGeeX)功能,讓用戶可以在IDE中通過問答對話的方式解決技術 ......

    uj5u.com 2023-06-08 08:21:52 more
  • “古老”編程語言的最新選擇!華為云發布CodeArts IDE for C/C++

    摘要:華為云CodeArts IDE for C/C++正式上線,歡迎體驗。 本文分享自華為云社區《“古老”編程語言的最新選擇!華為云發布CodeArts IDE for C/C++》,作者:華為云頭條 。 C語言是一種“古老”且應用至今的高級編程語言,它是多種流行編程語言的根源。C++進一步擴充和 ......

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

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

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

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

    uj5u.com 2023-06-08 08:21:20 more
  • jenkins~權限控制

    jenkins上管理的任務比較多,這時需要有一定的權限管控機制,我們選擇了插件`Role-based Authorization Strategy`來做這事,它支持按著專案前綴去控制你的任務,主要思想還是rbac的模式,通過角色系結權限,通過用戶來系結角色。 # 安裝之后 ![](https://i ......

    uj5u.com 2023-06-08 08:21:07 more
  • Serverless: AI everywhere的下一塊拼圖

    摘要:本文介紹華為云函式作業流(FunctionGraph)的靈活、速度,如何讓開發人員提升工程效率,縮短TTM等 本文分享自華為云社區《華為云FunctionGraph函式作業流—— Serverless“遇見”AI,釋放AI生產力》,作者: 華為云PaaS服務小智 。 華為云Serverless ......

    uj5u.com 2023-06-08 08:20:20 more
  • 南洋才女,德藝雙馨,孫燕姿本尊回應AI孫燕姿(基于Sadtalker/Pytho

    孫燕姿果然不愧是孫燕姿,不愧為南洋理工大學的高材生,近日她在個人官方媒體博客上寫了一篇英文版的長文,正式回應現在滿城風雨的“AI孫燕姿”現象,流行天后展示了超人一等的智識水平,行文優美,綿恒雋永,對AIGC藝術表現得極其克制,又相當寬容,充滿了語言上的古典之美,表現出了“任彼如泰山壓頂,我只當清風拂 ......

    uj5u.com 2023-06-08 08:20:09 more
  • 完全免費白嫖 GPT-4 的終極方案!

    > 原文鏈接:[https://icloudnative.io/posts/completely-free-to-use-gpt4/](https://icloudnative.io/posts/completely-free-to-use-gpt4/) ![](https://img2023.cn ......

    uj5u.com 2023-06-08 08:19:06 more