From 8c9efd86087c36dda54cbe5284c1f804688bd443 Mon Sep 17 00:00:00 2001 From: Bruno Oliveira Date: Tue, 31 Jul 2018 19:06:30 -0300 Subject: [PATCH] Only call _collectfile on package instances As discussed in #3751, this feels like a hack, pushing it only so we can see how it fares on CI and if there are better solutions out there --- src/_pytest/main.py | 4 +++- testing/test_collection.py | 2 +- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/src/_pytest/main.py b/src/_pytest/main.py index 9599fa1617..105891e468 100644 --- a/src/_pytest/main.py +++ b/src/_pytest/main.py @@ -482,6 +482,8 @@ def collect(self): self.trace.root.indent -= 1 def _collect(self, arg): + from _pytest.python import Package + names = self._parsearg(arg) argpath = names.pop(0) paths = [] @@ -503,7 +505,7 @@ def _collect(self, arg): root = self._node_cache[pkginit] else: col = root._collectfile(pkginit) - if col: + if col and isinstance(col, Package): root = col[0] self._node_cache[root.fspath] = root diff --git a/testing/test_collection.py b/testing/test_collection.py index 6480cc85d4..23d82cb141 100644 --- a/testing/test_collection.py +++ b/testing/test_collection.py @@ -647,7 +647,7 @@ def test_pkgfile(self, testdir): col = testdir.getnode(config, x) assert isinstance(col, pytest.Module) assert col.name == "x.py" - assert col.parent.parent.parent is None + assert col.parent.parent is None for col in col.listchain(): assert col.config is config