-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathio_test.go
74 lines (61 loc) · 1.58 KB
/
io_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
package consistentio
import (
"bytes"
"testing"
"github.com/stretchr/testify/require"
)
func TestConsistentIO(t *testing.T) {
_, err := NewConsistentIO()
require.NotNil(t, err)
_, err = NewConsistentIO(
Replicas(-1),
Hash(nil),
)
require.NotNil(t, err)
k1 := "93b3e49e"
k2 := "9228c"
k3 := "c748cbe16d5239"
w1 := bytes.NewBuffer([]byte{})
w2 := bytes.NewBuffer([]byte{})
w3 := bytes.NewBuffer([]byte{})
cio, err := NewConsistentIO(
Replicas(50),
AddWriter(k1, w1),
AddWriter(k2, w2),
AddWriter(k3, w3),
)
require.Nil(t, err)
require.NotNil(t, cio)
n, err := cio.Write(k1, []byte("Hello,"))
require.Nil(t, err)
require.Equal(t, 6, n)
require.Equal(t, 6, w3.Len())
n, err = cio.Write(k1, []byte(" "))
require.Nil(t, err)
require.Equal(t, 1, n)
require.Equal(t, 7, w3.Len())
n, err = cio.Write(k1, []byte("World"))
require.Nil(t, err)
require.Equal(t, 5, n)
require.Equal(t, 12, w3.Len())
require.Equal(t, "Hello, World", w3.String())
n, err = cio.Write(k2, []byte("f1529ad"))
require.Nil(t, err)
require.Equal(t, 7, n)
require.Equal(t, 7, w2.Len())
n, err = cio.Write(k3, []byte("f45efcf84fc3"))
require.Nil(t, err)
require.Equal(t, 12, n)
require.Equal(t, 12, w1.Len())
n, err = cio.Write(k2, []byte("d7"))
require.Nil(t, err)
require.Equal(t, 2, n)
require.Equal(t, 9, w2.Len())
n, err = cio.Write(k3, []byte("0d373c2c803"))
require.Nil(t, err)
require.Equal(t, 11, n)
require.Equal(t, 23, w1.Len())
require.Equal(t, "f45efcf84fc30d373c2c803", w1.String())
require.Equal(t, "f1529add7", w2.String())
require.Equal(t, "Hello, World", w3.String())
}