summaryrefslogtreecommitdiff
path: root/src/python/stdlib/test/test_mutex.py
diff options
context:
space:
mode:
authorLieuwe <lieuwemo@gmail.com>2011-03-18 16:04:51 (GMT)
committer Lieuwe <lieuwemo@gmail.com>2011-03-18 16:04:51 (GMT)
commit9c39875ef09d439ef51716dba091188f72977f5e (patch)
treefb0fd27a1bcd3e54a1913852c23aa137ee5eb30b /src/python/stdlib/test/test_mutex.py
parentbc8af4e2101ac93bdc51b59ee64fa43ecb2442f3 (diff)
downloadpowder-9c39875ef09d439ef51716dba091188f72977f5e.zip
powder-9c39875ef09d439ef51716dba091188f72977f5e.tar.gz
...
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()