当我使用coverage.py运行一系列测试时,我得到一个导入错误,其中nose是底层测试运行器。如果我只是在Python下运行,测试运行正常。
coverage run run_tests.py
ERROR
======================================================================
ERROR: <nose.suite.ContextSuite context=nova.tests>
----------------------------------------------------------------------
Traceback (most recent call last):
File "/Users/lorin/nova/hpc-trunk/.nova-venv/lib/python2.6/site-packages/nose/suite.py", line 208, in run
self.setUp()
File "/Users/lorin/nova/hpc-trunk/.nova-venv/lib/python2.6/site-packages/nose/suite.py", line 291, in setUp
self.setupContext(ancestor)
File "/Users/lorin/nova/hpc-trunk/.nova-venv/lib/python2.6/site-packages/nose/suite.py", line 314, in setupContext
try_run(context, names)
File "/Users/lorin/nova/hpc-trunk/.nova-venv/lib/python2.6/site-packages/nose/util.py", line 478, in try_run
return func()
File "/Users/lorin/nova/trunk/nova/tests/__init__.py", line 43, in setup
from nova import context
ImportError: cannot import name context
这似乎不是路径错误,相反,当我通过执行“覆盖运行”运行测试时,似乎“nova”模块的子模块不可见。我通过将以下代码添加到失败的方法中找到了这个:
import nova; print nova.__path__
print dir(nova)
当我以python run_tests.py
运行时,我看到以下输出:
['/Users/lorin/nova/hpc-trunk/nova']
['__builtins__', '__doc__', '__file__', '__name__', '__package__', '__path__',
'api', 'auth', 'compute', 'console', 'context', 'crypto', 'db', 'exception',
'fakerabbit', 'flags', 'image', 'ipv6', 'log', 'manager', 'network', 'objectstore',
'quota', 'rpc', 'scheduler', 'service', 'test', 'tests', 'twistd', 'utils', 'version',
'virt', 'vnc', 'volume', 'wsgi']
但是,当我以coverage run run_tests.py
运行时,我会看到以下输出:
['/Users/lorin/nova/hpc-trunk/nova']
['__builtins__', '__doc__', '__file__', '__name__', '__package__', '__path__',
'api', 'tests']
似乎它在每种情况下都在同一个地方找到了nova模块,但是在我用coverage运行它的情况下,Python没有看到大多数子模块:(auth,compute,...)控制台。
请注意,当我使用nose的coverage插件时,不会发生此问题,但在这种特殊情况下,我不想使用该插件。
答案 0 :(得分:2)
这是coverage.py的一个问题。当它将当前目录插入sys.path列表时,它没有使用绝对路径,这会以某种方式导致此问题。 Coverage.py现已修复:https://bitbucket.org/ned/coveragepy/changeset/811ed58de8a3