summaryrefslogtreecommitdiff
path: root/libgo/go/bufio/bufio_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'libgo/go/bufio/bufio_test.go')
-rw-r--r--libgo/go/bufio/bufio_test.go37
1 files changed, 36 insertions, 1 deletions
diff --git a/libgo/go/bufio/bufio_test.go b/libgo/go/bufio/bufio_test.go
index 41bd3d45633..5cd030714de 100644
--- a/libgo/go/bufio/bufio_test.go
+++ b/libgo/go/bufio/bufio_test.go
@@ -139,7 +139,7 @@ var bufreaders = []bufReader{
const minReadBufferSize = 16
var bufsizes = []int{
- minReadBufferSize, 23, 32, 46, 64, 93, 128, 1024, 4096,
+ 0, minReadBufferSize, 23, 32, 46, 64, 93, 128, 1024, 4096,
}
func TestReader(t *testing.T) {
@@ -259,6 +259,38 @@ func TestUnreadRune(t *testing.T) {
}
}
+func TestUnreadByte(t *testing.T) {
+ want := "Hello, world"
+ got := ""
+ segments := []string{"Hello, ", "world"}
+ r := NewReader(&StringReader{data: segments})
+ // Normal execution.
+ for {
+ b1, err := r.ReadByte()
+ if err != nil {
+ if err != io.EOF {
+ t.Fatal("unexpected EOF")
+ }
+ break
+ }
+ got += string(b1)
+ // Put it back and read it again
+ if err = r.UnreadByte(); err != nil {
+ t.Fatalf("unexpected error on UnreadByte: %v", err)
+ }
+ b2, err := r.ReadByte()
+ if err != nil {
+ t.Fatalf("unexpected error reading after unreading: %v", err)
+ }
+ if b1 != b2 {
+ t.Fatalf("incorrect byte after unread: got %c wanted %c", b1, b2)
+ }
+ }
+ if got != want {
+ t.Errorf("got=%q want=%q", got, want)
+ }
+}
+
// Test that UnreadRune fails if the preceding operation was not a ReadRune.
func TestUnreadRuneError(t *testing.T) {
buf := make([]byte, 3) // All runes in this test are 3 bytes long
@@ -516,6 +548,9 @@ func TestPeek(t *testing.T) {
if s, err := buf.Peek(4); string(s) != "abcd" || err != nil {
t.Fatalf("want %q got %q, err=%v", "abcd", string(s), err)
}
+ if _, err := buf.Peek(-1); err != ErrNegativeCount {
+ t.Fatalf("want ErrNegativeCount got %v", err)
+ }
if _, err := buf.Peek(32); err != ErrBufferFull {
t.Fatalf("want ErrBufFull got %v", err)
}