mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-03 20:27:35 +03:00
sync: quic-go 0.42.0
Signed-off-by: Gaukas Wang <i@gaukas.wang>
This commit is contained in:
parent
d40dde9b9b
commit
4973374ea5
252 changed files with 13121 additions and 5437 deletions
|
@ -2,7 +2,8 @@ package quic
|
|||
|
||||
import (
|
||||
"bytes"
|
||||
"math/rand"
|
||||
|
||||
"golang.org/x/exp/rand"
|
||||
|
||||
"github.com/refraction-networking/uquic/internal/ackhandler"
|
||||
"github.com/refraction-networking/uquic/internal/protocol"
|
||||
|
@ -23,7 +24,7 @@ var _ = Describe("Framer", func() {
|
|||
framer framer
|
||||
stream1, stream2 *MockSendStreamI
|
||||
streamGetter *MockStreamGetter
|
||||
version protocol.VersionNumber
|
||||
version protocol.Version
|
||||
)
|
||||
|
||||
BeforeEach(func() {
|
||||
|
@ -108,6 +109,72 @@ var _ = Describe("Framer", func() {
|
|||
Expect(fs).To(HaveLen(2))
|
||||
Expect(length).To(Equal(ping.Length(version) + ncid.Length(version)))
|
||||
})
|
||||
|
||||
It("detects when too many frames are queued", func() {
|
||||
for i := 0; i < maxControlFrames-1; i++ {
|
||||
framer.QueueControlFrame(&wire.PingFrame{})
|
||||
framer.QueueControlFrame(&wire.PingFrame{})
|
||||
Expect(framer.QueuedTooManyControlFrames()).To(BeFalse())
|
||||
frames, _ := framer.AppendControlFrames([]ackhandler.Frame{}, 1, protocol.Version1)
|
||||
Expect(frames).To(HaveLen(1))
|
||||
Expect(framer.(*framerI).controlFrames).To(HaveLen(i + 1))
|
||||
}
|
||||
framer.QueueControlFrame(&wire.PingFrame{})
|
||||
Expect(framer.QueuedTooManyControlFrames()).To(BeFalse())
|
||||
Expect(framer.(*framerI).controlFrames).To(HaveLen(maxControlFrames))
|
||||
framer.QueueControlFrame(&wire.PingFrame{})
|
||||
Expect(framer.QueuedTooManyControlFrames()).To(BeTrue())
|
||||
Expect(framer.(*framerI).controlFrames).To(HaveLen(maxControlFrames))
|
||||
})
|
||||
})
|
||||
|
||||
Context("handling PATH_RESPONSE frames", func() {
|
||||
It("packs a single PATH_RESPONSE per packet", func() {
|
||||
f1 := &wire.PathResponseFrame{Data: [8]byte{1, 2, 3, 4, 5, 6, 7, 8}}
|
||||
f2 := &wire.PathResponseFrame{Data: [8]byte{2, 3, 4, 5, 6, 7, 8, 9}}
|
||||
cf1 := &wire.DataBlockedFrame{MaximumData: 1337}
|
||||
cf2 := &wire.HandshakeDoneFrame{}
|
||||
framer.QueueControlFrame(f1)
|
||||
framer.QueueControlFrame(f2)
|
||||
framer.QueueControlFrame(cf1)
|
||||
framer.QueueControlFrame(cf2)
|
||||
// the first packet should contain a single PATH_RESPONSE frame, but all the other control frames
|
||||
Expect(framer.HasData()).To(BeTrue())
|
||||
frames, length := framer.AppendControlFrames(nil, protocol.MaxByteCount, protocol.Version1)
|
||||
Expect(frames).To(HaveLen(3))
|
||||
Expect(frames[0].Frame).To(Equal(f1))
|
||||
Expect([]wire.Frame{frames[1].Frame, frames[2].Frame}).To(ContainElement(cf1))
|
||||
Expect([]wire.Frame{frames[1].Frame, frames[2].Frame}).To(ContainElement(cf2))
|
||||
Expect(length).To(Equal(f1.Length(protocol.Version1) + cf1.Length(protocol.Version1) + cf2.Length(protocol.Version1)))
|
||||
// the second packet should contain the other PATH_RESPONSE frame
|
||||
Expect(framer.HasData()).To(BeTrue())
|
||||
frames, length = framer.AppendControlFrames(nil, protocol.MaxByteCount, protocol.Version1)
|
||||
Expect(frames).To(HaveLen(1))
|
||||
Expect(frames[0].Frame).To(Equal(f2))
|
||||
Expect(length).To(Equal(f2.Length(protocol.Version1)))
|
||||
Expect(framer.HasData()).To(BeFalse())
|
||||
})
|
||||
|
||||
It("limits the number of queued PATH_RESPONSE frames", func() {
|
||||
var pathResponses []*wire.PathResponseFrame
|
||||
for i := 0; i < 2*maxPathResponses; i++ {
|
||||
var f wire.PathResponseFrame
|
||||
rand.Read(f.Data[:])
|
||||
pathResponses = append(pathResponses, &f)
|
||||
framer.QueueControlFrame(&f)
|
||||
}
|
||||
for i := 0; i < maxPathResponses; i++ {
|
||||
Expect(framer.HasData()).To(BeTrue())
|
||||
frames, length := framer.AppendControlFrames(nil, protocol.MaxByteCount, protocol.Version1)
|
||||
Expect(frames).To(HaveLen(1))
|
||||
Expect(frames[0].Frame).To(Equal(pathResponses[i]))
|
||||
Expect(length).To(Equal(pathResponses[i].Length(protocol.Version1)))
|
||||
}
|
||||
Expect(framer.HasData()).To(BeFalse())
|
||||
frames, length := framer.AppendControlFrames(nil, protocol.MaxByteCount, protocol.Version1)
|
||||
Expect(frames).To(BeEmpty())
|
||||
Expect(length).To(BeZero())
|
||||
})
|
||||
})
|
||||
|
||||
Context("popping STREAM frames", func() {
|
||||
|
@ -296,7 +363,7 @@ var _ = Describe("Framer", func() {
|
|||
It("pops maximum size STREAM frames", func() {
|
||||
for i := protocol.MinStreamFrameSize; i < 2000; i++ {
|
||||
streamGetter.EXPECT().GetOrOpenSendStream(id1).Return(stream1, nil)
|
||||
stream1.EXPECT().popStreamFrame(gomock.Any(), protocol.Version1).DoAndReturn(func(size protocol.ByteCount, v protocol.VersionNumber) (ackhandler.StreamFrame, bool, bool) {
|
||||
stream1.EXPECT().popStreamFrame(gomock.Any(), protocol.Version1).DoAndReturn(func(size protocol.ByteCount, v protocol.Version) (ackhandler.StreamFrame, bool, bool) {
|
||||
f := &wire.StreamFrame{
|
||||
StreamID: id1,
|
||||
DataLenPresent: true,
|
||||
|
@ -318,7 +385,7 @@ var _ = Describe("Framer", func() {
|
|||
for i := 2 * protocol.MinStreamFrameSize; i < 2000; i++ {
|
||||
streamGetter.EXPECT().GetOrOpenSendStream(id1).Return(stream1, nil)
|
||||
streamGetter.EXPECT().GetOrOpenSendStream(id2).Return(stream2, nil)
|
||||
stream1.EXPECT().popStreamFrame(gomock.Any(), protocol.Version1).DoAndReturn(func(size protocol.ByteCount, v protocol.VersionNumber) (ackhandler.StreamFrame, bool, bool) {
|
||||
stream1.EXPECT().popStreamFrame(gomock.Any(), protocol.Version1).DoAndReturn(func(size protocol.ByteCount, v protocol.Version) (ackhandler.StreamFrame, bool, bool) {
|
||||
f := &wire.StreamFrame{
|
||||
StreamID: id2,
|
||||
DataLenPresent: true,
|
||||
|
@ -326,7 +393,7 @@ var _ = Describe("Framer", func() {
|
|||
f.Data = make([]byte, f.MaxDataLen(protocol.MinStreamFrameSize, v))
|
||||
return ackhandler.StreamFrame{Frame: f}, true, false
|
||||
})
|
||||
stream2.EXPECT().popStreamFrame(gomock.Any(), protocol.Version1).DoAndReturn(func(size protocol.ByteCount, v protocol.VersionNumber) (ackhandler.StreamFrame, bool, bool) {
|
||||
stream2.EXPECT().popStreamFrame(gomock.Any(), protocol.Version1).DoAndReturn(func(size protocol.ByteCount, v protocol.Version) (ackhandler.StreamFrame, bool, bool) {
|
||||
f := &wire.StreamFrame{
|
||||
StreamID: id2,
|
||||
DataLenPresent: true,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue