在使用`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