aboutsummaryrefslogtreecommitdiff
path: root/sys_test.go
blob: 0dcae66d8379b4eab7c214186538dfab025307cc (plain) (blame)
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
package bolt

import (
	"testing"
	"unsafe"

	"github.com/stretchr/testify/assert"
)

// Ensure that a system page can set a bucket.
func TestSysPut(t *testing.T) {
	s := &sys{buckets: make(map[string]*bucket)}
	s.put("foo", &bucket{root: 2})
	s.put("bar", &bucket{root: 3})
	s.put("foo", &bucket{root: 4})
	assert.Equal(t, len(s.buckets), 2)
	assert.Equal(t, s.get("foo").root, pgid(4))
	assert.Equal(t, s.get("bar").root, pgid(3))
	assert.Nil(t, s.get("no_such_bucket"))
}

// Ensure that a system page can deserialize from a page.
func TestSysRead(t *testing.T) {
	// Create a page.
	var buf [4096]byte
	page := (*page)(unsafe.Pointer(&buf[0]))
	page.count = 2

	// Insert 2 buckets at the beginning.
	buckets := (*[3]bucket)(unsafe.Pointer(&page.ptr))
	buckets[0] = bucket{root: 3}
	buckets[1] = bucket{root: 4}

	// Write data for the nodes at the end.
	data := (*[4096]byte)(unsafe.Pointer(&buckets[2]))
	data[0] = 3
	copy(data[1:], []byte("bar"))
	data[4] = 10
	copy(data[5:], []byte("helloworld"))

	// Deserialize page into a system page.
	s := &sys{buckets: make(map[string]*bucket)}
	s.read(page)

	// Check that there are two items with correct data.
	assert.Equal(t, len(s.buckets), 2)
	assert.Equal(t, s.get("bar").root, pgid(3))
	assert.Equal(t, s.get("helloworld").root, pgid(4))
}

// Ensure that a system page can serialize itself.
func TestSysWrite(t *testing.T) {
	s := &sys{buckets: make(map[string]*bucket)}
	s.put("foo", &bucket{root: 2})
	s.put("bar", &bucket{root: 3})

	// Write it to a page.
	var buf [4096]byte
	p := (*page)(unsafe.Pointer(&buf[0]))
	s.write(p)

	// Read the page back in.
	s2 := &sys{buckets: make(map[string]*bucket)}
	s2.read(p)

	// Check that the two pages are the same.
	assert.Equal(t, len(s.buckets), 2)
	assert.Equal(t, s.get("foo").root, pgid(2))
	assert.Equal(t, s.get("bar").root, pgid(3))
}