【问题标题】:Logging not showing in console during django tests在 django 测试期间日志未显示在控制台中
【发布时间】:2015-08-13 13:15:18
【问题描述】:

我正在 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'
        }
    }
}

日志记录基于 django 的网站示例。使用 manage.py 运行测试时,如何使消息显示在控制台中?

【问题讨论】:

标签: python django unit-testing logging


【解决方案1】:

我已将Django logging 设置为记录到文件,如下所示:

'handlers': {
    'file': {
        'level': 'DEBUG',
        'class': 'logging.FileHandler',
        'filename': '/path/to/django/debug.log',
    },
},

当我使用 python manage.py test 运行测试时,日志也会转到该文件。

由于您使用的是console 处理程序,因此您的日志应该转到stdout,这很可能被测试代码过滤捕获。所以尝试改用FileHandler。详情请参考Configuring Logging 下的第一个示例。

【讨论】:

    猜你喜欢
    • 2023-03-20
    • 1970-01-01
    • 2018-06-10
    • 2022-01-16
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-10-28
    • 1970-01-01
    相关资源
    最近更新 更多