Added simple test case. Thanks Benjamin Peterson.
This commit is contained in:
parent
0bb8567e1e
commit
c12b9888f7
|
@ -0,0 +1,33 @@
|
||||||
|
import mutex
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
import test.test_support
|
||||||
|
|
||||||
|
class MutexTest(unittest.TestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
self.mutex = mutex.mutex()
|
||||||
|
|
||||||
|
def called_by_mutex(self, some_data):
|
||||||
|
self.assert_(self.mutex.test(), "mutex not held")
|
||||||
|
# Nested locking
|
||||||
|
self.mutex.lock(self.called_by_mutex2, "eggs")
|
||||||
|
|
||||||
|
def called_by_mutex2(self, some_data):
|
||||||
|
self.assert_(self.ready_for_2,
|
||||||
|
"called_by_mutex2 called too soon")
|
||||||
|
|
||||||
|
def test_lock_and_unlock(self):
|
||||||
|
self.read_for_2 = False
|
||||||
|
self.mutex.lock(self.called_by_mutex, "spam")
|
||||||
|
self.ready_for_2 = True
|
||||||
|
# unlock both locks
|
||||||
|
self.mutex.unlock()
|
||||||
|
self.mutex.unlock()
|
||||||
|
self.failIf(self.mutex.test(), "mutex still held")
|
||||||
|
|
||||||
|
def test_main():
|
||||||
|
test.test_support.run_unittest(MutexTest)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
test_main()
|
Loading…
Reference in New Issue