This commit is contained in:
		
							parent
							
								
									4d8903fd0b
								
							
						
					
					
						commit
						bfd0addaeb
					
				|  | @ -216,18 +216,6 @@ def pytest_pycollect_makemodule(path, parent): | ||||||
|     return Module(path, parent) |     return Module(path, parent) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def pytest_ignore_collect(path, config): |  | ||||||
|     # Skip duplicate packages. |  | ||||||
|     keepduplicates = config.getoption("keepduplicates") |  | ||||||
|     if keepduplicates: |  | ||||||
|         duplicate_paths = config.pluginmanager._duplicatepaths |  | ||||||
|         if path.basename == "__init__.py": |  | ||||||
|             if path in duplicate_paths: |  | ||||||
|                 return True |  | ||||||
|             else: |  | ||||||
|                 duplicate_paths.add(path) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| @hookimpl(hookwrapper=True) | @hookimpl(hookwrapper=True) | ||||||
| def pytest_pycollect_makeitem(collector, name, obj): | def pytest_pycollect_makeitem(collector, name, obj): | ||||||
|     outcome = yield |     outcome = yield | ||||||
|  | @ -554,9 +542,7 @@ class Package(Module): | ||||||
|         self.name = fspath.dirname |         self.name = fspath.dirname | ||||||
|         self.trace = session.trace |         self.trace = session.trace | ||||||
|         self._norecursepatterns = session._norecursepatterns |         self._norecursepatterns = session._norecursepatterns | ||||||
|         for path in list(session.config.pluginmanager._duplicatepaths): |         self.fspath = fspath | ||||||
|             if path.dirname == fspath.dirname and path != fspath: |  | ||||||
|                 session.config.pluginmanager._duplicatepaths.remove(path) |  | ||||||
| 
 | 
 | ||||||
|     def _recurse(self, path): |     def _recurse(self, path): | ||||||
|         ihook = self.gethookproxy(path.dirpath()) |         ihook = self.gethookproxy(path.dirpath()) | ||||||
|  | @ -594,6 +580,15 @@ class Package(Module): | ||||||
|         return path in self.session._initialpaths |         return path in self.session._initialpaths | ||||||
| 
 | 
 | ||||||
|     def collect(self): |     def collect(self): | ||||||
|  |         # XXX: HACK! | ||||||
|  |         # Before starting to collect any files from this package we need | ||||||
|  |         # to cleanup the duplicate paths added by the session's collect(). | ||||||
|  |         # Proper fix is to not track these as duplicates in the first place. | ||||||
|  |         for path in list(self.session.config.pluginmanager._duplicatepaths): | ||||||
|  |             # if path.parts()[:len(self.fspath.dirpath().parts())] == self.fspath.dirpath().parts(): | ||||||
|  |             if path.dirname.startswith(self.name): | ||||||
|  |                 self.session.config.pluginmanager._duplicatepaths.remove(path) | ||||||
|  | 
 | ||||||
|         this_path = self.fspath.dirpath() |         this_path = self.fspath.dirpath() | ||||||
|         pkg_prefix = None |         pkg_prefix = None | ||||||
|         for path in this_path.visit(rec=self._recurse, bf=True, sort=True): |         for path in this_path.visit(rec=self._recurse, bf=True, sort=True): | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue