news 2026/4/15 10:50:42

Pytest自动化测试执行环境切换的2种解决方案

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Pytest自动化测试执行环境切换的2种解决方案

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

一、痛点分析

在实际企业的项目中,自动化测试的代码往往需要在不同的环境中进行切换,比如多套测试环境、预上线环境、UAT环境、线上环境等等,并且在DevOps理念中,往往自动化都会与Jenkins进行CI/CD,不论是定时执行策略还是迭代测试,那么问题来了,难道每次切换环境都需要提供一套测试代码?或者每次切换都要需修改我们的自动化环境配置?答案当然不是,不然怎么能叫测试自动化呢!

在未使用pytest的Hook相关方法之前,切换环境我们一般会使用python的内置模块sys,它有一个argv的方法,可以从我们的命令行接收参数,通过它也可以实现上面的需求,就像如下部分代码这样:

try: if sys.argv[1] == '-p': # 预上线环境 conf_url.write_value(filename=CONFIGS_FILE_PATH_URL, data=p_api_address) modify_properties_url(filename=ENVIRONMENT_PROPERTIES_PATH, url=p_api_address["request"]["url"]) elif sys.argv[1] in [f't{i}' for i in range(1, 8)]: # 测试环境 conf_url.write_value(filename=CONFIGS_FILE_PATH_URL, data=test_api_address(sys.argv[1][1:])) modify_properties_url(filename=ENVIRONMENT_PROPERTIES_PATH, url=test_api_address(sys.argv[1][1:])["request"]["url"]) else: case_logger.error("Please confirm the environmental information.") print("Please confirm the environmental information.") raise Exception except IndexError: # 生产环境 conf_url.write_value(filename=CONFIGS_FILE_PATH_URL, data=formal_api_address) modify_properties_url(filename=ENVIRONMENT_PROPERTIES_PATH, url=formal_api_address["request"]["url"])

这种方式我们需要使用 "python xxx.py -p" 这种方式进行环境切换,然后再执行pytest命令行去执行测试用例,但是这种方法能在pytest的命令行中使用吗?能不能将环境切换的命令行也集成到pytest的命令行中,执行整个自动化项目只使用一条命令行呢?

方法一:Hook方法pytest_addoption注册命令行参数

1、Hook方法注解

pytest_addoption:可以让用户注册一个自定义的命令行参数,方便用户将数据传递给 pytest
这个 Hook 方法一般和内置 fixture pytestconfig 配合使用
pytest_addoption 注册命令行参数,pytestconfig 通过配置对象读取参数的值
参考文档:Writing plugins — pytest documentation

2、使用方法

1.一般编写到conftest.py文件中

2.定义pytest_addoption方法注册pytest命令行参数,函数名和参数保持一致

def pytest_addoption(parser): """注册自定义参数 env 到配置对象""" parser.addoption("--env", action="store", default="https://www.cnblogs.com/", help="将命令行参数 ’--env' 添加到 pytest 配置中")

parser.addoption参数说明:

  • name:自定义命令行参数的名字,可以是:"xx", "-xx" 或 "--xx"
  • action:在命令行中遇到此参数时要采取的基本操作类型
  • store:默认,只存储参数的值,可以存储任何类型的值,此时 default 也可以是任何类型的值,而且命令行参数多次使用也只能生效一个,最后一个值覆盖之前的值
  • append:存储一个列表,用 append 模式将可以同时多次使用自定义参数,并且 default 默认值必须是一个列表,pytest 会把 default 默认参数的值和多个自定义参数的值放在一个列表中
  • store_const:用 const 为命令行参数指定一个常量值,必须和 const 参数同时使用,使用这个模式后命令行参数不能赋值
  • append_const:存储一个列表,使用 const 为命令行参数指定一个常量值,并将 default 默认值和 const 常量值添加到列表中,这个模式可以同时多次使用自定义参数,但是还是不能赋值,只能使用常量
  • nargs:应该使用的命令行参数的数量
  • const:某些操作和nargs选择所需的常量值
  • default:如果参数的值不在命令行中,则使用默认值
  • type:可以是 python 的基础类型,比如:int,str,float,list 等类型,如果不指定类型的话,pytest会把接受到的参数值都默认为 str 类型,所以我们有时需要指定参数的类型,在使用 type 指定类型时,也需要把 default 的类型修改为同样的类型!
  • choices:choices 可以指定几个值,自定义参数必须在这几个值中选择一个,否则会报错
  • required:命令行选项是否可以省略(仅可选)
  • help:对参数作用的简要说明
  • metavar:用法消息中参数的名称
  • dest:要添加到 parse_args() 返回的对象中的属性的名称

3.使用request.config.getoption("--命令行")获取命令行参数的值

@pytest.fixture(scope="session") def get_env(request): """从配置对象中读取自定义参数的值""" return request.config.getoption("--env")

4.fixture继承,进行环境切换

@pytest.fixture(autouse=True) def set_env(get_env): """将自定义参数的值写入全局配置文件""" with open(ENV_TXT_FILE, 'w', encoding='utf-8') as f: f.write(get_env)

5.通过pytest命令行传参一键化实现环境切换和测试用例执行

方法二:使用插件pytest-base-url进行命令行传参

1.安装pytest-base-url

pip install pytest-base-url -i https://pypi.douban.com/simple

2.将base_url参数传入到fixture函数中

@pytest.fixture def driver_setup(base_url): try: URL = base_url start_chrome(URL, options=browser_options(), headless=False) driver = get_driver() except Exception as e: log.error(e) else: yield driver

3.pytest命令行传参

使用 --base-url https://www.xxx.com/ 形式传参

pytest --base-url https://www.cnblogs.com/
第一种不局限于环境切换,任何想通过pytest命令行传入自定义的参数都可以通过方法一实现,因此杀鸡焉用牛刀,环境切换优先推荐方法二!

二、总结

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 9:36:11

强力解锁:5分钟掌握网络工具终极部署方案

还在为复杂网络工具配置而头疼吗?每次看到那些密密麻麻的命令行参数就望而却步?今天,让我们一同探索一种革命性的解决方案——一键部署系统,它将彻底改变你对网络工具的认知。 【免费下载链接】sing-box 最好用的 sing-box 一键安…

作者头像 李华
网站建设 2026/4/15 0:35:48

5分钟快速上手:Scrcpy安卓投屏完整使用指南

5分钟快速上手:Scrcpy安卓投屏完整使用指南 【免费下载链接】scrcpy Display and control your Android device 项目地址: https://gitcode.com/gh_mirrors/sc/scrcpy 想要在电脑上流畅操控安卓设备却不知从何下手?Scrcpy作为一款完全免费的安卓投…

作者头像 李华
网站建设 2026/4/5 3:14:57

LiveSplit完整指南:免费专业速度跑计时器的终极使用方法

LiveSplit完整指南:免费专业速度跑计时器的终极使用方法 【免费下载链接】LiveSplit A sleek, highly customizable timer for speedrunners. 项目地址: https://gitcode.com/gh_mirrors/li/LiveSplit 在追求极致游戏速度的旅程中,一个精准可靠的…

作者头像 李华
网站建设 2026/4/14 6:52:59

数字鸿沟弥合:让偏远地区孩子听到优质语音教育资源

数字鸿沟弥合:让偏远地区孩子听到优质语音教育资源 在云南怒江峡谷的一间村小教室里,投影仪正播放一段数学动画——“分数的加减法”。屏幕上的卡通老师刚说完“我们一步一步来”,孩子们便齐声接道:“你一定能学会!”这…

作者头像 李华
网站建设 2026/4/12 12:13:03

Nucleus Co-op:单机游戏秒变多人派对的终极神器

Nucleus Co-op:单机游戏秒变多人派对的终极神器 【免费下载链接】splitscreenme-nucleus Nucleus Co-op is an application that starts multiple instances of a game for split-screen multiplayer gaming! 项目地址: https://gitcode.com/gh_mirrors/spl/split…

作者头像 李华
网站建设 2026/4/3 5:01:44

救命神器8个AI论文平台,助你轻松搞定本科生毕业论文!

救命神器8个AI论文平台,助你轻松搞定本科生毕业论文! AI 工具如何改变论文写作的未来 在当今这个信息爆炸的时代,学术写作已经不再是传统意义上的“苦差事”,而是借助 AI 工具变得更加高效、精准。对于本科生而言,撰写…

作者头像 李华