diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2012-12-29 19:34:11 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2012-12-29 19:34:11 (GMT) |
commit | f2b9cf4e612551eec954ee42e4ae3f0dfde3fd03 (patch) | |
tree | 37683aa6a808b44e67fee5e41a08b056eac8b15c /Lib/test/test_sched.py | |
parent | c04957bff3a53ba3d051b7c4148a48ec5238f3cb (diff) | |
download | cpython-f2b9cf4e612551eec954ee42e4ae3f0dfde3fd03.zip cpython-f2b9cf4e612551eec954ee42e4ae3f0dfde3fd03.tar.gz cpython-f2b9cf4e612551eec954ee42e4ae3f0dfde3fd03.tar.bz2 |
Issue #16165: Fix sched.scheduler.run() method was block a scheduler for
other threads.
Diffstat (limited to 'Lib/test/test_sched.py')
-rw-r--r-- | Lib/test/test_sched.py | 37 |
1 files changed, 36 insertions, 1 deletions
diff --git a/Lib/test/test_sched.py b/Lib/test/test_sched.py index 50ada52..d0112e4 100644 --- a/Lib/test/test_sched.py +++ b/Lib/test/test_sched.py @@ -4,7 +4,10 @@ import sched import time import unittest from test import support - +try: + import threading +except ImportError: + threading = None class TestCase(unittest.TestCase): @@ -26,6 +29,20 @@ class TestCase(unittest.TestCase): scheduler.run() self.assertEqual(l, [0.01, 0.02, 0.03, 0.04, 0.05]) + @unittest.skipUnless(threading, 'Threading required for this test.') + def test_enter_concurrent(self): + l = [] + fun = lambda x: l.append(x) + scheduler = sched.scheduler(time.time, time.sleep) + scheduler.enter(0.03, 1, fun, (0.03,)) + t = threading.Thread(target=scheduler.run) + t.start() + for x in [0.05, 0.04, 0.02, 0.01]: + z = scheduler.enter(x, 1, fun, (x,)) + scheduler.run() + t.join() + self.assertEqual(l, [0.01, 0.02, 0.03, 0.04, 0.05]) + def test_priority(self): l = [] fun = lambda x: l.append(x) @@ -50,6 +67,24 @@ class TestCase(unittest.TestCase): scheduler.run() self.assertEqual(l, [0.02, 0.03, 0.04]) + @unittest.skipUnless(threading, 'Threading required for this test.') + def test_cancel_concurrent(self): + l = [] + fun = lambda x: l.append(x) + scheduler = sched.scheduler(time.time, time.sleep) + now = time.time() + event1 = scheduler.enterabs(now + 0.01, 1, fun, (0.01,)) + event2 = scheduler.enterabs(now + 0.02, 1, fun, (0.02,)) + event3 = scheduler.enterabs(now + 0.03, 1, fun, (0.03,)) + event4 = scheduler.enterabs(now + 0.04, 1, fun, (0.04,)) + event5 = scheduler.enterabs(now + 0.05, 1, fun, (0.05,)) + t = threading.Thread(target=scheduler.run) + t.start() + scheduler.cancel(event1) + scheduler.cancel(event5) + t.join() + self.assertEqual(l, [0.02, 0.03, 0.04]) + def test_empty(self): l = [] fun = lambda x: l.append(x) |