mirror of
https://github.com/python/cpython.git
synced 2025-09-28 19:25:27 +00:00
Merged revisions 74524,74556 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r74524 | gregory.p.smith | 2009-08-20 04:39:38 -0500 (Thu, 20 Aug 2009) | 2 lines Add weakref support to the thread.lock type. ........ r74556 | kristjan.jonsson | 2009-08-27 17:20:21 -0500 (Thu, 27 Aug 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. ........
This commit is contained in:
parent
2e30440153
commit
9a779ea98e
5 changed files with 30 additions and 2 deletions
|
@ -891,6 +891,10 @@ 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.
|
||||||
|
|
||||||
|
|
|
@ -61,6 +61,9 @@ instances, functions written in Python (but not in C), instance methods, sets,
|
||||||
frozensets, file objects, :term:`generator`\s, type objects, sockets, arrays,
|
frozensets, file objects, :term:`generator`\s, type objects, sockets, arrays,
|
||||||
deques, and regular expression pattern objects.
|
deques, and regular expression pattern objects.
|
||||||
|
|
||||||
|
.. versionchanged:: 2.7
|
||||||
|
Added support for thread.lock and threading.Lock.
|
||||||
|
|
||||||
Several built-in types such as :class:`list` and :class:`dict` do not directly
|
Several built-in types such as :class:`list` and :class:`dict` do not directly
|
||||||
support weak references but can add support through subclassing::
|
support weak references but can add support through subclassing::
|
||||||
|
|
||||||
|
|
|
@ -2834,6 +2834,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,7 @@ 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
|
||||||
|
self.exc_value = exc_value #store for later retrieval
|
||||||
if self.expected_regex is None:
|
if self.expected_regex is None:
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
/* Interface to Sjoerd's portable C thread library */
|
/* Interface to Sjoerd's portable C thread library */
|
||||||
|
|
||||||
#include "Python.h"
|
#include "Python.h"
|
||||||
|
#include "structmember.h" /* offsetof */
|
||||||
|
|
||||||
#ifndef WITH_THREAD
|
#ifndef WITH_THREAD
|
||||||
#error "Error! The rest of Python is not compiled with thread support."
|
#error "Error! The rest of Python is not compiled with thread support."
|
||||||
|
@ -20,12 +21,15 @@ static PyObject *ThreadError;
|
||||||
typedef struct {
|
typedef struct {
|
||||||
PyObject_HEAD
|
PyObject_HEAD
|
||||||
PyThread_type_lock lock_lock;
|
PyThread_type_lock lock_lock;
|
||||||
|
PyObject *in_weakreflist;
|
||||||
} lockobject;
|
} lockobject;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
lock_dealloc(lockobject *self)
|
lock_dealloc(lockobject *self)
|
||||||
{
|
{
|
||||||
assert(self->lock_lock);
|
assert(self->lock_lock);
|
||||||
|
if (self->in_weakreflist != NULL)
|
||||||
|
PyObject_ClearWeakRefs((PyObject *) self);
|
||||||
/* Unlock the lock so it's safe to free it */
|
/* Unlock the lock so it's safe to free it */
|
||||||
PyThread_acquire_lock(self->lock_lock, 0);
|
PyThread_acquire_lock(self->lock_lock, 0);
|
||||||
PyThread_release_lock(self->lock_lock);
|
PyThread_release_lock(self->lock_lock);
|
||||||
|
@ -145,7 +149,7 @@ static PyTypeObject Locktype = {
|
||||||
0, /*tp_traverse*/
|
0, /*tp_traverse*/
|
||||||
0, /*tp_clear*/
|
0, /*tp_clear*/
|
||||||
0, /*tp_richcompare*/
|
0, /*tp_richcompare*/
|
||||||
0, /*tp_weaklistoffset*/
|
offsetof(lockobject, in_weakreflist), /*tp_weaklistoffset*/
|
||||||
0, /*tp_iter*/
|
0, /*tp_iter*/
|
||||||
0, /*tp_iternext*/
|
0, /*tp_iternext*/
|
||||||
lock_methods, /*tp_methods*/
|
lock_methods, /*tp_methods*/
|
||||||
|
@ -159,6 +163,7 @@ newlockobject(void)
|
||||||
if (self == NULL)
|
if (self == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
self->lock_lock = PyThread_allocate_lock();
|
self->lock_lock = PyThread_allocate_lock();
|
||||||
|
self->in_weakreflist = NULL;
|
||||||
if (self->lock_lock == NULL) {
|
if (self->lock_lock == NULL) {
|
||||||
PyObject_Del(self);
|
PyObject_Del(self);
|
||||||
self = NULL;
|
self = NULL;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue