mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 04:37:36 +03:00
fix race conditions when setting read and write deadlines
This commit is contained in:
parent
516b427d46
commit
0be8e033ab
4 changed files with 98 additions and 52 deletions
|
@ -360,6 +360,34 @@ var _ = Describe("Send Stream", func() {
|
|||
Expect(time.Now()).To(BeTemporally("~", deadline2, scaleDuration(20*time.Millisecond)))
|
||||
Eventually(done).Should(BeClosed())
|
||||
})
|
||||
|
||||
It("doesn't unblock if the deadline is removed", func() {
|
||||
mockSender.EXPECT().onHasStreamData(streamID)
|
||||
deadline := time.Now().Add(scaleDuration(50 * time.Millisecond))
|
||||
str.SetWriteDeadline(deadline)
|
||||
deadlineUnset := make(chan struct{})
|
||||
go func() {
|
||||
defer GinkgoRecover()
|
||||
time.Sleep(scaleDuration(20 * time.Millisecond))
|
||||
str.SetWriteDeadline(time.Time{})
|
||||
// make sure that this was actually execute before the deadline expires
|
||||
Expect(time.Now()).To(BeTemporally("<", deadline))
|
||||
close(deadlineUnset)
|
||||
}()
|
||||
done := make(chan struct{})
|
||||
go func() {
|
||||
defer GinkgoRecover()
|
||||
_, err := strWithTimeout.Write([]byte("foobar"))
|
||||
Expect(err).To(MatchError("test done"))
|
||||
close(done)
|
||||
}()
|
||||
runtime.Gosched()
|
||||
Eventually(deadlineUnset).Should(BeClosed())
|
||||
Consistently(done, scaleDuration(100*time.Millisecond)).ShouldNot(BeClosed())
|
||||
// make the go routine return
|
||||
str.closeForShutdown(errors.New("test done"))
|
||||
Eventually(done).Should(BeClosed())
|
||||
})
|
||||
})
|
||||
|
||||
Context("closing", func() {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue