pytest 自動(dòng)捕獲級(jí)別 ?WARNING
或更高級(jí)別的日志消息,并以與捕獲的 ?stdout
和 ?stderr
相同的方式將它們顯示在每個(gè)失敗的測(cè)試的自己的部分中。
不帶選項(xiàng)運(yùn)行:
pytest
顯示失敗的測(cè)試,如下所示:
----------------------- Captured stdlog call ----------------------
test_reporting.py 26 WARNING text going to logger
----------------------- Captured stdout call ----------------------
text going to stdout
----------------------- Captured stderr call ----------------------
text going to stderr
==================== 2 failed in 0.02 seconds =====================
默認(rèn)情況下,每個(gè)捕獲的日志消息都會(huì)顯示模塊、行號(hào)、日志級(jí)別和消息。
如果需要,可以通過(guò)傳遞特定的格式選項(xiàng)將日志和日期格式指定為日志模塊支持的任何內(nèi)容:
pytest --log-format="%(asctime)s %(levelname)s %(message)s" \
--log-date-format="%Y-%m-%d %H:%M:%S"
顯示失敗的測(cè)試,如下所示:
----------------------- Captured stdlog call ----------------------
2010-04-10 14:48:44 WARNING text going to logger
----------------------- Captured stdout call ----------------------
text going to stdout
----------------------- Captured stderr call ----------------------
text going to stderr
==================== 2 failed in 0.02 seconds =====================
這些選項(xiàng)也可以通過(guò) ?pytest.ini
文件自定義:
[pytest]
log_format = %(asctime)s %(levelname)s %(message)s
log_date_format = %Y-%m-%d %H:%M:%S
此外,可以通過(guò)以下方式完全禁用對(duì)失敗測(cè)試的捕獲內(nèi)容(?stdout
?、?stderr
?和?logs
?)的報(bào)告:
pytest --show-capture=no
在測(cè)試內(nèi)部,可以更改捕獲的日志消息的日志級(jí)別。這是由?caplog fixture
?支持的:
def test_foo(caplog):
caplog.set_level(logging.INFO)
pass
默認(rèn)情況下,級(jí)別是在根記錄器上設(shè)置的,但是為了方便起見(jiàn),也可以設(shè)置任何記錄器的日志級(jí)別:
def test_foo(caplog):
caplog.set_level(logging.CRITICAL, logger="root.baz")
pass
設(shè)置的日志級(jí)別會(huì)在測(cè)試結(jié)束時(shí)自動(dòng)恢復(fù)。
也可以使用上下文管理器臨時(shí)更改 ?with
塊內(nèi)的日志級(jí)別:
def test_bar(caplog):
with caplog.at_level(logging.INFO):
pass
同樣,默認(rèn)情況下,根記錄器的級(jí)別會(huì)受到影響,但任何記錄器的級(jí)別都可以通過(guò)以下方式更改:
def test_bar(caplog):
with caplog.at_level(logging.CRITICAL, logger="root.baz"):
pass
最后,在測(cè)試運(yùn)行期間發(fā)送給記錄器的所有日志都可以在?fixture
?上以日志記錄的形式獲得。當(dāng)你想要對(duì)消息的內(nèi)容進(jìn)行斷言時(shí),這很有用:
def test_baz(caplog):
func_under_test()
for record in caplog.records:
assert record.levelname != "CRITICAL"
assert "wally" not in caplog.text
如果您只想確保某些消息已記錄在具有給定嚴(yán)重性和消息的給定記錄器名稱下,您還可以使用 ?record_tuples
?:
def test_foo(caplog):
logging.getLogger().info("boo %s", "arg")
assert caplog.record_tuples == [("root", logging.INFO, "boo arg")]
您可以調(diào)用 ?caplog.clear()
? 來(lái)重置測(cè)試中捕獲的日志記錄:
def test_something_with_clearing_records(caplog):
some_method_that_creates_log_records()
caplog.clear()
your_test_method()
assert ["Foo"] == [rec.message for rec in caplog.records]
?caplog.records
? 屬性僅包含來(lái)自當(dāng)前階段的記錄,因此在設(shè)置階段內(nèi)它僅包含設(shè)置日志,與調(diào)用和拆卸階段相同。
要從其他階段訪問(wèn)日志,請(qǐng)使用?caplog.get_records(when)
?方法。例如,如果你想確保使用某個(gè)?fixture
?的測(cè)試不會(huì)記錄任何警告,你可以像這樣檢查安裝和調(diào)用階段的記錄:
@pytest.fixture
def window(caplog):
window = create_window()
yield window
for when in ("setup", "call"):
messages = [
x.message for x in caplog.get_records(when) if x.levelno == logging.WARNING
]
if messages:
pytest.fail(
"warning messages encountered during testing: {}".format(messages)
)
通過(guò)將 ?log_cli
配置選項(xiàng)設(shè)置為 ?true
,pytest 將輸出日志記錄,因?yàn)樗鼈冎苯影l(fā)送到控制臺(tái)。
您可以通過(guò)傳遞 ?--log-cli-level
? 指定將具有相同或更高級(jí)別的日志記錄打印到控制臺(tái)的日志記錄級(jí)別。 此設(shè)置接受 python 文檔中看到的日志記錄級(jí)別名稱或整數(shù)作為日志記錄級(jí)別 ?num
?。
此外,您還可以指定 ?--log-cli-format
? 和 ?--log-cli-date-format
? 鏡像并默認(rèn)為 ?--log-format
? 和 ?--log-date-format
?,如果未提供,但僅適用于控制臺(tái)日志記錄處理程序。
所有 ?CLI
日志選項(xiàng)也可以在配置 ?INI
文件中設(shè)置。 選項(xiàng)名稱是:
log_cli_level
?log_cli_format
?log_cli_date_format
?如果您需要將整個(gè)測(cè)試套件的日志調(diào)用記錄到一個(gè)文件中,您可以傳遞 ?--log-file=/path/to/log/file
?。 此日志文件以寫(xiě)入模式打開(kāi),這意味著它將在每次運(yùn)行測(cè)試會(huì)話時(shí)被覆蓋。
您還可以通過(guò)傳遞 ?--log-file-level
? 來(lái)指定日志文件的日志記錄級(jí)別。 此設(shè)置接受 python 文檔中所見(jiàn)的日志級(jí)別名稱(即大寫(xiě)的級(jí)別名稱)或整數(shù)作為日志級(jí)別 ?num
?。
此外,您還可以指定 ?--log-file-format
? 和 ?--log-file-date-format
? 等于 ?--log-format
? 和 ?--log-date-format
? 但應(yīng)用于日志文件日志記錄處理程序。
所有日志文件選項(xiàng)也可以在配置 ?INI
文件中設(shè)置。 選項(xiàng)名稱是:
log_file
?log_file_level
?log_file_format
?log_file_date_format
?您可以調(diào)用 ?set_log_path()
? 來(lái)動(dòng)態(tài)自定義 ?log_file
?路徑。
如果啟用了彩色終端輸出,則日志級(jí)別是彩色的。 通過(guò) ?add_color_level()
? 支持從默認(rèn)顏色更改或在自定義日志級(jí)別上添加顏色。 例如:
@pytest.hookimpl
def pytest_configure(config):
logging_plugin = config.pluginmanager.get_plugin("logging-plugin")
# Change color on existing log level
logging_plugin.log_cli_handler.formatter.add_color_level(logging.INFO, "cyan")
# Add color to a custom log level (a custom log level `SPAM` is already set up)
logging_plugin.log_cli_handler.formatter.add_color_level(logging.SPAM, "blue")
此功能是作為 ?pytest-catchlog
? 插件的替代品引入的,它們相互沖突。 引入此功能時(shí),帶有 ?pytest-capturelog
? 的向后兼容性 API 已被刪除,因此如果您仍然需要 ?pytest-catchlog
?,您可以通過(guò)添加到 ?pytest.ini
? 來(lái)禁用內(nèi)部功能:
[pytest]
addopts=-p no:logging
更多建議: