Merged in The-Compiler/pytest (pull request #298)
Fix monkeypatch.setenv with string and raising=False.
This commit is contained in:
commit
ad08bf79e7
|
@ -27,7 +27,7 @@ def pytest_funcarg__monkeypatch(request):
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def derive_importpath(import_path):
|
def derive_importpath(import_path, raising):
|
||||||
import pytest
|
import pytest
|
||||||
if not isinstance(import_path, _basestring) or "." not in import_path:
|
if not isinstance(import_path, _basestring) or "." not in import_path:
|
||||||
raise TypeError("must be absolute import path string, not %r" %
|
raise TypeError("must be absolute import path string, not %r" %
|
||||||
|
@ -51,7 +51,8 @@ def derive_importpath(import_path):
|
||||||
attr = rest.pop()
|
attr = rest.pop()
|
||||||
obj = getattr(obj, attr)
|
obj = getattr(obj, attr)
|
||||||
attr = rest[0]
|
attr = rest[0]
|
||||||
getattr(obj, attr)
|
if raising:
|
||||||
|
getattr(obj, attr)
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
__tracebackhide__ = True
|
__tracebackhide__ = True
|
||||||
pytest.fail("object %r has no attribute %r" % (obj, attr))
|
pytest.fail("object %r has no attribute %r" % (obj, attr))
|
||||||
|
@ -95,7 +96,7 @@ class monkeypatch:
|
||||||
"setattr(target, value) with target being a dotted "
|
"setattr(target, value) with target being a dotted "
|
||||||
"import string")
|
"import string")
|
||||||
value = name
|
value = name
|
||||||
name, target = derive_importpath(target)
|
name, target = derive_importpath(target, raising)
|
||||||
|
|
||||||
oldval = getattr(target, name, notset)
|
oldval = getattr(target, name, notset)
|
||||||
if raising and oldval is notset:
|
if raising and oldval is notset:
|
||||||
|
@ -124,7 +125,7 @@ class monkeypatch:
|
||||||
raise TypeError("use delattr(target, name) or "
|
raise TypeError("use delattr(target, name) or "
|
||||||
"delattr(target) with target being a dotted "
|
"delattr(target) with target being a dotted "
|
||||||
"import string")
|
"import string")
|
||||||
name, target = derive_importpath(target)
|
name, target = derive_importpath(target, raising)
|
||||||
|
|
||||||
if not hasattr(target, name):
|
if not hasattr(target, name):
|
||||||
if raising:
|
if raising:
|
||||||
|
|
|
@ -62,6 +62,11 @@ class TestSetattrWithImportPath:
|
||||||
pytest.raises(pytest.fail.Exception,
|
pytest.raises(pytest.fail.Exception,
|
||||||
lambda: monkeypatch.setattr("os.path.qweqwe", None))
|
lambda: monkeypatch.setattr("os.path.qweqwe", None))
|
||||||
|
|
||||||
|
def test_unknown_attr_non_raising(self, monkeypatch):
|
||||||
|
# https://bitbucket.org/pytest-dev/pytest/issue/746/
|
||||||
|
monkeypatch.setattr('os.path.qweqwe', 42, raising=False)
|
||||||
|
assert os.path.qweqwe == 42
|
||||||
|
|
||||||
def test_delattr(self, monkeypatch):
|
def test_delattr(self, monkeypatch):
|
||||||
monkeypatch.delattr("os.path.abspath")
|
monkeypatch.delattr("os.path.abspath")
|
||||||
assert not hasattr(os.path, "abspath")
|
assert not hasattr(os.path, "abspath")
|
||||||
|
|
Loading…
Reference in New Issue