Apo*_*los 5 python django logging unit-testing
我在django尝试一些简单的测试.我在我的设置文件中设置了我的django日志系统.但是当我运行我的测试时,它不会在我的控制台上打印调试消息.当我从manage.py test命令运行测试时会发生这种情况.如果我使用IDE的运行命令它会正常打印消息.我的日志设置如下
LOGGING = {
'version': 1,
'disable_existing_loggers': True,
'formatters': {
'verbose': {
'format': '%(levelname)s %(asctime)s %(module)s %(process)d (thread)d %(message)s'
},
'simple':{
'format': '%(levelname)s %(message)s'
},
},
'handlers': {
'null': {
'level': 'DEBUG',
'class': 'django.utils.log.NullHandler',
},
'console': {
'level':'DEBUG',
'class': 'logging.StreamHandler',
'formatter': 'simple',
},
},
'loggers': {
'django': {
'handlers': ['console', ],
'propagate': True,
'level': 'DEBUG'
},
'payments_system': {
'handlers': ['console', ],
'propagate': True,
'level': 'DEBUG'
}
}
}
Run Code Online (Sandbox Code Playgroud)
记录基于django的网站示例.当我使用manage.py运行测试时,如何在控制台中显示消息?
我将Django 日志记录设置为记录到文件,如下所示:
'handlers': {
'file': {
'level': 'DEBUG',
'class': 'logging.FileHandler',
'filename': '/path/to/django/debug.log',
},
},
Run Code Online (Sandbox Code Playgroud)
当我使用 运行测试时python manage.py test,日志也会转到该文件。
由于您使用的是console处理程序,因此您的日志应该发送到stdout,这可能会被测试代码过滤捕获。所以尝试使用 aFileHandler代替。有关更多详细信息,请参阅配置日志记录下的第一个示例。