mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-05 21:27:35 +03:00
Implement loss recovery from the current WG draft
Fixes #498 and will hopefully go a long way towards fixing the many flaky tests.
This commit is contained in:
parent
959a8d0e4f
commit
1c5380c49b
9 changed files with 376 additions and 434 deletions
|
@ -62,7 +62,6 @@ type mockSentPacketHandler struct {
|
|||
retransmissionQueue []*ackhandler.Packet
|
||||
sentPackets []*ackhandler.Packet
|
||||
congestionLimited bool
|
||||
maybeQueueRTOsCalled bool
|
||||
requestedStopWaiting bool
|
||||
}
|
||||
|
||||
|
@ -70,22 +69,22 @@ func (h *mockSentPacketHandler) SentPacket(packet *ackhandler.Packet) error {
|
|||
h.sentPackets = append(h.sentPackets, packet)
|
||||
return nil
|
||||
}
|
||||
|
||||
func (h *mockSentPacketHandler) ReceivedAck(ackFrame *frames.AckFrame, withPacketNumber protocol.PacketNumber, recvTime time.Time) error {
|
||||
return nil
|
||||
}
|
||||
func (h *mockSentPacketHandler) BytesInFlight() protocol.ByteCount { return 0 }
|
||||
|
||||
func (h *mockSentPacketHandler) GetLeastUnacked() protocol.PacketNumber { return 1 }
|
||||
func (h *mockSentPacketHandler) CheckForError() error { return nil }
|
||||
|
||||
func (h *mockSentPacketHandler) GetAlarmTimeout() time.Time { panic("not implemented") }
|
||||
func (h *mockSentPacketHandler) OnAlarm() { panic("not implemented") }
|
||||
func (h *mockSentPacketHandler) SendingAllowed() bool { return !h.congestionLimited }
|
||||
|
||||
func (h *mockSentPacketHandler) GetStopWaitingFrame(force bool) *frames.StopWaitingFrame {
|
||||
h.requestedStopWaiting = true
|
||||
return &frames.StopWaitingFrame{LeastUnacked: 0x1337}
|
||||
}
|
||||
func (h *mockSentPacketHandler) SendingAllowed() bool { return !h.congestionLimited }
|
||||
func (h *mockSentPacketHandler) CheckForError() error { return nil }
|
||||
func (h *mockSentPacketHandler) TimeOfFirstRTO() time.Time { panic("not implemented") }
|
||||
|
||||
func (h *mockSentPacketHandler) MaybeQueueRTOs() {
|
||||
h.maybeQueueRTOsCalled = true
|
||||
}
|
||||
|
||||
func (h *mockSentPacketHandler) DequeuePacketForRetransmission() *ackhandler.Packet {
|
||||
if len(h.retransmissionQueue) > 0 {
|
||||
|
@ -433,6 +432,7 @@ var _ = Describe("Session", func() {
|
|||
|
||||
It("doesn't queue a RST_STREAM for a stream that it already sent a FIN on", func() {
|
||||
str, err := sess.GetOrOpenStream(5)
|
||||
Expect(err).NotTo(HaveOccurred())
|
||||
str.(*stream).sentFin()
|
||||
str.Close()
|
||||
err = sess.handleRstStreamFrame(&frames.RstStreamFrame{
|
||||
|
@ -973,14 +973,6 @@ var _ = Describe("Session", func() {
|
|||
Expect(ok).To(BeTrue())
|
||||
})
|
||||
|
||||
It("calls MaybeQueueRTOs even if congestion blocked, so that bytesInFlight is updated", func() {
|
||||
sph.congestionLimited = true
|
||||
sess.sentPacketHandler = sph
|
||||
err := sess.sendPacket()
|
||||
Expect(err).NotTo(HaveOccurred())
|
||||
Expect(sph.maybeQueueRTOsCalled).To(BeTrue())
|
||||
})
|
||||
|
||||
It("retransmits a WindowUpdates if it hasn't already sent a WindowUpdate with a higher ByteOffset", func() {
|
||||
_, err := sess.GetOrOpenStream(5)
|
||||
Expect(err).ToNot(HaveOccurred())
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue