From d50a1877ee51a275a132c05d89bac12958811a5d Mon Sep 17 00:00:00 2001 From: "Andrew M. Kuchling" Date: Tue, 29 Aug 2000 16:53:34 +0000 Subject: [PATCH] Fix for two problems on FreeBSD: In test_poll1(), unregister file descriptors as they're closed, and also close the read end of the pipe In test_poll2(), make the code assume less about the combinations of flag bits that will be returned --- Lib/test/test_poll.py | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/Lib/test/test_poll.py b/Lib/test/test_poll.py index 543dc6bc48b..82d8372be2e 100644 --- a/Lib/test/test_poll.py +++ b/Lib/test/test_poll.py @@ -57,7 +57,9 @@ def test_poll1(): buf = os.read(rd, MSG_LEN) assert len(buf) == MSG_LEN print buf - os.close(r2w[rd]) + os.close(r2w[rd]) ; os.close( rd ) + p.unregister( r2w[rd] ) + p.unregister( rd ) writers.remove(r2w[rd]) poll_unit_tests() @@ -145,13 +147,14 @@ def test_poll2(): fdlist = pollster.poll(tout) if (fdlist == []): continue - if fdlist[0] == (p.fileno(),select.POLLHUP): + fd, flags = fdlist[0] + if flags & select.POLLHUP: line = p.readline() if line != "": print 'error: pipe seems to be closed, but still returns data' continue - elif fdlist[0] == (p.fileno(),select.POLLIN): + elif flags & select.POLLIN: line = p.readline() if verbose: print `line`