Pytest框架 — 10、Pytest的標記(一)

来源:https://www.cnblogs.com/qishuaiRisen/archive/2022/08/18/16599547.html
-Advertisement-
Play Games

1、標記跳過 在自動化測試過程中,我們經常會遇到因為某些功能阻塞,未開發完成或者環境等問題,一些測試用例不能執行,如果人工去註釋掉,後面還需要再恢復才能繼續測試,pytest的標記跳過功能就可以實現暫時跳過。 (一)無條件跳過skip 使用方法:通過@pytest.mark.skip(reason= ...


目錄

1、標記跳過

在自動化測試過程中,我們經常會遇到因為某些功能阻塞,未開發完成或者環境等問題,一些測試用例不能執行,如果人工去註釋掉,後面還需要再恢復才能繼續測試,pytest的標記跳過功能就可以實現暫時跳過。

(一)無條件跳過skip

使用方法:通過@pytest.mark.skip(reason=跳過原因)裝飾器標記要跳過的測試用例

  • 參數reason:跳過的原因,非必填
import pytest


@pytest.mark.skip
def test_register():
    # 測試註冊功能
    raise Exception("該功能尚未開發完成")


@pytest.mark.skip(reason="該功能尚未開發完成")
def test_logout():
    # 註銷
    raise Exception("該功能尚未開發完成")


def test_login():
    # 登錄功能
    assert True

"""
執行結果
mark/skip_mark.py::test_register SKIPPED (unconditional skip)
mark/skip_mark.py::test_logout SKIPPED (該功能尚未開發完成)
mark/skip_mark.py::test_login PASSED
"""

(二)有條件跳過skipif

使用方法:通過@pytest.mark.skipif(condition=跳過條件,reason=跳過原因)標記要跳過的測試用例。

  • 參數condition:跳過的條件,值為True則跳過,值為False則繼續執行,預設值為True
  • 參數reason:必填,跳過的原因
import pytest

version = 3.0


@pytest.mark.skipif(condition=version > 3.0 or version == 3.0, reason="3.0及以上版本不提供下載功能")
def test_download():
    print("下載功能")


def test_upload():
    print("上傳功能")


"""
執行結果
mark/skipif_mark.py::test_download SKIPPED (3.0及以上版本不提供下載功能)
mark/skipif_mark.py::test_upload 上傳功能
PASSED
"""

2、標記實現參數化

通過@pytest.mark.parametrize(argnames, argvalues, indirect=False, ids=None, scope=None)裝飾器來實現參數化。

參數說明:

  • argnames:參數名,使用逗號分隔的列表,或元祖,或字元串,表示一個或多個參數名,【常用】
  • argvalues:參數值,可以是列表、元祖、字典列表、字典元祖,【常用】
  • indirect:中文翻譯為中間人,為True時可以對argvalues的參數值進行處理,預設False,【不常用】
    • indirect=True: 且argnames的值為fixture函數名,此時argnames的值變為可執行函數,會將argvalues的參數值當做參數傳遞給fixture函數進行處理,fixture函數返回處理結果給argnames
    • indirect=False: argnames僅為參數名
  • ids:給用例起別名,字元串列表或數字列表,不設置會自動從測試數據中提取
  • scope:待理解【不常用】

示例1:單個參數

import pytest


phone_list = [
    "13881118888",
    "13012034288",
    "13234324188",
    "13231423288"
]

@pytest.mark.parametrize(argnames="phone_num", argvalues=phone_list)
def test_phone_number(phone_num):  # 註意,這裡的參數要和argnames參數名一致
    print(f"正在測試手機號{phone_num}")

"""
執行結果
mark/parametrize/single_param.py::test_phone_number[13881118888] 正在測試手機號13881118888
PASSED
mark/parametrize/single_param.py::test_phone_number[13012034288] 正在測試手機號13012034288
PASSED
mark/parametrize/single_param.py::test_phone_number[13234324188] 正在測試手機號13234324188
PASSED
mark/parametrize/single_param.py::test_phone_number[13231423288] 正在測試手機號13231423288
PASSED
"""

示例2:多個參數

import pytest

user_info = [
    ("張三", "18011111111"),
    ("李四", "18022222222"),
    ("王五", "18033333333")
]

@pytest.mark.parametrize(argnames="name,phonenum", argvalues=user_info)
def test_read_info(name, phonenum):
    print(f"正在讀取用戶{name},手機號{phonenum}")

"""
執行結果
mark/parametrize/multiple_param.py::test_read_info[\u5f20\u4e09-18011111111] 正在讀取用戶張三,手機號18011111111
PASSED
mark/parametrize/multiple_param.py::test_read_info[\u674e\u56db-18022222222] 正在讀取用戶李四,手機號18022222222
PASSED
mark/parametrize/multiple_param.py::test_read_info[\u738b\u4e94-18033333333] 正在讀取用戶王五,手機號18033333333
PASSED
"""

由上面例子執行結果中可以看到中文參數值亂碼了,解決辦法如下
方法1. 在pytest.ini中加入disable_test_id_escaping_and_forfeit_all_rights_to_community_support=True
方法2. 在conftest.py中加入

# 收集每一個用例name和nodeid的中文顯示,轉化為utf-8形式
def pytest_collection_modifyitems(items):
    for item in items:
        item.name = item.name.encode("utf-8").decode("unicode_escape")
        item._nodeid = item.nodeid.encode("utf-8").decode("unicode_escape")

示例3:多個參數化(笛卡爾積)

import pytest


data1 = ['a', 'b', 'c']
data2 = [1, 2]


@pytest.mark.parametrize('test1', data1)
@pytest.mark.parametrize('test2', data2)
def test_param(test1, test2):
    print('\n測試數據:{}-{}'.format(test1, test2))
"""
執行結果
mark/parametrize/multiple_parameterization.py::test_param[1-a] 
測試數據:a-1
PASSED
mark/parametrize/multiple_parameterization.py::test_param[1-b] 
測試數據:b-1
PASSED
mark/parametrize/multiple_parameterization.py::test_param[1-c] 
測試數據:c-1
PASSED
mark/parametrize/multiple_parameterization.py::test_param[2-a] 
測試數據:a-2
PASSED
mark/parametrize/multiple_parameterization.py::test_param[2-b] 
測試數據:b-2
PASSED
mark/parametrize/multiple_parameterization.py::test_param[2-c] 
測試數據:c-2
PASSED
"""

示例4:ids參數給用例起別名

import pytest


user_info = [
    ("張三", "18011111111"),
    ("李四", "18022222222"),
    ("王五", "18033333333")
]

@pytest.mark.parametrize(argnames="name,phonenum", argvalues=user_info, ids=["用戶1","用戶2","用戶3"])
def test_read_info(name, phonenum):
    print(f"正在讀取用戶{name},手機號{phonenum}")
    
"""
執行結果
mark/parametrize/ids.py::test_read_info[用戶1] 正在讀取用戶張三,手機號18011111111
PASSED
mark/parametrize/ids.py::test_read_info[用戶2] 正在讀取用戶李四,手機號18022222222
PASSED
mark/parametrize/ids.py::test_read_info[用戶3] 正在讀取用戶王五,手機號18033333333
PASSED
"""

示例5:使用indirect處理參數值

import pytest

@pytest.fixture()
def fixture_and_parametrize(request):  # request是關鍵字不能改變,用來接收參數
    print('郵箱賬號為:{}'.format(request.param))
    return request.param + "@qq.com"


@pytest.mark.parametrize('fixture_and_parametrize', ['100203', '466238894', '23942423'],
                         indirect=True)
def test_fixture_and_parametrize_2(fixture_and_parametrize):
    print('拼接後郵箱為:{}'.format(fixture_and_parametrize))

"""
執行結果
mark/parametrize/indirect.py::test_fixture_and_parametrize_2[100203] 郵箱賬號為:100203
拼接後郵箱為:[email protected]
PASSED
mark/parametrize/indirect.py::test_fixture_and_parametrize_2[466238894] 郵箱賬號為:466238894
拼接後郵箱為:[email protected]
PASSED
mark/parametrize/indirect.py::test_fixture_and_parametrize_2[23942423] 郵箱賬號為:23942423
拼接後郵箱為:[email protected]
PASSED
"""

示例6:標記數據

在參數化的過程中也可以標記數據進行跳過等

import pytest


@pytest.mark.parametrize("test_input,expected", [
    ("3+9", 12), ("5+4", 9),
    pytest.param("7 * 9", 42, marks=pytest.mark.xfail),
    pytest.param("8 * 6", 42, marks=pytest.mark.skip)
])
def test_mark(test_input, expected):
    assert eval(test_input) == expected
"""
執行結果
mark/parametrize/mark_data.py::test_mark[3+9-12] PASSED
mark/parametrize/mark_data.py::test_mark[5+4-9] PASSED
mark/parametrize/mark_data.py::test_mark[7 * 9-42] XFAIL
mark/parametrize/mark_data.py::test_mark[8 * 6-42] SKIPPED (unconditional skip)
"""

參考
https://www.cnblogs.com/miki-peng/p/14736332.html
https://zhuanlan.zhihu.com/p/515377205


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 爬取 flbook 文檔 需求介紹 由於實習期間被主管委派了下載下來《安徽省助企政策彙編》的任務,去大概搜索瞭解了一下 flbook 網站,發現該網站並不提供已經發佈的文檔的下載渠道(感覺挺莫名其妙的,都公開允許觀看了,為什麼不給下載渠道啊,更何況還是個政府文件,發佈在這種網站上,總覺得哪裡有問題) ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • 0. 標簽順序 Mybatis核心配置文件中有很多標簽,它們誰誰寫在前寫在後其實是:boom:有順序:boom:要求的: 從前到後: properties?,settings?,typeAliases?,typeHandlers?,objectFactory?,objectWrapperFactor ...
  • 2.函數的遞歸的定義 函數的遞歸調用:是函數嵌套調用的一種特殊形式 具體是指:在調用一個函數的過程中又直接或者間接的調用到本身,是一個死迴圈,最大遞歸是1000次,超出之後報錯。 2.函數遞歸的調用 # 直接調本身 def f1(): print('是我還是我') f1() f1() # 間接調用 ...
  • 當我們拿到一個對象的引用時,如何知道這個對象是什麼類型、有哪些方法呢? 1.使用type() 首先,我們來判斷對象類型,使用type()函數: 基本類型都可以用type()判斷: >>> type(123) <class 'int'> >>> type('str') <class 'str'> >> ...
  • 1、先配置spring、springmvc通用xml文件的頭部信息 spring、springmvc通用xml文件的模板內容如下: 1 <?xml version="1.0" encoding="UTF-8"?> 2 <beans xmlns="http://www.springframework. ...
  • 使用文件流對文件進行複製: package io; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOExce ...
  • K 哥之前寫過一篇關於百度翻譯逆向的文章,也在 bilibili 上出過相應的視頻,最近在 K 哥爬蟲交流群中有群友提出,百度翻譯新增了一個請求頭參數 Acs-Token,如果不攜帶該參數,直接按照以前的方法進行處理,會出現 1022 報錯,並且如果直接將 Acs-Token 寫成定值,前幾次可能能 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...