pytest не может импортировать модуль, пока python может

Я работаю над пакетом в Python. Я использую виртуальное окружение. Я установил путь к корню модуля в a .PTH-путь в моем virtualenv, чтобы я мог импортировать модули пакета при разработке кода и выполнять тестирование (Вопрос 1: это хороший способ сделать?). Это отлично работает (вот пример, это поведение, которое я хочу):

(VEnvTestRc) zz@zz:~/Desktop/GitFolders/rc$ python
Python 2.7.12 (default, Jul  1 2016, 15:12:24) 
[GCC 5.4.0 20160609] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> from rc import ns
>>> exit()
(VEnvTestRc) zz@zz:~/Desktop/GitFolders/rc$ python tests/test_ns.py 
issued command: echo hello
command output: hello

однако, если я попытаюсь использовать PyTest, я получу некоторые сообщения об ошибках импорта:

(VEnvTestRc) zz@zz:~/Desktop/GitFolders/rc$ pytest
=========================================== test session starts ============================================
platform linux2 -- Python 2.7.12, pytest-3.0.5, py-1.4.31, pluggy-0.4.0
rootdir: /home/zz/Desktop/GitFolders/rc, inifile: 
collected 0 items / 1 errors 

================================================== ERRORS ==================================================
________________________________ ERROR collecting tests/test_ns.py ________________________________
ImportError while importing test module '/home/zz/Desktop/GitFolders/rc/tests/test_ns.py'.
Hint: make sure your test modules/packages have valid Python names.
Traceback:
tests/test_ns.py:2: in <module>
    from rc import ns
E   ImportError: cannot import name ns
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! Interrupted: 1 errors during collection !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
========================================= 1 error in 0.09 seconds ==========================================
(VEnvTestRc) zz@zz:~/Desktop/GitFolders/rc$ which pytest
/home/zz/Desktop/VirtualEnvs/VEnvTestRc/bin/pytest

Я немного озадачен, Это выглядит так указывает на ошибку импорта, но Python делает это хорошо, так почему есть проблема именно с PyTest? Любые предложения относительно причины / средства правовой защиты (Вопрос 2)? Я погуглил и стек переполнен ошибкой "ImportError: не могу импортировать" для PyTest, но хиты, которые я получил, были связаны с отсутствующим путем python и исправлением этого, что, похоже, не является проблемой здесь. Есть предложения?

9 ответов


нашел ответ:

Не ставьте __init__.py файл в папке, содержащей тесты, Если вы планируете использовать pytest. У меня был один такой файл, удаление его решило проблему.

Это было фактически похоронено в комментариях ко второму ответу проблема пути с pytest 'ImportError: нет модуля с именем YadaYadaYada' поэтому я его не видел, надеюсь, что здесь будет больше видимости.


Я не могу сказать, что я понимаю, почему это работает, но у меня была та же проблема и тесты работают нормально, если я запустить python -m pytest.

Я в virtualenv, с pytest также доступны по всему миру:

(proj)tom@neon ~/dev/proj$ type -a python
python is /home/tom/.virtualenvs/proj/bin/python
python is /usr/bin/python

(proj)tom@neon ~/dev/proj$ python -V
Python 3.5.2

(proj)tom@neon ~/dev/proj$ type -a pytest
pytest is /home/tom/.virtualenvs/proj/bin/pytest
pytest is /usr/bin/pytest

(proj)tom@neon ~/dev/proj$ pytest --version
This is pytest version 3.5.0, imported from /home/tom/.virtualenvs/proj/lib/python3.5/site-packages/pytest.py

у меня была та же проблема, но по другой причине, чем упомянутые:

у меня был пай.тестирование установлено глобально, в то время как пакеты были установлены в виртуальной среде.

решение было установка pytest в виртуальной среде. (Если ваша оболочка хэширует исполняемые файлы, как это делает Bash, используйте hash -r, или используйте полный путь к py.test)


Я просто решил это, удалив __init__.py в моем проекте root:

.
├── __init__.py <--- removed
├── models
│   ├── __init__.py
│   ├── address.py
│   ├── appointment.py
│   └── client.py
├── requirements.txt
├── setup.cfg
├── tests
│   ├── __init__.py
│   ├── models
│   │   ├── __init__.py
│   │   ├── appointment_test.py
│   │   └── client_test.py
│   └── other_test.py
└── script.py

эта проблема произойдет, если у вас есть tests.py файл и папка тестов с tests/__init__.py.

во время сбора pytest находит папку, но при попытке импортировать тестовые файлы из папки tests.py файл вызовет проблему импорта.

чтобы исправить, просто удалите tests.py файл и поместите все свои тесты внутри .

для вашего конкретного случая исправление будет точно:

  • удалить файл /home/zz/Desktop/GitFolders/rc/tests.py
  • убедится /home/zz/Desktop/GitFolders/rc/tests/__init__.py присутствует

в моем случае произошла ошибка импорта, потому что пакет указывает на другой пакет / каталог с то же имя и его путь на один уровень выше папки, которую я действительно хотел. Я думаю, это также объясняет, почему некоторым людям нужно удалить _ init _.py в то время как другие должны добавить обратно.

Я просто ставлю print(the_root_package.__path__) (после import the_root_package) в и pytest скрипты для сравнения разница

НИЖНЯЯ СТРОКА: Когда вы делаете python, импортируемый пакет может отличаться от пакета при запуске pytest.


возможно, Pytest не читает пакет как модуль Python, в то время как Python (вероятно, из-за проблем пути). Попробуйте изменить каталог скрипта pytest или явно добавить модуль в PYTHONPATH.

или может быть, что у вас есть две версии Python, установленные на вашем компьютере. Проверьте источник Python для pytest и для оболочки python, которую вы запускаете. Если они разные (например, Python 2 vs 3), Используйте source activate чтобы убедиться, что вы используете pytest установлен для того же python, в котором установлен модуль.


У меня была аналогичная проблема, точно такая же ошибка, но другая причина. Я запускал тестовый код просто отлично, но против старой версии модуля. В предыдущей версии моего кода один класс существовал, а другой-нет. После обновления моего кода я должен был запустить следующее, Чтобы установить его.

sudo pip install ./ --upgrade

при установке обновленного модуля под управлением pytest получены правильные результаты (потому что я использовал правильную базу кода).


установите пакеты в виртуальную среду.
Затем запустите новую оболочку и снова создайте виртуальную среду.