Jiri Simsa | d7616c9 | 2015-03-24 23:44:30 -0700 | [diff] [blame] | 1 | // Copyright 2015 The Vanadium Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style |
| 3 | // license that can be found in the LICENSE file. |
| 4 | |
Bogdan Caprita | 2f5585b | 2014-11-21 17:32:21 -0800 | [diff] [blame] | 5 | package modules_test |
| 6 | |
| 7 | import ( |
| 8 | "bytes" |
| 9 | "io" |
| 10 | "testing" |
| 11 | |
Cosmos Nicolaou | 1381f8a | 2015-03-13 09:40:34 -0700 | [diff] [blame] | 12 | "v.io/x/ref/test/modules" |
| 13 | "v.io/x/ref/test/testutil" |
Bogdan Caprita | 2f5585b | 2014-11-21 17:32:21 -0800 | [diff] [blame] | 14 | ) |
| 15 | |
Bogdan Caprita | 2f5585b | 2014-11-21 17:32:21 -0800 | [diff] [blame] | 16 | func TestQueueRW(t *testing.T) { |
Jiri Simsa | 95ab297 | 2015-07-01 12:35:57 -0700 | [diff] [blame] | 17 | testutil.InitRandGenerator(t.Logf) |
Bogdan Caprita | 2f5585b | 2014-11-21 17:32:21 -0800 | [diff] [blame] | 18 | q := modules.NewRW() |
Cosmos Nicolaou | c818b80 | 2015-06-05 15:52:45 -0700 | [diff] [blame] | 19 | size := testutil.RandomIntn(1000) |
Bogdan Caprita | 2f5585b | 2014-11-21 17:32:21 -0800 | [diff] [blame] | 20 | data := testutil.RandomBytes(size) |
| 21 | begin := 0 |
| 22 | for { |
Cosmos Nicolaou | c818b80 | 2015-06-05 15:52:45 -0700 | [diff] [blame] | 23 | end := begin + testutil.RandomIntn(100) + 1 |
Bogdan Caprita | 2f5585b | 2014-11-21 17:32:21 -0800 | [diff] [blame] | 24 | if end > len(data) { |
| 25 | end = len(data) |
| 26 | } |
| 27 | n, err := q.Write(data[begin:end]) |
| 28 | if err != nil { |
| 29 | t.Fatalf("Write failed: %v", err) |
| 30 | } |
| 31 | begin = begin + n |
| 32 | if begin == len(data) { |
| 33 | break |
| 34 | } |
| 35 | } |
Matt Rosencrantz | 5c75ff8 | 2015-03-02 17:55:31 -0800 | [diff] [blame] | 36 | if err := q.Close(); err != nil { |
Bogdan Caprita | 2f5585b | 2014-11-21 17:32:21 -0800 | [diff] [blame] | 37 | t.Fatalf("err %v", err) |
| 38 | } |
| 39 | readData := make([]byte, 0, size) |
| 40 | for { |
Cosmos Nicolaou | c818b80 | 2015-06-05 15:52:45 -0700 | [diff] [blame] | 41 | buf := make([]byte, testutil.RandomIntn(100)+1) |
Bogdan Caprita | 2f5585b | 2014-11-21 17:32:21 -0800 | [diff] [blame] | 42 | n, err := q.Read(buf) |
| 43 | if n > 0 { |
| 44 | readData = append(readData, buf[:n]...) |
| 45 | } |
| 46 | if err != nil { |
| 47 | if err == io.EOF { |
| 48 | break |
| 49 | } |
| 50 | t.Fatalf("Read failed: %v", err) |
| 51 | } |
| 52 | } |
| 53 | if size != len(readData) { |
| 54 | t.Fatalf("Mismatching data size: %d != %d", size, len(readData)) |
| 55 | } |
| 56 | if !bytes.Equal(data, readData) { |
| 57 | t.Fatalf("Diffing data:\n%v\n%v", data, readData) |
| 58 | } |
| 59 | } |