mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-03 20:27:35 +03:00
enforce that a conn ID is not retired in a packet that uses that conn ID
This commit is contained in:
parent
5227fef1a3
commit
25db2166dd
4 changed files with 37 additions and 24 deletions
|
@ -1,6 +1,8 @@
|
|||
package quic
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
"github.com/lucas-clemente/quic-go/internal/protocol"
|
||||
"github.com/lucas-clemente/quic-go/internal/wire"
|
||||
|
||||
|
@ -68,14 +70,22 @@ var _ = Describe("Connection ID Generator", func() {
|
|||
})
|
||||
|
||||
It("errors if the peers tries to retire a connection ID that wasn't yet issued", func() {
|
||||
Expect(g.Retire(1)).To(MatchError("PROTOCOL_VIOLATION: tried to retire connection ID 1. Highest issued: 0"))
|
||||
Expect(g.Retire(1, protocol.ConnectionID{})).To(MatchError("PROTOCOL_VIOLATION: tried to retire connection ID 1. Highest issued: 0"))
|
||||
})
|
||||
|
||||
It("errors if the peers tries to retire a connection ID in a packet with that connection ID", func() {
|
||||
Expect(g.SetMaxActiveConnIDs(4)).To(Succeed())
|
||||
Expect(queuedFrames).ToNot(BeEmpty())
|
||||
Expect(queuedFrames[0]).To(BeAssignableToTypeOf(&wire.NewConnectionIDFrame{}))
|
||||
f := queuedFrames[0].(*wire.NewConnectionIDFrame)
|
||||
Expect(g.Retire(f.SequenceNumber, f.ConnectionID)).To(MatchError(fmt.Sprintf("FRAME_ENCODING_ERROR: tried to retire connection ID %d (%s), which was used as the Destination Connection ID on this packet", f.SequenceNumber, f.ConnectionID)))
|
||||
})
|
||||
|
||||
It("issues new connection IDs, when old ones are retired", func() {
|
||||
Expect(g.SetMaxActiveConnIDs(5)).To(Succeed())
|
||||
queuedFrames = nil
|
||||
Expect(retiredConnIDs).To(BeEmpty())
|
||||
Expect(g.Retire(3)).To(Succeed())
|
||||
Expect(g.Retire(3, protocol.ConnectionID{})).To(Succeed())
|
||||
Expect(queuedFrames).To(HaveLen(1))
|
||||
Expect(queuedFrames[0]).To(BeAssignableToTypeOf(&wire.NewConnectionIDFrame{}))
|
||||
nf := queuedFrames[0].(*wire.NewConnectionIDFrame)
|
||||
|
@ -84,7 +94,7 @@ var _ = Describe("Connection ID Generator", func() {
|
|||
})
|
||||
|
||||
It("retires the initial connection ID", func() {
|
||||
Expect(g.Retire(0)).To(Succeed())
|
||||
Expect(g.Retire(0, protocol.ConnectionID{})).To(Succeed())
|
||||
Expect(removedConnIDs).To(BeEmpty())
|
||||
Expect(retiredConnIDs).To(HaveLen(1))
|
||||
Expect(retiredConnIDs[0]).To(Equal(initialConnID))
|
||||
|
@ -95,10 +105,10 @@ var _ = Describe("Connection ID Generator", func() {
|
|||
Expect(g.SetMaxActiveConnIDs(11)).To(Succeed())
|
||||
queuedFrames = nil
|
||||
Expect(retiredConnIDs).To(BeEmpty())
|
||||
Expect(g.Retire(5)).To(Succeed())
|
||||
Expect(g.Retire(5, protocol.ConnectionID{})).To(Succeed())
|
||||
Expect(retiredConnIDs).To(HaveLen(1))
|
||||
Expect(queuedFrames).To(HaveLen(1))
|
||||
Expect(g.Retire(5)).To(Succeed())
|
||||
Expect(g.Retire(5, protocol.ConnectionID{})).To(Succeed())
|
||||
Expect(retiredConnIDs).To(HaveLen(1))
|
||||
Expect(queuedFrames).To(HaveLen(1))
|
||||
})
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue