Merge pull request #4352 from blueyed/_check_initialpaths_for_relpath
Fix nodes._check_initialpaths_for_relpath for dirs
This commit is contained in:
		
						commit
						e14ca19988
					
				|  | @ -447,7 +447,7 @@ class Collector(Node): | ||||||
| def _check_initialpaths_for_relpath(session, fspath): | def _check_initialpaths_for_relpath(session, fspath): | ||||||
|     for initial_path in session._initialpaths: |     for initial_path in session._initialpaths: | ||||||
|         if fspath.common(initial_path) == initial_path: |         if fspath.common(initial_path) == initial_path: | ||||||
|             return fspath.relto(initial_path.dirname) |             return fspath.relto(initial_path) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class FSCollector(Collector): | class FSCollector(Collector): | ||||||
|  |  | ||||||
|  | @ -663,11 +663,11 @@ class TestInvocationVariants(object): | ||||||
|         assert result.ret == 0 |         assert result.ret == 0 | ||||||
|         result.stdout.fnmatch_lines( |         result.stdout.fnmatch_lines( | ||||||
|             [ |             [ | ||||||
|                 "*test_hello.py::test_hello*PASSED*", |                 "test_hello.py::test_hello*PASSED*", | ||||||
|                 "*test_hello.py::test_other*PASSED*", |                 "test_hello.py::test_other*PASSED*", | ||||||
|                 "*test_world.py::test_world*PASSED*", |                 "ns_pkg/world/test_world.py::test_world*PASSED*", | ||||||
|                 "*test_world.py::test_other*PASSED*", |                 "ns_pkg/world/test_world.py::test_other*PASSED*", | ||||||
|                 "*4 passed*", |                 "*4 passed in*", | ||||||
|             ] |             ] | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,3 +1,5 @@ | ||||||
|  | import py | ||||||
|  | 
 | ||||||
| import pytest | import pytest | ||||||
| from _pytest import nodes | from _pytest import nodes | ||||||
| 
 | 
 | ||||||
|  | @ -29,3 +31,23 @@ def test_std_warn_not_pytestwarning(testdir): | ||||||
|     ) |     ) | ||||||
|     with pytest.raises(ValueError, match=".*instance of PytestWarning.*"): |     with pytest.raises(ValueError, match=".*instance of PytestWarning.*"): | ||||||
|         items[0].warn(UserWarning("some warning")) |         items[0].warn(UserWarning("some warning")) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def test__check_initialpaths_for_relpath(): | ||||||
|  |     """Ensure that it handles dirs, and does not always use dirname.""" | ||||||
|  |     cwd = py.path.local() | ||||||
|  | 
 | ||||||
|  |     class FakeSession: | ||||||
|  |         _initialpaths = [cwd] | ||||||
|  | 
 | ||||||
|  |     assert nodes._check_initialpaths_for_relpath(FakeSession, cwd) == "" | ||||||
|  | 
 | ||||||
|  |     sub = cwd.join("file") | ||||||
|  | 
 | ||||||
|  |     class FakeSession: | ||||||
|  |         _initialpaths = [cwd] | ||||||
|  | 
 | ||||||
|  |     assert nodes._check_initialpaths_for_relpath(FakeSession, sub) == "file" | ||||||
|  | 
 | ||||||
|  |     outside = py.path.local("/outside") | ||||||
|  |     assert nodes._check_initialpaths_for_relpath(FakeSession, outside) is None | ||||||
|  |  | ||||||
|  | @ -323,7 +323,11 @@ def test_rootdir_option_arg(testdir, monkeypatch, path): | ||||||
| 
 | 
 | ||||||
|     result = testdir.runpytest("--rootdir={}".format(path)) |     result = testdir.runpytest("--rootdir={}".format(path)) | ||||||
|     result.stdout.fnmatch_lines( |     result.stdout.fnmatch_lines( | ||||||
|         ["*rootdir: {}/root, inifile:*".format(testdir.tmpdir), "*1 passed*"] |         [ | ||||||
|  |             "*rootdir: {}/root, inifile:*".format(testdir.tmpdir), | ||||||
|  |             "root/test_rootdir_option_arg.py *", | ||||||
|  |             "*1 passed*", | ||||||
|  |         ] | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue