summaryrefslogtreecommitdiff
path: root/src/python/stdlib/test/test_mutex.py
diff options
context:
space:
mode:
authorSimon <simon@hardwired.org.uk>2011-03-22 17:58:52 (GMT)
committer Simon <simon@hardwired.org.uk>2011-03-22 17:58:52 (GMT)
commit2e401babb793238564ca640fc802a52ab7f6c293 (patch)
tree87a9b471e82604e76f96d556f5771322fb31818a /src/python/stdlib/test/test_mutex.py
parentc096b2b14a200a0cc0a08cfea839c9e7f4edf22e (diff)
parent04a9cbcb8855e64db660a8c6e23d79114b4afd83 (diff)
downloadpowder-2e401babb793238564ca640fc802a52ab7f6c293.zip
powder-2e401babb793238564ca640fc802a52ab7f6c293.tar.gz
Python console
Diffstat (limited to 'src/python/stdlib/test/test_mutex.py')
-rw-r--r--src/python/stdlib/test/test_mutex.py35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/python/stdlib/test/test_mutex.py b/src/python/stdlib/test/test_mutex.py
new file mode 100644
index 0000000..2882213
--- /dev/null
+++ b/src/python/stdlib/test/test_mutex.py
@@ -0,0 +1,35 @@
+import unittest
+import test.test_support
+
+mutex = test.test_support.import_module("mutex", deprecated=True)
+
+class MutexTest(unittest.TestCase):
+
+ def test_lock_and_unlock(self):
+
+ def called_by_mutex(some_data):
+ self.assertEqual(some_data, "spam")
+ self.assertTrue(m.test(), "mutex not held")
+ # Nested locking
+ m.lock(called_by_mutex2, "eggs")
+
+ def called_by_mutex2(some_data):
+ self.assertEquals(some_data, "eggs")
+ self.assertTrue(m.test(), "mutex not held")
+ self.assertTrue(ready_for_2,
+ "called_by_mutex2 called too soon")
+
+ m = mutex.mutex()
+ read_for_2 = False
+ m.lock(called_by_mutex, "spam")
+ ready_for_2 = True
+ # unlock both locks
+ m.unlock()
+ m.unlock()
+ self.assertFalse(m.test(), "mutex still held")
+
+def test_main():
+ test.test_support.run_unittest(MutexTest)
+
+if __name__ == "__main__":
+ test_main()