如何防止 Django 测试显示 sys.stdout 消息?
How to prevent django tests from showing sys.stdout messages?
我的问题是,因为我在 运行 时向我的 django 应用程序添加了日志记录,所以我的单元测试显示在控制台中的所有日志消息。我用鼻子作为测试 运行ner。它通常的行为是捕获 sys.stdout
,仅在测试失败时显示控制台输出并在最后显示。
我曾经在 运行 测试时有这个输出:
........
Ran 8 tests in 0.876s
OK
Destroying test database for alias 'default'...
这是我在 运行 python manage.py test accounts
:
时得到的输出
...log message
.log message
....log message
Ran 8 tests in 1.034s
OK
Destroying test database for alias 'default'...
当我使用 Python 标准日志记录库向我的代码添加日志记录时,这种情况就开始发生了。我更改了 settings.py
和 views.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
nose测试运行ner在settings.py
中的配置(工作时是一样的)
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'
我的问题是,因为我在 运行 时向我的 django 应用程序添加了日志记录,所以我的单元测试显示在控制台中的所有日志消息。我用鼻子作为测试 运行ner。它通常的行为是捕获 sys.stdout
,仅在测试失败时显示控制台输出并在最后显示。
我曾经在 运行 测试时有这个输出:
........
Ran 8 tests in 0.876s
OK
Destroying test database for alias 'default'...
这是我在 运行 python manage.py test accounts
:
...log message
.log message
....log message
Ran 8 tests in 1.034s
OK
Destroying test database for alias 'default'...
当我使用 Python 标准日志记录库向我的代码添加日志记录时,这种情况就开始发生了。我更改了 settings.py
和 views.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
nose测试运行ner在settings.py
中的配置(工作时是一样的)
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'