4

我在一个项目中有以下结构:

app/
    __init__.py
    main.py
    tests/
        __init__.py
        test_a.py
        test_b.py

我想为tests包下的测试初始化​​日志记录。我假设初始化代码在app/tests/__init__.py任何测试运行之前运行,但我发现情况并非如此。

如何使此初始化代码在以下情况下运行?

  • python test_a.py从命令提示符运行时
  • test_a.py在 eclipse\aptana\pycharm 下作为单元测试运行时
  • 在 eclipse\aptana\pycharm 下运行整个测试套件时
4

1 回答 1

0

您可以使用记录器配置文件进行正常运行和测试,这是拥有不同配置的最安全方式。

“解决方法”的方法是重新创建记录器。您可能刚刚在 __init__.py 中添加了新的记录器?配置后,日志记录会保持其配置,并且只允许扩展。但是,您可以尝试重新创建整个记录器,如下所述: Python logging before you run logging.basicConfig? 例如:

root = logging.getLogger()
if root.handlers:
    for handler in root.handlers:
        root.removeHandler(handler)
# now create your test config
logging.basicConfig(format='%(asctime)s %(message)s',level=logging.DEBUG)

将此代码添加到您的 test.py 文件中,或将其添加到 __init__.py 但您可能需要:

from tests import *

使其在测试中执行。

于 2012-06-12T10:32:32.027 回答