gpt4 book ai didi

python - 如何防止 django 测试显示 sys.stdout 消息?

转载 作者:行者123 更新时间:2023-11-30 22:13:12 24 4
gpt4 key购买 nike

我的问题是,由于我在运行单元测试时向 django 应用程序添加了日志记录,因此所有日志消息都显示在控制台中。我使用 Nose 作为测试运行者。它通常的行为是捕获 sys.stdout,仅在测试失败时显示控制台输出并在最后显示。

我在运行测试时曾经有过这样的输出:

........
Ran 8 tests in 0.876s

OK
Destroying test database for alias 'default'...

这是我运行 python manage.py 测试帐户时得到的输出:

...log message
.log message
....log message
Ran 8 tests in 1.034s

OK
Destroying test database for alias 'default'...

当我使用 Python 标准日志记录库将日志记录添加到我的代码中时,这种情况就开始发生。我更改了 settings.pyviews.py。您可以在下面查看我具体更改了什么。

有人可以帮助我保留日志记录,但在运行测试时避免烦人的额外输出吗?

已添加到settings.py

LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console': {
'class': 'logging.StreamHandler',
'level': 'INFO',
'stream': sys.stdout,
},
},
'loggers': {
'': {
'handlers': ['console'],
'level': 'INFO',
'propagate': False,
},
},
}

已添加到我的观点

import logging

logger = logging.getLogger(__name__)

logger.info("log message")

django 用于运行我的测试的命令

nosetests accounts/ --with-coverage --cover-package=accounts,keys, utils --cover-html --cover-erase --logging-filter='selenium' --verbosity=1

settings.py中配置nose test runner(这与工作时相同)

TEST_RUNNER = 'django_nose.NoseTestSuiteRunner'
NOSE_ARGS = [
'--with-coverage',
'--cover-package=accounts,keys, utils',
'--cover-html',
'--cover-erase',
"--logging-filter='selenium'",
]

最佳答案

您应该编写一个自定义测试运行程序来禁用日志记录或更改级别。

import logging

from django_nose import NoseTestSuiteRunner


class DisableLoggingNoseTestSuiteRunner(NoseTestSuiteRunner):
"""
Disable the test runner log level below `logging.CRITICAL`.
"""
def run_tests(self, *args, **kwargs):
# Disable logging below critical
logging.disable(logging.CRITICAL)
super(DisableLoggingNoseTestSuiteRunner, self).run_tests(*args, **kwargs)

您还必须更改您的settings.py才能使用该测试运行程序。

TEST_RUNNER = 'package_where_you_place_it.DisableLoggingNoseTestSuiteRunner'

关于python - 如何防止 django 测试显示 sys.stdout 消息?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50860932/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com