| // Copyright 2014 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. |
| |
| //go:build unix |
| |
| package rand |
| |
| import ( |
| "bytes" |
| "encoding/binary" |
| "errors" |
| prand "math/rand" |
| "testing" |
| ) |
| |
| func TestBatched(t *testing.T) { |
| fillBatched := batched(func(p []byte) error { |
| for i := range p { |
| p[i] = byte(i) |
| } |
| return nil |
| }, 5) |
| |
| p := make([]byte, 13) |
| if err := fillBatched(p); err != nil { |
| t.Fatalf("batched function returned error: %s", err) |
| } |
| expected := []byte{0, 1, 2, 3, 4, 0, 1, 2, 3, 4, 0, 1, 2} |
| if !bytes.Equal(expected, p) { |
| t.Errorf("incorrect batch result: got %x, want %x", p, expected) |
| } |
| } |
| |
| func TestBatchedBuffering(t *testing.T) { |
| var prandSeed [8]byte |
| Read(prandSeed[:]) |
| prand.Seed(int64(binary.LittleEndian.Uint64(prandSeed[:]))) |
| |
| backingStore := make([]byte, 1<<23) |
| prand.Read(backingStore) |
| backingMarker := backingStore[:] |
| output := make([]byte, len(backingStore)) |
| outputMarker := output[:] |
| |
| fillBatched := batched(func(p []byte) error { |
| n := copy(p, backingMarker) |
| backingMarker = backingMarker[n:] |
| return nil |
| }, 731) |
| |
| for len(outputMarker) > 0 { |
| max := 9200 |
| if max > len(outputMarker) { |
| max = len(outputMarker) |
| } |
| howMuch := prand.Intn(max + 1) |
| if err := fillBatched(outputMarker[:howMuch]); err != nil { |
| t.Fatalf("batched function returned error: %s", err) |
| } |
| outputMarker = outputMarker[howMuch:] |
| } |
| if !bytes.Equal(backingStore, output) { |
| t.Error("incorrect batch result") |
| } |
| } |
| |
| func TestBatchedError(t *testing.T) { |
| b := batched(func(p []byte) error { return errors.New("failure") }, 5) |
| if b(make([]byte, 13)) == nil { |
| t.Fatal("batched function should have returned an error") |
| } |
| } |
| |
| func TestBatchedEmpty(t *testing.T) { |
| b := batched(func(p []byte) error { return errors.New("failure") }, 5) |
| if b(make([]byte, 0)) != nil { |
| t.Fatal("empty slice should always return successful") |
| } |
| } |