mirror of
https://github.com/golang/go
synced 2024-11-23 12:00:14 -07:00
net/http: remove a stale cookie TODO comment, add a test
Fixes #4528 R=golang-dev, rsc CC=golang-dev https://golang.org/cl/6922054
This commit is contained in:
parent
a257c753ac
commit
be5ce4e027
@ -231,8 +231,6 @@ func (c *Client) Get(url string) (resp *Response, err error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *Client) doFollowingRedirects(ireq *Request, shouldRedirect func(int) bool) (resp *Response, err error) {
|
func (c *Client) doFollowingRedirects(ireq *Request, shouldRedirect func(int) bool) (resp *Response, err error) {
|
||||||
// TODO: if/when we add cookie support, the redirected request shouldn't
|
|
||||||
// necessarily supply the same cookies as the original.
|
|
||||||
var base *url.URL
|
var base *url.URL
|
||||||
redirectChecker := c.CheckRedirect
|
redirectChecker := c.CheckRedirect
|
||||||
if redirectChecker == nil {
|
if redirectChecker == nil {
|
||||||
|
@ -351,6 +351,9 @@ type TestJar struct {
|
|||||||
func (j *TestJar) SetCookies(u *url.URL, cookies []*Cookie) {
|
func (j *TestJar) SetCookies(u *url.URL, cookies []*Cookie) {
|
||||||
j.m.Lock()
|
j.m.Lock()
|
||||||
defer j.m.Unlock()
|
defer j.m.Unlock()
|
||||||
|
if j.perURL == nil {
|
||||||
|
j.perURL = make(map[string][]*Cookie)
|
||||||
|
}
|
||||||
j.perURL[u.Host] = cookies
|
j.perURL[u.Host] = cookies
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -381,8 +384,9 @@ func TestRedirectCookiesJar(t *testing.T) {
|
|||||||
var ts *httptest.Server
|
var ts *httptest.Server
|
||||||
ts = httptest.NewServer(echoCookiesRedirectHandler)
|
ts = httptest.NewServer(echoCookiesRedirectHandler)
|
||||||
defer ts.Close()
|
defer ts.Close()
|
||||||
c := &Client{}
|
c := &Client{
|
||||||
c.Jar = &TestJar{perURL: make(map[string][]*Cookie)}
|
Jar: new(TestJar),
|
||||||
|
}
|
||||||
u, _ := url.Parse(ts.URL)
|
u, _ := url.Parse(ts.URL)
|
||||||
c.Jar.SetCookies(u, []*Cookie{expectedCookies[0]})
|
c.Jar.SetCookies(u, []*Cookie{expectedCookies[0]})
|
||||||
resp, err := c.Get(ts.URL)
|
resp, err := c.Get(ts.URL)
|
||||||
@ -411,6 +415,61 @@ func matchReturnedCookies(t *testing.T, expected, given []*Cookie) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestJarCalls(t *testing.T) {
|
||||||
|
ts := httptest.NewServer(HandlerFunc(func(w ResponseWriter, r *Request) {
|
||||||
|
pathSuffix := r.RequestURI[1:]
|
||||||
|
SetCookie(w, &Cookie{Name: "name" + pathSuffix, Value: "val" + pathSuffix})
|
||||||
|
if r.RequestURI == "/" {
|
||||||
|
Redirect(w, r, "http://secondhost.fake/secondpath", 302)
|
||||||
|
}
|
||||||
|
}))
|
||||||
|
defer ts.Close()
|
||||||
|
jar := new(RecordingJar)
|
||||||
|
c := &Client{
|
||||||
|
Jar: jar,
|
||||||
|
Transport: &Transport{
|
||||||
|
Dial: func(_ string, _ string) (net.Conn, error) {
|
||||||
|
return net.Dial("tcp", ts.Listener.Addr().String())
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
_, err := c.Get("http://firsthost.fake/")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
got := jar.log.String()
|
||||||
|
want := `Cookies("http://firsthost.fake/")
|
||||||
|
SetCookie("http://firsthost.fake/", [name=val])
|
||||||
|
Cookies("http://secondhost.fake/secondpath")
|
||||||
|
SetCookie("http://secondhost.fake/secondpath", [namesecondpath=valsecondpath])
|
||||||
|
`
|
||||||
|
if got != want {
|
||||||
|
t.Errorf("Got Jar calls:\n%s\nWant:\n%s", got, want)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// RecordingJar keeps a log of calls made to it, without
|
||||||
|
// tracking any cookies.
|
||||||
|
type RecordingJar struct {
|
||||||
|
mu sync.Mutex
|
||||||
|
log bytes.Buffer
|
||||||
|
}
|
||||||
|
|
||||||
|
func (j *RecordingJar) SetCookies(u *url.URL, cookies []*Cookie) {
|
||||||
|
j.logf("SetCookie(%q, %v)\n", u, cookies)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (j *RecordingJar) Cookies(u *url.URL) []*Cookie {
|
||||||
|
j.logf("Cookies(%q)\n", u)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (j *RecordingJar) logf(format string, args ...interface{}) {
|
||||||
|
j.mu.Lock()
|
||||||
|
defer j.mu.Unlock()
|
||||||
|
fmt.Fprintf(&j.log, format, args...)
|
||||||
|
}
|
||||||
|
|
||||||
func TestStreamingGet(t *testing.T) {
|
func TestStreamingGet(t *testing.T) {
|
||||||
say := make(chan string)
|
say := make(chan string)
|
||||||
ts := httptest.NewServer(HandlerFunc(func(w ResponseWriter, r *Request) {
|
ts := httptest.NewServer(HandlerFunc(func(w ResponseWriter, r *Request) {
|
||||||
|
Loading…
Reference in New Issue
Block a user