summaryrefslogtreecommitdiff
path: root/mocker.py
diff options
context:
space:
mode:
authorGustavo Niemeyer <gustavo@niemeyer.net>2007-12-04 23:37:47 -0200
committerGustavo Niemeyer <gustavo@niemeyer.net>2007-12-04 23:37:47 -0200
commitcaeaec199b25c99e18ed13abc7ad89ff624ec44a (patch)
treeaf5112954ae4278dc54006f8fa1f08bf39cd1f88 /mocker.py
parent47587fc40380290700dd6f182c255397cd17e75f (diff)
downloadmocker-caeaec199b25c99e18ed13abc7ad89ff624ec44a.tar.gz
Implemented support for Deferred results as understood by
Twisted Trial's TestCase, so that coexistence by multiple inheritance is possible and trivial.
Diffstat (limited to 'mocker.py')
-rw-r--r--mocker.py22
1 files changed, 16 insertions, 6 deletions
diff --git a/mocker.py b/mocker.py
index 8929b91..79f7191 100644
--- a/mocker.py
+++ b/mocker.py
@@ -98,15 +98,18 @@ class MockerTestCase(unittest.TestCase):
if test_method is not None:
def test_method_wrapper():
try:
- test_method()
+ result = test_method()
except:
self.__cleanup()
- self.mocker.restore()
raise
else:
- self.__cleanup()
- self.mocker.restore()
- self.mocker.verify()
+ if (hasattr(result, "addCallback") and
+ hasattr(result, "addErrback")):
+ result.addErrback(self.__cleanup)
+ result.addCallback(self.__cleanup_verify)
+ else:
+ self.__cleanup_verify()
+ return result
# Copy all attributes from the original method..
for attr in dir(test_method):
# .. unless they're present in our wrapper already.
@@ -121,12 +124,19 @@ class MockerTestCase(unittest.TestCase):
super(MockerTestCase, self).__init__(methodName)
- def __cleanup(self):
+ def __cleanup_verify(self, result=None):
+ self.__cleanup()
+ self.mocker.verify()
+ return result
+
+ def __cleanup(self, result=None):
for path in self.__cleanup_paths:
if os.path.isfile(path):
os.unlink(path)
elif os.path.isdir(path):
shutil.rmtree(path)
+ self.mocker.restore()
+ return result
def makeFile(self, content=None, suffix="", prefix="tmp", basename=None,
dirname=None):