forked from quic-go/quic-go
fix encoding of the error code in the STOP_SENDING frame
This commit is contained in:
@@ -23,7 +23,7 @@ func parseStopSendingFrame(r *bytes.Reader, _ protocol.VersionNumber) (*StopSend
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
errorCode, err := utils.BigEndian.ReadUint16(r)
|
errorCode, err := utils.ReadVarInt(r)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@@ -36,12 +36,12 @@ func parseStopSendingFrame(r *bytes.Reader, _ protocol.VersionNumber) (*StopSend
|
|||||||
|
|
||||||
// Length of a written frame
|
// Length of a written frame
|
||||||
func (f *StopSendingFrame) Length(_ protocol.VersionNumber) protocol.ByteCount {
|
func (f *StopSendingFrame) Length(_ protocol.VersionNumber) protocol.ByteCount {
|
||||||
return 1 + utils.VarIntLen(uint64(f.StreamID)) + 2
|
return 1 + utils.VarIntLen(uint64(f.StreamID)) + utils.VarIntLen(uint64(f.ErrorCode))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (f *StopSendingFrame) Write(b *bytes.Buffer, _ protocol.VersionNumber) error {
|
func (f *StopSendingFrame) Write(b *bytes.Buffer, _ protocol.VersionNumber) error {
|
||||||
b.WriteByte(0x5)
|
b.WriteByte(0x5)
|
||||||
utils.WriteVarInt(b, uint64(f.StreamID))
|
utils.WriteVarInt(b, uint64(f.StreamID))
|
||||||
utils.BigEndian.WriteUint16(b, uint16(f.ErrorCode))
|
utils.WriteVarInt(b, uint64(f.ErrorCode))
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ var _ = Describe("STOP_SENDING frame", func() {
|
|||||||
It("parses a sample frame", func() {
|
It("parses a sample frame", func() {
|
||||||
data := []byte{0x5}
|
data := []byte{0x5}
|
||||||
data = append(data, encodeVarInt(0xdecafbad)...) // stream ID
|
data = append(data, encodeVarInt(0xdecafbad)...) // stream ID
|
||||||
data = append(data, []byte{0x13, 0x37}...) // error code
|
data = append(data, encodeVarInt(0x1337)...) // error code
|
||||||
b := bytes.NewReader(data)
|
b := bytes.NewReader(data)
|
||||||
frame, err := parseStopSendingFrame(b, versionIETFFrames)
|
frame, err := parseStopSendingFrame(b, versionIETFFrames)
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
@@ -27,7 +27,7 @@ var _ = Describe("STOP_SENDING frame", func() {
|
|||||||
It("errors on EOFs", func() {
|
It("errors on EOFs", func() {
|
||||||
data := []byte{0x5}
|
data := []byte{0x5}
|
||||||
data = append(data, encodeVarInt(0xdecafbad)...) // stream ID
|
data = append(data, encodeVarInt(0xdecafbad)...) // stream ID
|
||||||
data = append(data, []byte{0x13, 0x37}...) // error code
|
data = append(data, encodeVarInt(0x123456)...) // error code
|
||||||
_, err := parseStopSendingFrame(bytes.NewReader(data), versionIETFFrames)
|
_, err := parseStopSendingFrame(bytes.NewReader(data), versionIETFFrames)
|
||||||
Expect(err).NotTo(HaveOccurred())
|
Expect(err).NotTo(HaveOccurred())
|
||||||
for i := range data {
|
for i := range data {
|
||||||
@@ -41,23 +41,22 @@ var _ = Describe("STOP_SENDING frame", func() {
|
|||||||
It("writes", func() {
|
It("writes", func() {
|
||||||
frame := &StopSendingFrame{
|
frame := &StopSendingFrame{
|
||||||
StreamID: 0xdeadbeefcafe,
|
StreamID: 0xdeadbeefcafe,
|
||||||
ErrorCode: 0x10,
|
ErrorCode: 0xdecafbad,
|
||||||
}
|
}
|
||||||
buf := &bytes.Buffer{}
|
buf := &bytes.Buffer{}
|
||||||
err := frame.Write(buf, versionIETFFrames)
|
Expect(frame.Write(buf, versionIETFFrames)).To(Succeed())
|
||||||
Expect(err).ToNot(HaveOccurred())
|
|
||||||
expected := []byte{0x5}
|
expected := []byte{0x5}
|
||||||
expected = append(expected, encodeVarInt(0xdeadbeefcafe)...)
|
expected = append(expected, encodeVarInt(0xdeadbeefcafe)...)
|
||||||
expected = append(expected, []byte{0x0, 0x10}...)
|
expected = append(expected, encodeVarInt(0xdecafbad)...)
|
||||||
Expect(buf.Bytes()).To(Equal(expected))
|
Expect(buf.Bytes()).To(Equal(expected))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("has the correct min length", func() {
|
It("has the correct min length", func() {
|
||||||
frame := &StopSendingFrame{
|
frame := &StopSendingFrame{
|
||||||
StreamID: 0xdeadbeef,
|
StreamID: 0xdeadbeef,
|
||||||
ErrorCode: 0x10,
|
ErrorCode: 0x1234567,
|
||||||
}
|
}
|
||||||
Expect(frame.Length(versionIETFFrames)).To(Equal(1 + 2 + utils.VarIntLen(0xdeadbeef)))
|
Expect(frame.Length(versionIETFFrames)).To(Equal(1 + utils.VarIntLen(0xdeadbeef) + utils.VarIntLen(0x1234567)))
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user