Issue #11140: Lock.release() now raises a RuntimeError when attempting

to release an unacquired lock, as claimed in the threading documentation.
The _thread.error exception is now an alias of RuntimeError.
This commit is contained in:
Antoine Pitrou 2011-02-28 22:03:34 +00:00
parent cfbcec3823
commit fcf81fd031
4 changed files with 14 additions and 1 deletions

View File

@ -35,6 +35,9 @@ It defines the following constants and functions:
Raised on thread-specific errors.
.. versionchanged:: 3.3
This is now a synonym of the built-in :exc:`RuntimeError`.
.. data:: LockType

View File

@ -685,6 +685,10 @@ class ThreadingExceptionTests(BaseTestCase):
thread.start()
self.assertRaises(RuntimeError, setattr, thread, "daemon", True)
def test_releasing_unacquired_lock(self):
lock = threading.Lock()
self.assertRaises(RuntimeError, lock.release)
class LockTests(lock_tests.LockTests):
locktype = staticmethod(threading.Lock)

View File

@ -35,6 +35,10 @@ Core and Builtins
Library
-------
- Issue #11140: Lock.release() now raises a RuntimeError when attempting
to release an unacquired lock, as claimed in the threading documentation.
The _thread.error exception is now an alias of RuntimeError.
- Issue 8594: ftplib now provides a source_address parameter to specify which
(address, port) to bind to before connecting.

View File

@ -1308,7 +1308,9 @@ PyInit__thread(void)
/* Add a symbolic constant */
d = PyModule_GetDict(m);
ThreadError = PyErr_NewException("_thread.error", NULL, NULL);
ThreadError = PyExc_RuntimeError;
Py_INCREF(ThreadError);
PyDict_SetItemString(d, "error", ThreadError);
Locktype.tp_doc = lock_doc;
Py_INCREF(&Locktype);