pytest 測(cè)試輸出和結(jié)果-管理日志記錄

2022-03-29 17:25 更新

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

caplog fixture

在測(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)
            )

實(shí)時(shí)日志

通過(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


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)