Kaydet (Commit) 92a653af authored tarafından Kristján Valur Jónsson's avatar Kristján Valur Jónsson

Merged revisions 74556 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/trunk

........
  r74556 | kristjan.jonsson | 2009-08-27 22:20:21 +0000 (fim., 27 ßg·. 2009) | 2 lines

  issue 6275
  Add an "exc_value" attribute to the _AssertRaisesContext context manager in the unittest package.  This allows further tests on the exception that was raised after the context manager exits.
........
üst 0daed996
...@@ -891,12 +891,19 @@ Test cases ...@@ -891,12 +891,19 @@ Test cases
with self.failUnlessRaises(some_error_class): with self.failUnlessRaises(some_error_class):
do_something() do_something()
The context manager will store the caught exception object in its
:attr:`exc_value` attribute. This can be useful if the intention
is to perform additional checks on the exception raised.
.. versionchanged:: 3.1 .. versionchanged:: 3.1
Added the ability to use :meth:`assertRaises` as a context manager. Added the ability to use :meth:`assertRaises` as a context manager.
.. deprecated:: 3.1 .. deprecated:: 3.1
:meth:`failUnlessRaises`. :meth:`failUnlessRaises`.
.. versionchanged:: 3.1
Added the :attr:`exc_value` attribute.
.. method:: assertRaisesRegexp(exception, regexp[, callable, ...]) .. method:: assertRaisesRegexp(exception, regexp[, callable, ...])
......
...@@ -2847,6 +2847,21 @@ test case ...@@ -2847,6 +2847,21 @@ test case
self.assertRaisesRegexp, Exception, self.assertRaisesRegexp, Exception,
re.compile('^Expected$'), Stub) re.compile('^Expected$'), Stub)
def testAssertRaisesExcValue(self):
class ExceptionMock(Exception):
pass
def Stub(foo):
raise ExceptionMock(foo)
v = "particular value"
ctx = self.assertRaises(ExceptionMock)
with ctx:
Stub(v)
e = ctx.exc_value
self.assertTrue(isinstance(e, ExceptionMock))
self.assertEqual(e.args[0], v)
def testSynonymAssertMethodNames(self): def testSynonymAssertMethodNames(self):
"""Test undocumented method name synonyms. """Test undocumented method name synonyms.
......
...@@ -116,6 +116,9 @@ class _AssertRaisesContext(object): ...@@ -116,6 +116,9 @@ class _AssertRaisesContext(object):
if not issubclass(exc_type, self.expected): if not issubclass(exc_type, self.expected):
# let unexpected exceptions pass through # let unexpected exceptions pass through
return False return False
#store exception, without traceback, for later retrieval
self.exc_value = exc_value
self.exc_value.with_traceback(None)
if self.expected_regex is None: if self.expected_regex is None:
return True return True
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment