forked from segmentio/parquet-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuffer_internal_test.go
56 lines (50 loc) · 1.57 KB
/
buffer_internal_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
package parquet
import (
"fmt"
"math/rand"
"testing"
)
func TestBufferAlwaysCorrectSize(t *testing.T) {
var p bufferPool
for i := 0; i < 1000; i++ {
n := rand.Intn(1024 * 1024)
b := p.get(n)
if len(b.data) != n {
t.Fatalf("Expected buffer of size %d, got %d", n, len(b.data))
}
b.unref()
}
}
func TestBufferPoolBucketIndexAndSizeOf(t *testing.T) {
tests := []struct {
size int
bucketIndex int
bucketSize int
}{
{size: 0, bucketIndex: 0, bucketSize: 4096},
{size: 1, bucketIndex: 0, bucketSize: 4096},
{size: 2049, bucketIndex: 0, bucketSize: 4096},
{size: 4096, bucketIndex: 0, bucketSize: 4096},
{size: 4097, bucketIndex: 1, bucketSize: 8192},
{size: 8192, bucketIndex: 1, bucketSize: 8192},
{size: 8193, bucketIndex: 2, bucketSize: 16384},
{size: 16384, bucketIndex: 2, bucketSize: 16384},
{size: 16385, bucketIndex: 3, bucketSize: 32768},
{size: 32768, bucketIndex: 3, bucketSize: 32768},
{size: 32769, bucketIndex: 4, bucketSize: 65536},
{size: 262143, bucketIndex: 6, bucketSize: 262144},
{size: 262144, bucketIndex: 6, bucketSize: 262144},
{size: 262145, bucketIndex: 7, bucketSize: 393216},
}
for _, test := range tests {
t.Run(fmt.Sprintf("size=%d", test.size), func(t *testing.T) {
bucketIndex, bucketSize := bufferPoolBucketIndexAndSizeOfGet(test.size)
if bucketIndex != test.bucketIndex {
t.Errorf("wrong bucket index, want %d but got %d", test.bucketIndex, bucketIndex)
}
if bucketSize != test.bucketSize {
t.Errorf("wrong bucket size, want %d but got %d", test.bucketSize, bucketSize)
}
})
}
}