Commit dc71ace2 authored by Brad Fitzpatrick's avatar Brad Fitzpatrick

bufio: add some tests

R=golang-dev, adg
CC=golang-dev
https://golang.org/cl/7927044
parent 5060dded
...@@ -7,6 +7,7 @@ package bufio_test ...@@ -7,6 +7,7 @@ package bufio_test
import ( import (
. "bufio" . "bufio"
"bytes" "bytes"
"errors"
"fmt" "fmt"
"io" "io"
"io/ioutil" "io/ioutil"
...@@ -434,9 +435,12 @@ func TestWriteErrors(t *testing.T) { ...@@ -434,9 +435,12 @@ func TestWriteErrors(t *testing.T) {
t.Errorf("Write hello to %v: %v", w, e) t.Errorf("Write hello to %v: %v", w, e)
continue continue
} }
e = buf.Flush() // Two flushes, to verify the error is sticky.
if e != w.expect { for i := 0; i < 2; i++ {
t.Errorf("Flush %v: got %v, wanted %v", w, e, w.expect) e = buf.Flush()
if e != w.expect {
t.Errorf("Flush %d/2 %v: got %v, wanted %v", i+1, w, e, w.expect)
}
} }
} }
} }
...@@ -962,6 +966,43 @@ func TestNegativeRead(t *testing.T) { ...@@ -962,6 +966,43 @@ func TestNegativeRead(t *testing.T) {
b.Read(make([]byte, 100)) b.Read(make([]byte, 100))
} }
var errFake = errors.New("fake error")
type errorThenGoodReader struct {
didErr bool
nread int
}
func (r *errorThenGoodReader) Read(p []byte) (int, error) {
r.nread++
if !r.didErr {
r.didErr = true
return 0, errFake
}
return len(p), nil
}
func TestReaderClearError(t *testing.T) {
r := &errorThenGoodReader{}
b := NewReader(r)
buf := make([]byte, 1)
if _, err := b.Read(nil); err != nil {
t.Fatalf("1st nil Read = %v; want nil", err)
}
if _, err := b.Read(buf); err != errFake {
t.Fatalf("1st Read = %v; want errFake", err)
}
if _, err := b.Read(nil); err != nil {
t.Fatalf("2nd nil Read = %v; want nil", err)
}
if _, err := b.Read(buf); err != nil {
t.Fatalf("3rd Read with buffer = %v; want nil", err)
}
if r.nread != 2 {
t.Errorf("num reads = %d; want 2", r.nread)
}
}
// An onlyReader only implements io.Reader, no matter what other methods the underlying implementation may have. // An onlyReader only implements io.Reader, no matter what other methods the underlying implementation may have.
type onlyReader struct { type onlyReader struct {
r io.Reader r io.Reader
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment