forked from szferi/gomdb
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmdb_test.go
113 lines (111 loc) · 2.39 KB
/
mdb_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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
package mdb
import (
"fmt"
"io/ioutil"
"os"
"testing"
)
func TestTest1(t *testing.T) {
env, err := NewEnv()
if err != nil {
t.Fatalf("Cannot create environment: %s", err)
}
err = env.SetMapSize(10485760)
if err != nil {
t.Fatalf("Cannot set mapsize: %s", err)
}
path, err := ioutil.TempDir("/tmp", "mdb_test")
if err != nil {
t.Fatalf("Cannot create temporary directory")
}
err = os.MkdirAll(path, 0770)
defer os.RemoveAll(path)
if err != nil {
t.Fatalf("Cannot create directory: %s", path)
}
err = env.Open(path, 0, 0664)
defer env.Close()
if err != nil {
t.Fatalf("Cannot open environment: %s", err)
}
var txn *Txn
txn, err = env.BeginTxn(nil, 0)
if err != nil {
t.Fatalf("Cannot begin transaction: %s", err)
}
var dbi DBI
dbi, err = txn.DBIOpen(nil, 0)
defer env.DBIClose(dbi)
if err != nil {
t.Fatalf("Cannot create DBI %s", err)
}
var data = map[string]string{}
var key string
var val string
num_entries := 10
for i := 0; i < num_entries; i++ {
key = fmt.Sprintf("Key-%d", i)
val = fmt.Sprintf("Val-%d", i)
data[key] = val
err = txn.Put(dbi, []byte(key), []byte(val), NOOVERWRITE)
if err != nil {
txn.Abort()
t.Fatalf("Error during put: %s", err)
}
}
err = txn.Commit()
if err != nil {
txn.Abort()
t.Fatalf("Cannot commit %s", err)
}
stat, err := env.Stat()
if err != nil {
t.Fatalf("Cannot get stat %s", err)
}
t.Logf("%+v", stat)
if stat.Entries != uint64(num_entries) {
t.Errorf("Less entry in the database than expected: %d <> %d", stat.Entries, num_entries)
}
txn, err = env.BeginTxn(nil, 0)
if err != nil {
t.Fatalf("Cannot begin transaction: %s", err)
}
var cursor *Cursor
cursor, err = txn.CursorOpen(dbi)
if err != nil {
cursor.Close()
txn.Abort()
t.Fatalf("Error during cursor open %s", err)
}
var bkey, bval []byte
var rc error
for {
bkey, bval, rc = cursor.Get(nil, nil, NEXT)
if rc != nil {
break
}
skey := string(bkey)
sval := string(bval)
t.Logf("Val: %s", sval)
t.Logf("Key: %s", skey)
var d string
var ok bool
if d, ok = data[skey]; !ok {
t.Errorf("Cannot found: %q", skey)
}
if d != sval {
t.Errorf("Data missmatch: %q <> %q", sval, d)
}
}
cursor.Close()
bval, err = txn.Get(dbi, []byte("Key-0"))
if err != nil {
txn.Abort()
t.Fatalf("Error during txn get %s", err)
}
if string(bval) != "Val-0" {
txn.Abort()
t.Fatalf("Invalid txn get %s", string(bval))
}
txn.Abort()
}