mirror of
https://github.com/golang/sys.git
synced 2026-02-09 04:06:04 +03:00
unix: don't fail TestSelect on EINTR from Select
Change-Id: Ie162966c830ffd86947cf4f04532a7f6741a5587 Reviewed-on: https://go-review.googlesource.com/c/sys/+/207861 Run-TryBot: Tobias Klauser <tobias.klauser@gmail.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org>
This commit is contained in:
committed by
Tobias Klauser
parent
6bfc516c86
commit
76d669a226
@@ -513,24 +513,37 @@ func TestPoll(t *testing.T) {
|
||||
}
|
||||
|
||||
func TestSelect(t *testing.T) {
|
||||
n, err := unix.Select(0, nil, nil, nil, &unix.Timeval{Sec: 0, Usec: 0})
|
||||
if err != nil {
|
||||
t.Fatalf("Select: %v", err)
|
||||
}
|
||||
if n != 0 {
|
||||
t.Fatalf("Select: got %v ready file descriptors, expected 0", n)
|
||||
for {
|
||||
n, err := unix.Select(0, nil, nil, nil, &unix.Timeval{Sec: 0, Usec: 0})
|
||||
if err == unix.EINTR {
|
||||
t.Logf("Select interrupted")
|
||||
continue
|
||||
} else if err != nil {
|
||||
t.Fatalf("Select: %v", err)
|
||||
}
|
||||
if n != 0 {
|
||||
t.Fatalf("Select: got %v ready file descriptors, expected 0", n)
|
||||
}
|
||||
break
|
||||
}
|
||||
|
||||
dur := 250 * time.Millisecond
|
||||
tv := unix.NsecToTimeval(int64(dur))
|
||||
start := time.Now()
|
||||
n, err = unix.Select(0, nil, nil, nil, &tv)
|
||||
took := time.Since(start)
|
||||
if err != nil {
|
||||
t.Fatalf("Select: %v", err)
|
||||
}
|
||||
if n != 0 {
|
||||
t.Fatalf("Select: got %v ready file descriptors, expected 0", n)
|
||||
var took time.Duration
|
||||
for {
|
||||
start := time.Now()
|
||||
n, err := unix.Select(0, nil, nil, nil, &tv)
|
||||
took = time.Since(start)
|
||||
if err == unix.EINTR {
|
||||
t.Logf("Select interrupted after %v", took)
|
||||
continue
|
||||
} else if err != nil {
|
||||
t.Fatalf("Select: %v", err)
|
||||
}
|
||||
if n != 0 {
|
||||
t.Fatalf("Select: got %v ready file descriptors, expected 0", n)
|
||||
}
|
||||
break
|
||||
}
|
||||
|
||||
// On some BSDs the actual timeout might also be slightly less than the requested.
|
||||
@@ -554,12 +567,18 @@ func TestSelect(t *testing.T) {
|
||||
fd := int(rr.Fd())
|
||||
rFdSet.Set(fd)
|
||||
|
||||
n, err = unix.Select(fd+1, rFdSet, nil, nil, nil)
|
||||
if err != nil {
|
||||
t.Fatalf("Select: %v", err)
|
||||
}
|
||||
if n != 1 {
|
||||
t.Fatalf("Select: got %v ready file descriptors, expected 1", n)
|
||||
for {
|
||||
n, err := unix.Select(fd+1, rFdSet, nil, nil, nil)
|
||||
if err == unix.EINTR {
|
||||
t.Log("Select interrupted")
|
||||
continue
|
||||
} else if err != nil {
|
||||
t.Fatalf("Select: %v", err)
|
||||
}
|
||||
if n != 1 {
|
||||
t.Fatalf("Select: got %v ready file descriptors, expected 1", n)
|
||||
}
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user