mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
pkg/transport: fix a data race in TestReadWriteTimeoutDialer
Accessing test.T async will cause data race. Change to use select to coordinate the access of test.T.
This commit is contained in:
@@ -42,18 +42,22 @@ func TestReadWriteTimeoutDialer(t *testing.T) {
|
||||
|
||||
// fill the socket buffer
|
||||
data := make([]byte, 5*1024*1024)
|
||||
timer := time.AfterFunc(d.wtimeoutd*5, func() {
|
||||
t.Fatal("wait timeout")
|
||||
})
|
||||
defer timer.Stop()
|
||||
done := make(chan struct{})
|
||||
go func() {
|
||||
_, err = conn.Write(data)
|
||||
done <- struct{}{}
|
||||
}()
|
||||
|
||||
select {
|
||||
case <-done:
|
||||
case <-time.After(d.wtimeoutd * 5):
|
||||
t.Fatal("wait timeout")
|
||||
}
|
||||
|
||||
_, err = conn.Write(data)
|
||||
if operr, ok := err.(*net.OpError); !ok || operr.Op != "write" || !operr.Timeout() {
|
||||
t.Errorf("err = %v, want write i/o timeout error", err)
|
||||
}
|
||||
|
||||
timer.Reset(d.rdtimeoutd * 5)
|
||||
|
||||
conn, err = d.Dial("tcp", ln.Addr().String())
|
||||
if err != nil {
|
||||
t.Fatalf("unexpected dial error: %v", err)
|
||||
@@ -61,7 +65,17 @@ func TestReadWriteTimeoutDialer(t *testing.T) {
|
||||
defer conn.Close()
|
||||
|
||||
buf := make([]byte, 10)
|
||||
_, err = conn.Read(buf)
|
||||
go func() {
|
||||
_, err = conn.Read(buf)
|
||||
done <- struct{}{}
|
||||
}()
|
||||
|
||||
select {
|
||||
case <-done:
|
||||
case <-time.After(d.rdtimeoutd * 5):
|
||||
t.Fatal("wait timeout")
|
||||
}
|
||||
|
||||
if operr, ok := err.(*net.OpError); !ok || operr.Op != "read" || !operr.Timeout() {
|
||||
t.Errorf("err = %v, want write i/o timeout error", err)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user