integration: Add http3 via tests
This commit is contained in:
parent
126b5f9d2b
commit
20d95edc57
|
@ -1,4 +1,5 @@
|
||||||
//go:build quic
|
//go:build quic
|
||||||
|
|
||||||
package nghttp2
|
package nghttp2
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
@ -7,6 +8,8 @@ import (
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"golang.org/x/net/http2/hpack"
|
||||||
)
|
)
|
||||||
|
|
||||||
// TestH3H1PlainGET tests whether simple HTTP/3 GET request works.
|
// TestH3H1PlainGET tests whether simple HTTP/3 GET request works.
|
||||||
|
@ -84,3 +87,87 @@ func TestH3H1RequestBody(t *testing.T) {
|
||||||
t.Errorf("res.status: %v; want %v", got, want)
|
t.Errorf("res.status: %v; want %v", got, want)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TestH3H1GenerateVia tests that server generates Via header field to
|
||||||
|
// and from backend server.
|
||||||
|
func TestH3H1GenerateVia(t *testing.T) {
|
||||||
|
opts := options{
|
||||||
|
handler: func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
if got, want := r.Header.Get("Via"), "3 nghttpx"; got != want {
|
||||||
|
t.Errorf("Via: %v; want %v", got, want)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
quic: true,
|
||||||
|
}
|
||||||
|
st := newServerTester(t, opts)
|
||||||
|
defer st.Close()
|
||||||
|
|
||||||
|
res, err := st.http3(requestParam{
|
||||||
|
name: "TestH3H1GenerateVia",
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error st.http3() = %v", err)
|
||||||
|
}
|
||||||
|
if got, want := res.header.Get("Via"), "1.1 nghttpx"; got != want {
|
||||||
|
t.Errorf("Via: %v; want %v", got, want)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// TestH3H1AppendVia tests that server adds value to existing Via
|
||||||
|
// header field to and from backend server.
|
||||||
|
func TestH3H1AppendVia(t *testing.T) {
|
||||||
|
opts := options{
|
||||||
|
handler: func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
if got, want := r.Header.Get("Via"), "foo, 3 nghttpx"; got != want {
|
||||||
|
t.Errorf("Via: %v; want %v", got, want)
|
||||||
|
}
|
||||||
|
w.Header().Add("Via", "bar")
|
||||||
|
},
|
||||||
|
quic: true,
|
||||||
|
}
|
||||||
|
st := newServerTester(t, opts)
|
||||||
|
defer st.Close()
|
||||||
|
|
||||||
|
res, err := st.http3(requestParam{
|
||||||
|
name: "TestH3H1AppendVia",
|
||||||
|
header: []hpack.HeaderField{
|
||||||
|
pair("via", "foo"),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error st.http3() = %v", err)
|
||||||
|
}
|
||||||
|
if got, want := res.header.Get("Via"), "bar, 1.1 nghttpx"; got != want {
|
||||||
|
t.Errorf("Via: %v; want %v", got, want)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// TestH3H1NoVia tests that server does not add value to existing Via
|
||||||
|
// header field to and from backend server.
|
||||||
|
func TestH3H1NoVia(t *testing.T) {
|
||||||
|
opts := options{
|
||||||
|
args: []string{"--no-via"},
|
||||||
|
handler: func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
if got, want := r.Header.Get("Via"), "foo"; got != want {
|
||||||
|
t.Errorf("Via: %v; want %v", got, want)
|
||||||
|
}
|
||||||
|
w.Header().Add("Via", "bar")
|
||||||
|
},
|
||||||
|
quic: true,
|
||||||
|
}
|
||||||
|
st := newServerTester(t, opts)
|
||||||
|
defer st.Close()
|
||||||
|
|
||||||
|
res, err := st.http3(requestParam{
|
||||||
|
name: "TestH3H1NoVia",
|
||||||
|
header: []hpack.HeaderField{
|
||||||
|
pair("via", "foo"),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error st.http3() = %v", err)
|
||||||
|
}
|
||||||
|
if got, want := res.header.Get("Via"), "bar"; got != want {
|
||||||
|
t.Errorf("Via: %v; want %v", got, want)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue