mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-03 20:27:35 +03:00
http3: unify handling of request and response headers (#3969)
This commit is contained in:
parent
ad16aa765d
commit
bb296b8c17
4 changed files with 92 additions and 52 deletions
|
@ -637,18 +637,6 @@ var _ = Describe("Client", func() {
|
|||
)
|
||||
testDone := make(chan struct{})
|
||||
|
||||
getHeadersFrame := func(headers map[string]string) []byte {
|
||||
headerBuf := &bytes.Buffer{}
|
||||
enc := qpack.NewEncoder(headerBuf)
|
||||
for name, value := range headers {
|
||||
Expect(enc.WriteField(qpack.HeaderField{Name: name, Value: value})).To(Succeed())
|
||||
}
|
||||
Expect(enc.Close()).To(Succeed())
|
||||
b := (&headersFrame{Length: uint64(headerBuf.Len())}).Append(nil)
|
||||
b = append(b, headerBuf.Bytes()...)
|
||||
return b
|
||||
}
|
||||
|
||||
decodeHeader := func(str io.Reader) map[string]string {
|
||||
fields := make(map[string]string)
|
||||
decoder := qpack.NewDecoder(nil)
|
||||
|
@ -849,26 +837,6 @@ var _ = Describe("Client", func() {
|
|||
Eventually(closed).Should(BeClosed())
|
||||
})
|
||||
|
||||
It("sets the Content-Length", func() {
|
||||
done := make(chan struct{})
|
||||
b := getHeadersFrame(map[string]string{
|
||||
":status": "200",
|
||||
"Content-Length": "1337",
|
||||
})
|
||||
b = (&dataFrame{Length: 0x6}).Append(b)
|
||||
b = append(b, []byte("foobar")...)
|
||||
r := bytes.NewReader(b)
|
||||
str.EXPECT().Close().Do(func() { close(done) })
|
||||
conn.EXPECT().ConnectionState().Return(quic.ConnectionState{})
|
||||
str.EXPECT().CancelWrite(gomock.Any()).MaxTimes(1) // when reading the response errors
|
||||
// the response body is sent asynchronously, while already reading the response
|
||||
str.EXPECT().Read(gomock.Any()).DoAndReturn(r.Read).AnyTimes()
|
||||
req, err := cl.RoundTripOpt(req, RoundTripOpt{})
|
||||
Expect(err).ToNot(HaveOccurred())
|
||||
Expect(req.ContentLength).To(BeEquivalentTo(1337))
|
||||
Eventually(done).Should(BeClosed())
|
||||
})
|
||||
|
||||
It("closes the connection when the first frame is not a HEADERS frame", func() {
|
||||
b := (&dataFrame{Length: 0x42}).Append(nil)
|
||||
conn.EXPECT().CloseWithError(quic.ApplicationErrorCode(ErrCodeFrameUnexpected), gomock.Any())
|
||||
|
@ -881,6 +849,24 @@ var _ = Describe("Client", func() {
|
|||
Eventually(closed).Should(BeClosed())
|
||||
})
|
||||
|
||||
It("cancels the stream when parsing the headers fails", func() {
|
||||
headerBuf := &bytes.Buffer{}
|
||||
enc := qpack.NewEncoder(headerBuf)
|
||||
Expect(enc.WriteField(qpack.HeaderField{Name: ":method", Value: "GET"})).To(Succeed()) // not a valid response pseudo header
|
||||
Expect(enc.Close()).To(Succeed())
|
||||
b := (&headersFrame{Length: uint64(headerBuf.Len())}).Append(nil)
|
||||
b = append(b, headerBuf.Bytes()...)
|
||||
|
||||
r := bytes.NewReader(b)
|
||||
str.EXPECT().CancelWrite(quic.StreamErrorCode(ErrCodeMessageError))
|
||||
closed := make(chan struct{})
|
||||
str.EXPECT().Close().Do(func() { close(closed) })
|
||||
str.EXPECT().Read(gomock.Any()).DoAndReturn(r.Read).AnyTimes()
|
||||
_, err := cl.RoundTripOpt(req, RoundTripOpt{})
|
||||
Expect(err).To(HaveOccurred())
|
||||
Eventually(closed).Should(BeClosed())
|
||||
})
|
||||
|
||||
It("cancels the stream when the HEADERS frame is too large", func() {
|
||||
b := (&headersFrame{Length: 1338}).Append(nil)
|
||||
r := bytes.NewReader(b)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue