Commit 9194421e authored by Mikio Hara's avatar Mikio Hara

net: deflake TestDialerDualStackFDLeak

We need to stop the mock listener certainly for preventing it from
pulling up pending connections during measurement.

Fixes #14223.

Change-Id: Ia40db01d1262963697b83ca867563dec77d772e3
Reviewed-on: https://go-review.googlesource.com/19246
Run-TryBot: Mikio Hara <mikioh.mikioh@gmail.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent e6d6ad47
...@@ -176,6 +176,7 @@ func TestDialerDualStackFDLeak(t *testing.T) { ...@@ -176,6 +176,7 @@ func TestDialerDualStackFDLeak(t *testing.T) {
t.Skip("both IPv4 and IPv6 are required") t.Skip("both IPv4 and IPv6 are required")
} }
before := sw.Sockets()
origTestHookLookupIP := testHookLookupIP origTestHookLookupIP := testHookLookupIP
defer func() { testHookLookupIP = origTestHookLookupIP }() defer func() { testHookLookupIP = origTestHookLookupIP }()
testHookLookupIP = lookupLocalhost testHookLookupIP = lookupLocalhost
...@@ -195,17 +196,15 @@ func TestDialerDualStackFDLeak(t *testing.T) { ...@@ -195,17 +196,15 @@ func TestDialerDualStackFDLeak(t *testing.T) {
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
} }
defer dss.teardown()
if err := dss.buildup(handler); err != nil { if err := dss.buildup(handler); err != nil {
dss.teardown()
t.Fatal(err) t.Fatal(err)
} }
before := sw.Sockets()
const T = 100 * time.Millisecond
const N = 10 const N = 10
var wg sync.WaitGroup var wg sync.WaitGroup
wg.Add(N) wg.Add(N)
d := &Dialer{DualStack: true, Timeout: T} d := &Dialer{DualStack: true, Timeout: 100 * time.Millisecond}
for i := 0; i < N; i++ { for i := 0; i < N; i++ {
go func() { go func() {
defer wg.Done() defer wg.Done()
...@@ -218,7 +217,7 @@ func TestDialerDualStackFDLeak(t *testing.T) { ...@@ -218,7 +217,7 @@ func TestDialerDualStackFDLeak(t *testing.T) {
}() }()
} }
wg.Wait() wg.Wait()
time.Sleep(2 * T) // wait for the dial racers to stop dss.teardown()
after := sw.Sockets() after := sw.Sockets()
if len(after) != len(before) { if len(after) != len(before) {
t.Errorf("got %d; want %d", len(after), len(before)) t.Errorf("got %d; want %d", len(after), len(before))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment