Pytest 使用命令行參數執行指定環境的腳本—— Python 實踐

🧾 一、項目背景

????????在自動化測試中,我們經常需要根據不同的運行環境(如測試環境和生產環境)來執行測試腳本。本文將詳細介紹如何通過命令行參數來指定運行環境,并使用 Python 和 pytest 框架實現這一功能。

🛠? 二、配置文件設置

首先,在項目的配置文件中定義不同環境下的相關參數。以 setting.py 文件為例:

# 優先從環境變量讀取運行環境
DOMAIN_ENV = os.getenv("DOMAIN_ENV", "test")  # 默認為 testDOMAINS = {"prod": "https:********",   # 線上環境域名"test": "http:*********"  # 測試環境域名
}# Webhook 配置(用于企業微信消息推送)
WEBHOOK_URLS = {"prod": "https:***************",    # 線上企微機器人地址"test": "https:***************"     # 測試企微機器人地址
}# 根據當前環境選擇基礎域名
DOMAIN = DOMAINS.get(DOMAIN_ENV, DOMAINS["test"])  # 默認使用測試環境# 獲取當前環境下的 Webhook URL
WEBHOOK_URL = WEBHOOK_URLS.get(DOMAIN_ENV, WEBHOOK_URLS["test"])# 獲取 token 的配置
TOKEN_CONFIGS = {"prod": {"M": {"url": "/*********",     # 登錄接口"headers": {"Content-Type": "application/json; charset=UTF-8"},"data": {"username": "員工1", "password": "123456"},"jsonpath_expr": "$.data.accessToken"},"P": {"url": "/*********",     # 登錄接口"headers": {"Content-Type": "application/json; charset=UTF-8"},"data": {"username": "員工2", "password": "123456"},"jsonpath_expr": "$.data.accessToken"}},"test": {"M": {"url": "/*********",     # 登錄接口"headers": {"Content-Type": "application/json; charset=UTF-8"},"data": {"username": "員工3", "password": "123456"},"jsonpath_expr": "$.data.accessToken"},"P": {"url": "/*********",     # 登錄接口"headers": {"Content-Type": "application/json; charset=UTF-8"},"data": {"username": "員工4", "password": "123456"},"jsonpath_expr": "$.data.accessToken"}}
}# 當前環境下的 token 配置
TOKEN_CONFIG_M = TOKEN_CONFIGS[DOMAIN_ENV]["M"]
TOKEN_CONFIG_P = TOKEN_CONFIGS[DOMAIN_ENV]["P"]

在這個配置文件中,我們定義了兩個環境:prod 和 test,并且可以根據環境變量 DOMAIN_ENV 來決定使用哪個環境。

📦 三、主程序邏輯

接下來,我們需要編寫一個主程序來解析命令行參數,并據此設置環境變量。以下是 run.py 文件的內容:

import os
import argparsedef main():"""主函數負責解析命令行參數并調用測試運行邏輯。"""# 定義 ArgumentParser 并解析所有參數parser = argparse.ArgumentParser(description="運行測試用例并生成 Allure 報告")parser.add_argument("--test-path",type=str,default="tests",help="測試文件或目錄的路徑,默認為 'tests'")parser.add_argument("--extra-args",nargs="*",default=[],help="額外的 pytest 命令行參數")parser.add_argument("--env",type=str,default="test",choices=["test", "prod"],help="指定運行環境: test 或 prod,默認為 test")args = parser.parse_args()# 設置環境變量os.environ["DOMAIN_ENV"] = args.envprint(f"Setting DOMAIN_ENV to: {args.env}")# 運行 pytestpytest.main()# 從 conftest 中導入全局變量 failed_resultsfrom conftest import failed_resultssend_to_wechat_robot(WEBHOOK_URL, failed_results)

解釋:

1、命令行參數解析:

  • --test-path: 指定測試文件或目錄的路徑,默認是 tests。
  • --extra-args: 允許傳遞額外的 pytest 命令行參數。
  • --env: 指定運行環境,可選值為 test 或 prod,默認是 test。

2、設置環境變量:

  • 在解析完命令行參數后,我們將環境變量 DOMAIN_ENV 設置為用戶提供的值。這樣,當我們在代碼中訪問這個環境變量時,就可以知道應該使用哪個環境的配置。

3、運行測試:

  • 使用 pytest.main() 方法來運行測試,并傳遞構建好的命令行參數。
  • 最后,將失敗的結果發送到企業微信機器人。

🔁 四、命令行運行腳本

要運行腳本并指定測試環境,可以使用以下命令:

python run.py --env=test

或者對于生產環境:

python run.py --env=prod

你還可以指定測試路徑和其他 pytest 參數:

python run.py --env=test --test-path=tests/smoke --extra-args="--html=report.html"

? 五、總結

????????通過以上步驟,我們可以輕松地根據命令行參數來指定運行環境,并且能夠靈活地控制測試腳本的行為。這種方法不僅提高了測試腳本的靈活性,還使得在不同環境中切換變得非常簡單。希望這篇文章對你有所幫助!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/88807.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/88807.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/88807.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

利用可控驗證碼位數實現拒絕服務攻擊(DoS)風險與線程模型分析

一、背景介紹:驗證碼接口中的潛在 DoS 漏洞 在滲透測試過程中,常見驗證碼接口支持傳入“驗證碼位數”參數,表面看是業務可配置,實則若未做上限控制,極易成為資源消耗型 DoS 攻擊入口。 🧪 測試場景&#…

Spring Cloud Feign 整合 Sentinel 實現服務降級與熔斷保護

Spring Cloud Feign 整合 Sentinel 實現服務降級與熔斷保護 在微服務架構中,服務之間的調用往往依賴 Feign,而服務調用的穩定性又至關重要。本文將介紹如何將 Feign 與 Sentinel 結合使用,實現服務的容錯保護(如降級與熔斷&#…

寵物醫院系統的設計與實現(springBoot版)

一、開題報告 一、本選題研究的意義和背景(理論與現實意義): 背景:隨著人們生活水平的提高,寵物飼養愈發普遍,寵物醫院的需求也日益增長。掛號方式主要依賴現場掛號,導致寵物主人需要長時間排隊…

SOCKSv5 協議通信的完整階段與報文格式詳解

SOCKSv5 協議的通信通常分為以下幾個主要階段: 方法協商階段 (Method Negotiation)方法依賴的子協商階段 (Method-Dependent Sub-negotiation) - 本例為用戶名/密碼認證請求發送階段 (Request Sending)請求回復階段 (Request Reply)數據傳輸階段 (Data Transfer) …

??Git提交代碼Commit消息企業級規范

??Git Commit 類型完整指南?? 類型用途示例??feat??新增功能(面向用戶的功能性變更)git commit -m "feat: 添加用戶登錄功能"??fix??修復 Bug(解決代碼中的問題)git commit -m "fix: 修復首頁加載崩潰…

TiDB AUTO_RANDOM 超大主鍵前端精度丟失排查:JavaScript Number 限制與解決方案

前端長整型主鍵“失蹤”記 ——一次 ArrayIndexOutOfBoundsException 的排查全過程 一、事故現場 最近在維護 SMS-OFFICE 后臺系統時,運維同事反饋: 點擊「短信詳情」或「郵箱賬號詳情」時,偶爾彈窗空白、日志報錯: java.lang.A…

在postgresql使用mybatis動態創建數據庫分區表

在postgresql使用mybatis動態創建數據庫分區表 1. 整體描述2. 前期準備2.1 創建主表語句2.2 創建分表語句2.3 xxl-job 3. 代碼實現3.1 mapper.xml層3.2 mapper.java層3.3 service接口層3.4 service實現層3.5 controller層 4. 總結 1. 整體描述 在java下實現:創建分…

Python網安-zip文件暴力破解

目錄 源碼在這里 需要的模塊 準備一個密碼本和需要破解的ZIP文件 一行一行地從密碼文件中讀取每個密碼。 核心部分 注意,需要修改上段代碼注釋里的這段具有編碼問題的代碼: 源碼在這里 https://github.com/Wist-fully/Attack/tree/cracker 需要的…

聊聊Golang開發工程師

誕生背景 Go由Google三位頂尖工程師(Ken Thompson、Rob Pike、Robert Griesemer)設計,目標是解決兩大行業痛點: 硬件利用率不足:多核CPU普及,但C/C等語言難以高效利用并發能力; 開發效率低下&a…

機器學習6——線性分類函數

線性分類函數 分類問題的兩種決策方法: 概率方法:通過計算后驗概率進行分類。優點是在概率分布已知的情況下可以得到最優解,缺點是實際中概率密度通常未知,需要通過大量數據估計。判別方法:假設判別函數的形式已知&…

Sentinel(三):Sentinel熔斷降級

一、Sentinel熔斷概念介紹 官方文檔網址:circuit-breaking | Sentinel 1、Sentinel熔斷基本介紹 除了流量控制以外,對調用鏈路中不穩定的資源進行熔斷降級也是保障高可用的重要措 施之一。一個服務常常會調用別的模塊,可能是另外的一個遠程服…

PostgreSQL 主從集群搭建

下面是 PostgreSQL 主從復制(Streaming Replication)環境的安裝與配置指南,適合在兩臺或多臺服務器之間構建一主一從(或一主多從)的高可用讀寫分離系統。 環境準備 角色主機名/IP說明主庫192.168.1.10可讀寫&#xff…

STM32安全固件升級:使用自定義 bootloader 實現SD卡固件升級,包含固件加密

前言 在 STM32 嵌入式開發中,Bootloader 是一個不可或缺的模塊。ST 公司為 STM32 提供了功能完備的官方 Bootloader,支持多種通信接口(如 USART、USB DFU、I2C、SPI 等),適用于標準的固件更新方案。 然而&#xff0c…

一步部署APache編譯安裝腳本

接下來我來介紹以下編譯安裝的好處 編譯安裝的優點與缺點 一、優點 高度可定制 可根據實際需求啟用或關閉特性(如 Apache 的模塊、MySQL 的引擎等)。 靈活控制編譯參數、優化性能(如 --enable-xxx、--with-xxx)。 更高的性能…

[Linux]mmap()函數內存映射原理及用法

一、內存映射 內存映射,簡而言之就是將用戶空間的一段內存區域映射到內核空間,映射成功后,用戶對這段內存區域的修改可以直接反映到內核空間,同樣,內核空間對這段區域的修改也直接反映用戶空間。那么對于內核空間和用…

通信無BUG,ethernet ip轉profinet網關,汽車焊接設備通信有心機

在運用“激光釬焊”對汽車車頂、側面板、后行李箱蓋等位置進行接合時,必須配備能夠沿著復雜車身線條,對細窄焊接線實施高精度快速檢測及模仿控制的“焊縫跟蹤控制”。 那么汽車生產線的系統升級改造迫在眉睫,當西門子PLC和庫卡機器人無法通信…

python腳本ETH獲取最新發行版本并將是否更新信息發送到釘釘

import requests import json import time import hmac import hashlib import base64 import urllib.parse# 1. 配置釘釘機器人 webhook "https://oapi.dingtalk.com/robot/send?access_tokenXXX" secret "XXX" # 如果沒有加簽驗證,請設…

【Docker基礎】Docker容器管理:docker ps及其參數詳解

目錄 1 docker ps命令概述 1.1 命令定位與作用 1.2 命令基本語法 2 基礎參數詳解 2.1 默認輸出解析 2.2 核心參數解析 2.2.1 -a, --all 2.2.2 -q, --quiet 2.2.3 --no-trunc 3 高級過濾與格式化 3.1 過濾器(--filter)詳解 3.1.1 常用過濾條件 3.1.2 實際應用示例 …

應急響應-感染Neshta病毒

病毒確定: 根據感染現象確定為Virus/Win32.Neshta家族病毒 病毒表現: 該病毒為感染式病毒。該病毒會在系統%SystemRoot%目錄下釋放svchost.com文件,并通過添加注冊表的方式確保每個exe文件執行的時候都會先執行這個文件。該病毒還會收集系統信…

Hyperledger Fabric 入門筆記(二十)Fabric V2.5 測試網絡進階之Tape性能測試

文章目錄 前言一、介紹二、架構三、安裝說明四、使用方法4.1. 修改配置文件4.2. 啟動測試網絡4.3. 運行測試 前言 本文介紹由Hyperledger中國技術工作組提供的另一款區塊鏈網絡性能測試工具Tape的架構、安裝和在Fabric測試網絡中的使用。 一、介紹 Tape是一款輕量級的、可以快…