在使用`pytest`进行测试时,标准输出(如`print`函数的输出)默认不会显示在控制台上。这是因为`pytest`捕获了所有的输出。如果你想要在测试运行时看到`print`函数的输出,你可以使用以下方法:
1. 使用`-s`或`--capture=no`选项运行`pytest`,这将禁用输出捕获功能:
~~~
shellCopy codepytest -s
~~~
或者
~~~
shellCopy codepytest --capture=no
~~~
2. 如果你不想全局禁用输出捕获,而是只想在特定的测试中看到输出,你可以使用`capsys`或`capfd`内置的fixture来临时禁用输出捕获。例如:
~~~
pythonCopy codedef test_example(capsys):
print("Hello, World!")
# 使用 capsys.readouterr() 来获取输出
captured = capsys.readouterr()
assert "Hello, World!" in captured.out
~~~
在这个例子中,`capsys`fixture 被用来捕获测试中的输出。调用`capsys.readouterr()`会返回一个对象,其中包含了捕获的标准输出(`out`)和标准错误输出(`err`)。即使在捕获模式下,你也可以通过检查这些值来验证输出。
3. 另外,你可以在测试函数中使用`pytest`的`logging`功能来记录信息,这些信息可以通过配置`pytest`来显示:
~~~
pythonCopy codeimport logging
def test_logging():
logging.info("Info level log message")
logging.warning("Warning level log message")
~~~
然后,你可以通过设置日志级别来控制日志的输出:
~~~
shellCopy codepytest --log-cli-level=INFO
~~~
使用这些方法,你可以根据需要在`pytest`中查看`print`函数的输出或者记录日志信息。
- 前言
- 1.入门篇
- Python介绍
- 安装与使用
- Python开发利器之VS Code
- 模块安装
- 命令行
- 一次Python无法安装模块的问题探索与解决之旅
- 命令运行
- Conda
- 下载地址
- 2.基础篇
- 基础语法
- 输入与输出
- with as的用法
- 注释
- Python命令行参数
- 编码
- 变量类型
- 列表遍历
- 运算符
- 表达式语句
- 条件
- 循环
- 日期和时间
- 函数
- 高级语法
- @符号-装饰器
- 模块和包
- name
- init.py
- 错误和异常
- 面向对象
- 3.专题篇
- 常用功能
- Python 字符串连接
- python web
- Python CGI编程
- Python OAuth2
- 认证 Flask-HTTPAuth
- 常用命令
- 内置函数
- dir()
- print(f)
- 标准模块
- sys
- pickle-数据序列化
- os
- IO(输入输出)
- 键盘输入
- 文件读写
- 测试
- Python测试框架之pytest快速入门
- pytest-bdd快速示例和问题解决
- 基于pytest-bdd的项目目录结构和命名规范
- python BDD 的相关概念
- Behave介绍和快速示例
- Python BDD之Behave测试报告
- Python BDD 框架比较之 pytest-bdd vs behave
- pytest进阶
- Flask + pytest测试
- 参考网址
- pytest-bdd进阶
- hehave进阶
- 测试路径
- python + selunium
- HTML 根据多层CSS 查找元素
- 等待执行
- 使用text 查找 span
- pytest如何在控制台输出
- 4.问题篇
- pip pip3 及区别
- TypeError: can only concatenate str (not "NoneType") to str
- 5.实战篇
- matplotlib-绘图包
- 导入类
- 命名规范
- 模块查找
- 6.进阶篇
- Flask
- Flask介绍
- Flask扩展模块
- Flask-Login
- 问题
- Jinja2
- Flask-RESTful
- Flask-JWT-Extended
- WSGI
- Flask-SQLAlchemy
- 部署
- Flask VS Django
- Flask Web
- Flask + Vue
- Flask实战
- Flask 标准目录结构
- Blueprints
- 参考
- FastAPI 测试
- https 证书 Caused by SSLError(SSLCertVerificationError(1, '[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate