[翻译]pytest测试框架(二):使用
此文已由作者吴琪惠授权网易云社区发布。
欢迎访问网易云社区,了解更多网易技术产品运营经验。
调用pytest
调用命令:
python -m pytest [...]
上面的命令相当于在命令行直接调用脚本 pytest [...](前提是python已经加入环境变量)
一些帮助信息
pytest --version # shows where pytest was imported from 查看版本
pytest --fixtures # show available builtin function arguments 查看内置参数
pytest -h | --help # show help on command line and config file options 命令行和配置文件帮助
失败后停止
pytest -x # stop after first failure 首次失败后停止运行
pytest --maxfail=2 # stop after two failures 两次失败后停止执行
选择测试用例
pytest test_mod.py # run tests in module 执行模块中的用例
pytest somepath # run all tests below somepath 执行路径中的用例
pytest -k stringexpr # only run tests with names that match the 执行字符串表达式中的用例
# "string expression", e.g. "MyClass and not method" 如:"MyClass and not method"
# will select TestMyClass.test_something 将会选择TestMyClass.test_something
# but not TestMyClass.test_method_simple 而不会选择TestMyClass.test_method_simple
pytest test_mod.py::test_func # only run tests that match the "node ID", 仅运行匹配"node ID"的用例
# e.g. "test_mod.py::test_func" will select 如选择:"test_mod.py::test_func"时只运行test_mod.py文件内的test_func
# only test_func in test_mod.py
pytest test_mod.py::TestClass::test_method # run a single method in a single class 在单独类中运行单独方法
pytest --pyargs pkg # 导入pkg,使用其文件系统位置来查找和执行用例,执行pkg目录下的所有用例
调试输出
pytest --showlocals # show local variables in tracebacks 在tracebacks中显示本地变量
pytest -l # show local variables (shortcut) 在tracebacks中显示本地变量(快捷方式) pytest --tb=auto # (default) 'long' tracebacks for the first and last(默认)第一个和最后一个使用长tracebacks信息,其他使用短的
# entry, but 'short' style for the other entries
pytest --tb=long # exhaustive, informative traceback formatting 完整的格式化的traceback信息
pytest --tb=short # shorter traceback format 短的traceback信息
pytest --tb=line # only one line per failure 每个错误信息显示一行
pytest --tb=native # Python standard library formatting 标准格式化输出
pytest --tb=no # no traceback at all 无traceback信息
Python带有一个内置的Python调试器称为PDB。pytest可以在命令行选项指定调用:
pytest --pdb
这将每次失败时调用Python调试器。通常,您可能只希望这样做的第一个失败的测试,以了解某些故障情况:
pytest -x --pdb # drop to PDB on first failure, then end test session 下降到PDB上的第一次失败,然后结束测试阶段pytest --pdb --maxfail=3 # drop to PDB for first three failures 下降到PDB前三失败
注意,任何失败的异常信息都会存储在sys.last_value,sys.last_type 以及 sys_last_traceback。在交互使用中,允许使用任意debug工具进行调试,也可手动访问异常信息,例如:
>>> import sys>>> sys.last_traceback.tb_lineno42>>> sys.last_valueAssertionError('assert result == "ok"',)
断点设置
import pytestdef test_function():
...
pytest.set_trace() # invoke PDB debugger and tracing
在pytest2.0.0版本之前,如果你没有能够通过 pytest -s 捕捉到trace信息,你只能查阅PDB traceing。在以后的版本中,当你输入PDB traceing,pytest自动禁用捕捉异常信息:
1.捕获输出不影响其他测试用例
2.任何prior测试输出已经被捕获,并且被处理
3.同一个测试中,任何later测试输出不会被捕获,输出内容将会直接发送到sys.stdout。注意,这条也适用于交互式PDB会话已经被退出,但测试输出已经开始了,也会继续定期运行测试。
从pytest2.4.0版本开始,你可以不需要使用pytest.set_trace()包装,也不需要禁用pytest -s命令,你可以使用本地Python命令:importpdb;pdb.set_trace()调用进入PBD traceing。
测试执行时间
获取运行最慢的10个测试执行时间:
pytest --durations=10
创建JUnitXML格式文件
为了创建一些可以让Jenkins或者其他持续继承服务器可识别的测试结果文件,可使用如下命令:
pytest --junitxml=path
记录xml(2.8版本支持)
如果你想要为一个测试日志提供额外信息,可使用recode_xml_property 参数:
def test_function(record_xml_property):
record_xml_property("example_key", 1)
assert 0
这段代码将会为测试用例标签添加一个额外的属性:example_key="1":
<testcase classname="test_function" file="test_function.py" line="0" name="test_function" time="0.0009">
<properties>
<property name="example_key" value="1" />
</properties></testcase>
注:
record_xml_property
Add extra xml properties to the tag for the calling test.
The fixture is callable with ``(name, value)``, with value being automatically xml-encoded.
注意:这是一个测试中的参数,这个接口在未来版本中可能会被更强大的接口取到,但他本身功能会保留
LogXML: add_global_property(3.0版本支持)
如果你希望在testsuite级别添加一个属性节点(properties node),这个属性会使得所有关联的测试用例都生效。
import pytest@pytest.fixture(scope="session")def log_global_env_facts(f): if pytest.config.pluginmanager.hasplugin('junitxml'):
my_junit = getattr(pytest.config, '_xml', None) my_junit.add_global_property('ARCH', 'PPC')
my_junit.add_global_property('STORAGE_TYPE', 'CEPH')@pytest.mark.usefixtures(log_global_env_facts)def start_and_prepare_env():
passclass TestMe:
def test_foo(self):
assert True
上面的代码将在testsuite下添加一个属性节点:
<testsuite errors="0" failures="0" name="pytest" skips="0" tests="1" time="0.006">
<properties>
<property name="ARCH" value="PPC"/>
<property name="STORAGE_TYPE" value="CEPH"/>
</properties>
<testcase classname="test_me.TestMe" file="test_me.py" line="16" name="test_foo" time="0.000243663787842"/></testsuite>
注意:这是一个测试中的参数,这个接口在未来版本中可能会被更强大的接口取到,但他本身功能会保留
测试结果格式化文件
这个功能在3.0版本已经弃用,并于4.0版本移除
创建一个machine-readable的文本测试结果文件,可使用:
pytest --resultlog=path
这些文件会被如PyPy-test web页面使用,来显示测试结果的几个修改。
在线发送测试报告服务
为每个测试失败用例创建URL:
pytest --pastebin=failed
上面命令将提交测试运行信息到远程服务,并且会为每个失败用例提供一个URL。如果你只是想发送一个特别的失败信息,你可以利用 -x 命令像往常一样选择测试用例集或者添加用例。
为整个会话日志创建URL:
pytest --pastebin=all
目前仅可以复制到 http://bpaste.net
禁用插件
使用 -p no 命令,在调用的时候禁用加载特定的插件,比如,禁用加载doctest插件,这个插件是从text文件列表中执行doctest用例,调用:
pytest -p no:doctest
使用Python调用pytest(2.0版本)
直接调用:
pytest.main()
这句语句跟你从命令行执行pytest命令是一样的,他不会出现SystemExit,但会返回exitcode,可选参数:
pytest.main(['-x', 'mytestdir'])
给pytest.main指定附加插件:
# content of myinvoke.pyimport pytestclass MyPlugin:
def pytest_sessionfinish(self):
print("*** test run reporting finishing")pytest.main(["-qq"], plugins=[MyPlugin()])
运行之后,将会显示 MyPlugin被添加了,他的钩子函数被调用:
$ python myinvoke.py
*** test run reporting finishing
网易云免费体验馆,0成本体验20+款云产品!
更多网易技术、产品、运营经验分享请点击。
相关文章:
【推荐】 selenium下拉框踩坑埋坑
[翻译]pytest测试框架(二):使用的更多相关文章
- [翻译]pytest测试框架(一)
此文已由作者吴琪惠授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 纯官网译文而已... pytest是一个成熟的.全功能的python测试工具. pytest框架编写测试用例 ...
- Pytest测试框架(二):pytest 的setup/teardown方法
PyTest支持xUnit style 结构, setup() 和 teardown() 方法用于初始化和清理测试环境,可以保证测试用例的独立性.pytest的setup/teardown方法包括:模 ...
- pytest测试框架 -- 简介
一.pytest测试框架简介: (1)pytest是python的第三方测试框架,是基于unittest的扩展框架,比unittest更简洁,更高效. (2)pytest框架可以兼容unittest用 ...
- Pytest测试框架(五):pytest + allure生成测试报告
Allure 是一款轻量级.支持多语言的开源自动化测试报告生成框架,由Java语言开发,可以集成到 Jenkins. pytest 测试框架支持Allure 报告生成. pytest也可以生成juni ...
- 『德不孤』Pytest框架 — 1、Pytest测试框架介绍
目录 1.什么是单元测试框架 2.单元测试框架主要做什么 3.单元测试框架和自动化测试框架有什么关系 4.Pytest测试框架说明 5.Pytest框架和Unittest框架区别 (1)Unittes ...
- Pytest测试框架(一):pytest安装及用例执行
PyTest是基于Python的开源测试框架,语法简单易用,有大量的插件,功能非常多.自动检测测试用例,支持参数化,跳过特定用例,失败重试等功能. 安装 pip install -U pytest ...
- Pytest测试框架(三):pytest fixture 用法
xUnit style 结构的 fixture用于初始化测试函数, pytest fixture是对传统的 xUnit 架构的setup/teardown功能的改进.pytest fixture为测试 ...
- python pytest测试框架介绍二
在介绍一中简单介绍了pytest的安装和简单使用,接下来我们就要实际了解pytest了 一.pytest的用例发现规则 pytest可以在不同的函数.包中发现用例,发现的规则如下 文件名以test_开 ...
- Pytest 测试框架
一 . Pytest 简介 Pytest是python的一种单元测试框架. 1. pytest 特点 入门简单,文档丰富 支持单元测试,功能测试 支持参数化,重复执行,部分执行,测试跳过 兼容其他测试 ...
随机推荐
- jquery带下拉菜单和焦点图
jQuery,下拉菜单,二级菜单,索引按钮,焦点图代码,jquery带下拉菜单和焦点图是一款顶部通栏带二级下拉菜单和banner导航菜单代码. JQuery特效代码来源:http://www.huiy ...
- TinkPHP 简单知识摘要
1.Session处理 赋值:session('name','value'); //设置session 与 $_SESSION['think']['name'] = 'value';相等 取值:$va ...
- Druid:一个用于大数据实时处理的开源分布式系统——大数据实时查询和分析的高容错、高性能开源分布式系统
转自:http://www.36dsj.com/archives/28590 Druid 是一个用于大数据实时查询和分析的高容错.高性能开源分布式系统,旨在快速处理大规模的数据,并能够实现快速查询和分 ...
- OpenCV——百叶窗
参考: PS 图像特效,百叶窗 // define head function #ifndef PS_ALGORITHM_H_INCLUDED #define PS_ALGORITHM_H_INCLU ...
- Gym 101142C :CodeCoder vs TopForces(强连通算法)
题意:N个人,每个人有a属性和b属性,如果一个人的a或者b大于另外一个人,我们说这个人可以打败那个人.且这种关系可以传递.对于每个人,输出他可以打败多少人.(保证每个a不相同,保证每个b不相同. 思路 ...
- hdu 1724 Ellipse —— 自适应辛普森积分
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1724 函数都给出来了,可以用辛普森积分: 一开始 eps = 1e-8 TLE了,答案只要三位小数,那么 ...
- C#中DataTable用法
一.select方法1.筛选出男性且名字中带有李的人然后按照生日降序排列(1)DataRow[] rows=DataTable.Select("sex='"+"男&quo ...
- css基础知识一
1.CSS (Cascding Style Sheet)层叠样式表 级联样式表 样式表 2.CSS作用: 修改页面中元素的显示样式 能够实现内容与表现的分离 提高代码的可重用性和可维护性 3.导入CS ...
- 1 ELK 简介
日志主要包括系统日志.应用程序日志和安全日志,系统运维和开发人员可以通过日志了解服务器软硬件信息.检查配置过程中的错误及错误发生的原因.经常分析日志可以了解服务器的负荷,性能安全性,从而及时采取措施纠 ...
- 在python3.6下 发明一个类似python3.7 dataclass数据类,不用在 __init__中self.xx
虽然我用3.6,但我在2.7转3.6时候,把3.3 3.4 3.5 3.6的变化都看了一次,虽然已经忘了哪些变化.同时也关注3.7 3.8的变化,3.7中就有1个数据类印象深刻,因为之前在定义这种类时 ...