diff options
| author | Brett Cannon <brett@python.org> | 2011-03-15 21:23:21 (GMT) |
|---|---|---|
| committer | Brett Cannon <brett@python.org> | 2011-03-15 21:23:21 (GMT) |
| commit | f434ba9e4ef5a68940757ba5e3527dd02fdb53ca (patch) | |
| tree | a07c3480561906d1aa0ce04ea6cbd2b732ff3cca /Lib/test/support.py | |
| parent | f30645d5521afe5537befd0d9e84a7c539135cdc (diff) | |
| parent | 765dcdede824c41011228461e4a5fdaec6fc90d2 (diff) | |
| download | cpython-f434ba9e4ef5a68940757ba5e3527dd02fdb53ca.zip cpython-f434ba9e4ef5a68940757ba5e3527dd02fdb53ca.tar.gz cpython-f434ba9e4ef5a68940757ba5e3527dd02fdb53ca.tar.bz2 | |
merge
Diffstat (limited to 'Lib/test/support.py')
| -rw-r--r-- | Lib/test/support.py | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/Lib/test/support.py b/Lib/test/support.py index f5a53ca..98f333e 100644 --- a/Lib/test/support.py +++ b/Lib/test/support.py @@ -1478,3 +1478,36 @@ def skip_unless_symlink(test): ok = can_symlink() msg = "Requires functional symlink implementation" return test if ok else unittest.skip(msg)(test) + +def patch(test_instance, object_to_patch, attr_name, new_value): + """Override 'object_to_patch'.'attr_name' with 'new_value'. + + Also, add a cleanup procedure to 'test_instance' to restore + 'object_to_patch' value for 'attr_name'. + The 'attr_name' should be a valid attribute for 'object_to_patch'. + + """ + # check that 'attr_name' is a real attribute for 'object_to_patch' + # will raise AttributeError if it does not exist + getattr(object_to_patch, attr_name) + + # keep a copy of the old value + attr_is_local = False + try: + old_value = object_to_patch.__dict__[attr_name] + except (AttributeError, KeyError): + old_value = getattr(object_to_patch, attr_name, None) + else: + attr_is_local = True + + # restore the value when the test is done + def cleanup(): + if attr_is_local: + setattr(object_to_patch, attr_name, old_value) + else: + delattr(object_to_patch, attr_name) + + test_instance.addCleanup(cleanup) + + # actually override the attribute + setattr(object_to_patch, attr_name, new_value) |
