forked from folbricht/desync
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmake_test.go
86 lines (78 loc) · 2.15 KB
/
make_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
75
76
77
78
79
80
81
82
83
84
85
86
package desync
import (
"bytes"
"context"
"crypto/sha512"
"fmt"
"math/rand"
"os"
"testing"
"github.com/folbricht/tempfile"
)
func TestParallelChunking(t *testing.T) {
null := make([]byte, 4*ChunkSizeMaxDefault)
rand1 := make([]byte, 4*ChunkSizeMaxDefault)
rand.Read(rand1)
rand2 := make([]byte, 4*ChunkSizeMaxDefault)
rand.Read(rand2)
tests := map[string][][]byte{
"random input": {rand1, rand2, rand1, rand2, rand1},
"leading null": {null, null, null, null, rand1, rand2},
"trailing null": {rand1, rand2, null, null, null, null},
"middle null": {rand1, null, null, null, null, rand2},
"spread out null": {rand1, null, null, null, rand1, null, null, null, rand2},
}
for name, input := range tests {
t.Run(name, func(t *testing.T) {
// Put the input data into a file for chunking
f, err := tempfile.New("", "")
if err != nil {
t.Fatal(err)
}
defer os.Remove(f.Name())
b := join(input...)
if _, err := f.Write(b); err != nil {
t.Fatal(err)
}
f.Close()
// Chunk the file single stream first to use the results as reference for
// the parallel chunking
c, err := NewChunker(bytes.NewReader(b), ChunkSizeMinDefault, ChunkSizeAvgDefault, ChunkSizeMaxDefault)
if err != nil {
t.Fatal(err)
}
var expected []IndexChunk
for {
start, buf, err := c.Next()
if err != nil {
t.Fatal(err)
}
if len(buf) == 0 {
break
}
id := ChunkID(sha512.Sum512_256(buf))
expected = append(expected, IndexChunk{Start: start, Size: uint64(len(buf)), ID: id})
}
// Chunk the file with the parallel chunking algorithm and different degrees of concurrency
for n := 1; n <= 10; n++ {
t.Run(fmt.Sprintf("%s, n=%d", name, n), func(t *testing.T) {
index, _, err := IndexFromFile(
context.Background(),
f.Name(),
n,
ChunkSizeMinDefault, ChunkSizeAvgDefault, ChunkSizeMaxDefault,
NewProgressBar(""),
)
if err != nil {
t.Fatal(err)
}
for i := range expected {
if expected[i] != index.Chunks[i] {
t.Fatal("chunks from parallel splitter don't match single stream chunks")
}
}
})
}
})
}
}