From d655b1252ad194cda5ed7f6ddd6fc823127ae1dd Mon Sep 17 00:00:00 2001 From: Steve Newman Date: Tue, 9 Jun 2009 10:58:58 -0700 Subject: Basic HTTP client. R=rsc APPROVED=rsc DELTA=392 (386 added, 2 deleted, 4 changed) OCL=29963 CL=30107 --- src/pkg/http/client_test.go | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 src/pkg/http/client_test.go (limited to 'src/pkg/http/client_test.go') diff --git a/src/pkg/http/client_test.go b/src/pkg/http/client_test.go new file mode 100644 index 000000000..e9354fc40 --- /dev/null +++ b/src/pkg/http/client_test.go @@ -0,0 +1,40 @@ +// Copyright 2009 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// Tests for client.go + +package http + +import ( + "fmt"; + "http"; + "io"; + "strings"; + "testing"; +) + +func TestClient(t *testing.T) { + // TODO: add a proper test suite. Current test merely verifies that + // we can retrieve the Google home page. + + r, url, err := Get("http://www.google.com"); + var b []byte; + if err == nil { + b, err = io.ReadAll(r.Body); + r.Body.Close(); + } + + // TODO: io.ErrEOF check is needed because we're sometimes getting + // this error when nothing is actually wrong. rsc suspects a bug + // in bufio. Can remove the ErrEOF check once the bug is fixed + // (expected to occur within a few weeks of this writing, 6/9/09). + if err != nil && err != io.ErrEOF { + t.Errorf("Error fetching URL: %v", err); + } else { + s := string(b); + if (!strings.HasPrefix(s, "")) { + t.Errorf("Incorrect page body (did not begin with ): %q", s); + } + } +} -- cgit v1.2.3