测试开发技术网站
博客
设计
设计
开发
Python
测试
unittest
运维
Linux基础应用
CI/CD
CI/CD
数据库
数据库
云计算
云计算
云原生
云原生
爬虫
爬虫
数据分析
数据分析
人工智能
人工智能
登录
注册
Pytest----pytest-tldr 插件简化脚本执行日志输出
收藏本文
作者:redrose2100 类别: 日期:2022-12-07 09:20:25 阅读:764 次 消耗积分:0 分
[TOC] ![](https://redrose2100.oss-cn-hangzhou.aliyuncs.com/img/7cd47362-951c-11ee-986a-0242ac110004.png) Pytest测试框架在执行的时候多实时标准输出、实时日志、捕获日志、捕获标准输出等多种类型的内容在控制台显示,让许多人觉得输出不是太友好,尤其是当用例失败后,来回上下翻控制台的输出却总感觉找不到报错位置。而pytest-tldr插件则就是为了解决这个问题的,让用例报错后仅仅显示报错用例的调用错误栈,而不去显示各种错综复杂的乱七八糟的显示。 为了更好的体验pytest-tldr插件的效果,在安装pytest-tldr之前,首先利用如下用例执行一次观察一线报错信息。 ```python def test_1(): print("in test_1") assert 1==1 def test_2(): print("in test_2") assert 1==2 ``` 执行结果如下,可以看到其实本来这个用例非常的简单,仅仅是直接判断1和2是否相等的断言,但是经pytest执行后打印出来的信息确实这么多,让人尤其是新手会感觉无法入手定位问题的感觉。 ```bash (demo-HCIhX0Hq) E:\demo>pytest Test session starts (platform: win32, Python 3.7.9, pytest 7.2.0, pytest-sugar 0.9.6) benchmark: 4.0.0 (defaults: timer=time.perf_counter disable_gc=False min_rounds=5 min_time=0.000005 max_time=1.0 calibration_precision=10 warmup=False warmup_iterations=100000) rootdir: E:\demo, configfile: pytest.ini plugins: allure-pytest-2.12.0, assume-2.4.3, attrib-0.1.3, benchmark-4.0.0, csv-3.0.0, rerunfailures-10.2, sugar-0.9.6 collecting ... test_demo.py ✓ 50% █████ ――――――――――――――――――――――――― test_2 ―――――――――――――――――――――――――― def test_2(): print("in test_2") > assert 1==2 E assert 1 == 2 test_demo.py:8: AssertionError ------------------ Captured stdout call ------------------- in test_2 test_demo.py ⨯ 100% ██████████ ================= short test summary info ================= FAILED test_demo.py::test_2 - assert 1 == 2 Results (0.15s): 1 passed 1 failed - test_demo.py:6 test_2 (demo-HCIhX0Hq) E:\demo> ``` 然后通过如下命令安装pytest-tldr插件。 ```bash pip install pytest-tldr ``` 安装完成后,此时再次使用pytest执行,如下可以看出此时的结构就简单多了,很明了。 ```bash (demo-HCIhX0Hq) E:\demo>pytest .F ============================================================================== FAIL: test_demo.py::test_2 ------------------------------------------------------------------------------ in test_2 Traceback (most recent call last): File "E:\demo\test_demo.py", line 8, in test_2 assert 1==2 AssertionError: assert 1 == 2 ------------------------------------------------------------------------------ Ran 2 tests in 0.08s FAILED (failures=1) (demo-HCIhX0Hq) E:\demo> ``` 下面将用例断言改为成功,如下。 ```python def test_1(): print("in test_1") assert 1==1 def test_2(): print("in test_2") assert 1==1 ``` 如下,关闭tldr插件执行结果如下。 ```bash (demo-HCIhX0Hq) E:\demo>pytest -p no:tldr Test session starts (platform: win32, Python 3.7.9, pytest 7.2.0, pytest-sugar 0.9.6) benchmark: 4.0.0 (defaults: timer=time.perf_counter disable_gc=False min_rounds=5 min_time=0.000005 max_time=1.0 calibration_precision=10 warmup=False warmup_iterations=100000) rootdir: E:\demo, configfile: pytest.ini plugins: allure-pytest-2.12.0, assume-2.4.3, attrib-0.1.3, benchmark-4.0.0, csv-3.0.0, rerunfailures-10.2, sugar-0.9.6 collecting ... test_demo.py ✓✓ 100% ██████████ Results (0.09s): 2 passed (demo-HCIhX0Hq) E:\demo> ``` 而放开tldr插件后执行结果如下所示,可以发现此时显示非常的简洁。 ```bash (demo-HCIhX0Hq) E:\demo>pytest .. ------------------------------------------------------------------------------ Ran 2 tests in 0.08s OK (demo-HCIhX0Hq) E:\demo> ```
始终坚持开源开放共享精神,同时感谢您的充电鼓励和支持!
版权所有,转载本站文章请注明出处:redrose2100, http://blog.redrose2100.com/article/487
上一篇:
Pytest----pytest-csv 执行结果输出csv文件
下一篇:
Pluggy源码解读----Pluggy模块的应用
搜索
个人成就
出版书籍
《Pytest企业级应用实战》
测试开发技术全栈公众号
测试开发技术全栈公众号
DevOps技术交流微信群
加微信邀请进群
常用网站链接
开源软件洞察
云原生技术栈全景图
Python语言官方文档
Golang官方文档
Docker官方文档
Jenkins中文用户手册
Scrapy官方文档
VUE官方文档
Harbor官方文档
openQA官方文档
云原生开源社区
开源中国
Kubernetes中文文档
Markdown语法官方教程
Kubernetes中文社区
Kubersphere官方文档
BootStrap中文网站
JavaScript中文网
NumPy官方文档
Pandas官方文档
GitLink确实开源网站
数据库排名网站
编程语言排名网站
SEO综合查询网站
数学加减法练习自动生成网站
Kickstart Generator
文章分类
最新文章
最多阅读
特别推荐
×
Close
登录
注册
找回密码
登录邮箱:
登录密码:
图片验证码:
注册邮箱:
注册密码:
邮箱验证码:
发送邮件
注册邮箱:
新的密码:
邮箱验证码:
发送邮件