From 198fcd8a6f442e67b309e4ee2015944d93c6497e Mon Sep 17 00:00:00 2001 From: Daniel Hahler Date: Mon, 5 Aug 2019 17:51:51 +0200 Subject: [PATCH] Fix RuntimeError when trying to collect package with "__init__.py" only Fixes https://github.com/pytest-dev/pytest/issues/4344. --- changelog/4344.bugfix.rst | 1 + src/_pytest/main.py | 8 +++++++- testing/test_collection.py | 12 ++++++++++++ 3 files changed, 20 insertions(+), 1 deletion(-) create mode 100644 changelog/4344.bugfix.rst diff --git a/changelog/4344.bugfix.rst b/changelog/4344.bugfix.rst new file mode 100644 index 00000000000..644a6f03058 --- /dev/null +++ b/changelog/4344.bugfix.rst @@ -0,0 +1 @@ +Fix RuntimeError/StopIteration when trying to collect package with "__init__.py" only. diff --git a/src/_pytest/main.py b/src/_pytest/main.py index f28bc68db34..8d3f9f23431 100644 --- a/src/_pytest/main.py +++ b/src/_pytest/main.py @@ -584,7 +584,13 @@ def _collect(self, arg): # Module itself, so just use that. If this special case isn't taken, then all # the files in the package will be yielded. if argpath.basename == "__init__.py": - yield next(m[0].collect()) + try: + yield next(m[0].collect()) + except StopIteration: + # The package collects nothing with only an __init__.py + # file in it, which gets ignored by the default + # "python_files" option. + pass return yield from m diff --git a/testing/test_collection.py b/testing/test_collection.py index 864125c40af..dee07d5c715 100644 --- a/testing/test_collection.py +++ b/testing/test_collection.py @@ -1203,6 +1203,18 @@ def test_collect_pkg_init_and_file_in_args(testdir): ) +def test_collect_pkg_init_only(testdir): + subdir = testdir.mkdir("sub") + init = subdir.ensure("__init__.py") + init.write("def test_init(): pass") + + result = testdir.runpytest(str(init)) + result.stdout.fnmatch_lines(["*no tests ran in*"]) + + result = testdir.runpytest("-v", "-o", "python_files=*.py", str(init)) + result.stdout.fnmatch_lines(["sub/__init__.py::test_init PASSED*", "*1 passed in*"]) + + @pytest.mark.skipif( not hasattr(py.path.local, "mksymlinkto"), reason="symlink not available on this platform",