2
0

Fix flickering test TestBufferNonBlockingRead

This commit is contained in:
Jack Christensen
2023-02-10 19:40:09 -06:00
parent 255f16b00f
commit b707faea8f
+19 -9
View File
@@ -2,7 +2,6 @@ package nbconn_test
import ( import (
"crypto/tls" "crypto/tls"
"errors"
"io" "io"
"net" "net"
"strings" "strings"
@@ -10,6 +9,7 @@ import (
"time" "time"
"github.com/jackc/pgx/v5/internal/nbconn" "github.com/jackc/pgx/v5/internal/nbconn"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
) )
@@ -354,24 +354,34 @@ func TestBufferNonBlockingRead(t *testing.T) {
errChan := make(chan error, 1) errChan := make(chan error, 1)
go func() { go func() {
_, err := remote.Write([]byte("okay")) err := remote.SetWriteDeadline(time.Now().Add(5 * time.Second))
if err != nil {
errChan <- err
return
}
_, err = remote.Write([]byte("okay"))
errChan <- err errChan <- err
}() }()
readLoop:
for i := 0; i < 1000; i++ { for i := 0; i < 1000; i++ {
err = conn.BufferReadUntilBlock() err := conn.BufferReadUntilBlock()
if !errors.Is(err, nbconn.ErrWouldBlock) { require.NoError(t, err)
break select {
case err := <-errChan:
require.NoError(t, err)
break readLoop
default:
time.Sleep(time.Millisecond)
} }
time.Sleep(time.Millisecond)
} }
require.NoError(t, err)
buf := make([]byte, 4) buf := make([]byte, 4)
n, err := conn.Read(buf) n, err := conn.Read(buf)
require.NoError(t, err) require.NoError(t, err)
require.EqualValues(t, 4, n) assert.EqualValues(t, 4, n)
require.Equal(t, []byte("okay"), buf) assert.Equal(t, []byte("okay"), buf)
}) })
} }