[7.1.x] config: restore pre-pytest 7.1.0 confcutdir exclusion behavior
This commit is contained in:
		
							parent
							
								
									7d4d1ecde6
								
							
						
					
					
						commit
						f1df8074b3
					
				|  | @ -0,0 +1 @@ | |||
| Fixed a regression in pytest 7.1.0 where some conftest.py files outside of the source tree (e.g. in the `site-packages` directory) were not picked up. | ||||
|  | @ -538,11 +538,7 @@ class PytestPluginManager(PluginManager): | |||
|         """ | ||||
|         if self._confcutdir is None: | ||||
|             return True | ||||
|         try: | ||||
|             path.relative_to(self._confcutdir) | ||||
|         except ValueError: | ||||
|             return False | ||||
|         return True | ||||
|         return path not in self._confcutdir.parents | ||||
| 
 | ||||
|     def _try_load_conftest( | ||||
|         self, anchor: Path, importmode: Union[str, ImportMode], rootpath: Path | ||||
|  |  | |||
|  | @ -252,6 +252,34 @@ def test_conftest_confcutdir(pytester: Pytester) -> None: | |||
|     result.stdout.no_fnmatch_line("*warning: could not load initial*") | ||||
| 
 | ||||
| 
 | ||||
| def test_installed_conftest_is_picked_up(pytester: Pytester, tmp_path: Path) -> None: | ||||
|     """When using `--pyargs` to run tests in an installed packages (located e.g. | ||||
|     in a site-packages in the PYTHONPATH), conftest files in there are picked | ||||
|     up. | ||||
| 
 | ||||
|     Regression test for #9767. | ||||
|     """ | ||||
|     # pytester dir - the source tree. | ||||
|     # tmp_path - the simulated site-packages dir (not in source tree). | ||||
| 
 | ||||
|     pytester.syspathinsert(tmp_path) | ||||
|     pytester.makepyprojecttoml("[tool.pytest.ini_options]") | ||||
|     tmp_path.joinpath("foo").mkdir() | ||||
|     tmp_path.joinpath("foo", "__init__.py").touch() | ||||
|     tmp_path.joinpath("foo", "conftest.py").write_text( | ||||
|         textwrap.dedent( | ||||
|             """\ | ||||
|             import pytest | ||||
|             @pytest.fixture | ||||
|             def fix(): return None | ||||
|             """ | ||||
|         ) | ||||
|     ) | ||||
|     tmp_path.joinpath("foo", "test_it.py").write_text("def test_it(fix): pass") | ||||
|     result = pytester.runpytest("--pyargs", "foo") | ||||
|     assert result.ret == 0 | ||||
| 
 | ||||
| 
 | ||||
| def test_conftest_symlink(pytester: Pytester) -> None: | ||||
|     """`conftest.py` discovery follows normal path resolution and does not resolve symlinks.""" | ||||
|     # Structure: | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue