changeset: 88592:033137c12d88 branch: 3.3 parent: 88589:9fda6658c01a user: Victor Stinner date: Tue Jan 21 01:41:00 2014 +0100 files: Lib/test/test_epoll.py Misc/NEWS Modules/selectmodule.c description: Issue #20311: select.epoll.poll() now rounds the timeout away from zero, instead of rounding towards zero. For example, a timeout of one microsecond is now rounded to one millisecond, instead of being rounded to zero. diff -r 9fda6658c01a -r 033137c12d88 Lib/test/test_epoll.py --- a/Lib/test/test_epoll.py Mon Jan 20 21:57:40 2014 +0200 +++ b/Lib/test/test_epoll.py Tue Jan 21 01:41:00 2014 +0100 @@ -46,6 +46,17 @@ self.serverSocket.listen(1) self.connections = [self.serverSocket] + def test_timeout_rounding(self): + # epoll_wait() has a resolution of 1 millisecond, check if the timeout + # is correctly rounded to the upper bound + epoll = select.epoll() + self.addCleanup(epoll.close) + for timeout in (1e-2, 1e-3, 1e-4): + t0 = time.perf_counter() + epoll.poll(timeout) + dt = time.perf_counter() - t0 + self.assertGreaterEqual(dt, timeout) + def tearDown(self): for skt in self.connections: diff -r 9fda6658c01a -r 033137c12d88 Misc/NEWS --- a/Misc/NEWS Mon Jan 20 21:57:40 2014 +0200 +++ b/Misc/NEWS Tue Jan 21 01:41:00 2014 +0100 @@ -43,6 +43,10 @@ Library ------- +- Issue #20311: select.epoll.poll() now rounds the timeout away from zero, + instead of rounding towards zero. For example, a timeout of one microsecond + is now rounded to one millisecond, instead of being rounded to zero. + - Issue #20262: Warnings are raised now when duplicate names are added in the ZIP file or too long ZIP file comment is truncated. diff -r 9fda6658c01a -r 033137c12d88 Modules/selectmodule.c --- a/Modules/selectmodule.c Mon Jan 20 21:57:40 2014 +0200 +++ b/Modules/selectmodule.c Tue Jan 21 01:41:00 2014 +0100 @@ -1379,7 +1379,9 @@ return NULL; } else { - timeout = (int)(dtimeout * 1000.0); + /* epoll_wait() has a resolution of 1 millisecond, round away from zero + to wait *at least* dtimeout seconds. */ + timeout = (int)ceil(dtimeout * 1000.0); } if (maxevents == -1) {