summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_sched.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2012-12-29 19:34:11 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2012-12-29 19:34:11 (GMT)
commitf2b9cf4e612551eec954ee42e4ae3f0dfde3fd03 (patch)
tree37683aa6a808b44e67fee5e41a08b056eac8b15c /Lib/test/test_sched.py
parentc04957bff3a53ba3d051b7c4148a48ec5238f3cb (diff)
downloadcpython-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.py37
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)