Fix flickering test TestBufferNonBlockingRead
This commit is contained in:
@@ -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)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user