Mitigate TestShutdownUDPConn flakyness
This commit is contained in:
parent
822f349fa1
commit
0880cc672f
1 changed files with 6 additions and 0 deletions
|
|
@ -53,12 +53,18 @@ func TestShutdownUDPConn(t *testing.T) {
|
||||||
// Start sending packets, to create a "session" with the server.
|
// Start sending packets, to create a "session" with the server.
|
||||||
requireEcho(t, "TEST", conn, time.Second)
|
requireEcho(t, "TEST", conn, time.Second)
|
||||||
|
|
||||||
|
shutdownStartedChan := make(chan struct{})
|
||||||
doneChan := make(chan struct{})
|
doneChan := make(chan struct{})
|
||||||
go func() {
|
go func() {
|
||||||
|
close(shutdownStartedChan)
|
||||||
entryPoint.Shutdown(t.Context())
|
entryPoint.Shutdown(t.Context())
|
||||||
close(doneChan)
|
close(doneChan)
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
// Wait until shutdown has started, and hopefully after 100 ms the listener has stopped accepting new sessions.
|
||||||
|
<-shutdownStartedChan
|
||||||
|
time.Sleep(100 * time.Millisecond)
|
||||||
|
|
||||||
// Make sure that our session is still live even after the shutdown.
|
// Make sure that our session is still live even after the shutdown.
|
||||||
requireEcho(t, "TEST2", conn, time.Second)
|
requireEcho(t, "TEST2", conn, time.Second)
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue