mirror of
https://github.com/golang/go
synced 2024-11-20 04:04:41 -07:00
net: do not test TestReadWriteDeadline timeout upper bound during short test
It also increases timeout deltas to allow for longer wait. Also disables this test on plan9. R=golang-dev, minux.ma CC=golang-dev https://golang.org/cl/6821062
This commit is contained in:
parent
20548b153f
commit
a906f9aa86
@ -24,6 +24,8 @@ func probeIPv6Stack() (supportsIPv6, supportsIPv4map bool) {
|
|||||||
return false, false
|
return false, false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var canCancelIO = true // used for testing current package
|
||||||
|
|
||||||
// parsePlan9Addr parses address of the form [ip!]port (e.g. 127.0.0.1!80).
|
// parsePlan9Addr parses address of the form [ip!]port (e.g. 127.0.0.1!80).
|
||||||
func parsePlan9Addr(s string) (ip IP, iport int, err error) {
|
func parsePlan9Addr(s string) (ip IP, iport int, err error) {
|
||||||
addr := IPv4zero // address contains port only
|
addr := IPv4zero // address contains port only
|
||||||
|
@ -148,19 +148,24 @@ func TestTimeoutAccept(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestReadWriteDeadline(t *testing.T) {
|
func TestReadWriteDeadline(t *testing.T) {
|
||||||
|
switch runtime.GOOS {
|
||||||
|
case "plan9":
|
||||||
|
t.Logf("skipping test on %q", runtime.GOOS)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
if !canCancelIO {
|
if !canCancelIO {
|
||||||
t.Logf("skipping test on this system")
|
t.Logf("skipping test on this system")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
const (
|
const (
|
||||||
readTimeout = 100 * time.Millisecond
|
readTimeout = 50 * time.Millisecond
|
||||||
writeTimeout = 200 * time.Millisecond
|
writeTimeout = 250 * time.Millisecond
|
||||||
delta = 40 * time.Millisecond
|
|
||||||
)
|
)
|
||||||
checkTimeout := func(command string, start time.Time, should time.Duration) {
|
checkTimeout := func(command string, start time.Time, should time.Duration) {
|
||||||
is := time.Now().Sub(start)
|
is := time.Now().Sub(start)
|
||||||
d := should - is
|
d := should - is
|
||||||
if d < -delta || delta < d {
|
if d < -30*time.Millisecond || !testing.Short() && 150*time.Millisecond < d {
|
||||||
t.Errorf("%s timeout test failed: is=%v should=%v\n", command, is, should)
|
t.Errorf("%s timeout test failed: is=%v should=%v\n", command, is, should)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user