forked from tecbot/gorocksdb
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtransactiondb_test.go
110 lines (92 loc) · 2.62 KB
/
transactiondb_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
package gorocksdb
import (
"io/ioutil"
"testing"
"github.com/facebookgo/ensure"
)
func TestOpenTransactionDb(t *testing.T) {
db := newTestTransactionDB(t, "TestOpenTransactionDb", nil)
defer db.Close()
}
func TestTransactionDBCRUD(t *testing.T) {
db := newTestTransactionDB(t, "TestTransactionDBGet", nil)
defer db.Close()
var (
givenKey = []byte("hello")
givenVal1 = []byte("world1")
givenVal2 = []byte("world2")
givenTxnKey = []byte("hello2")
givenTxnKey2 = []byte("hello3")
givenTxnVal1 = []byte("whatawonderful")
wo = NewDefaultWriteOptions()
ro = NewDefaultReadOptions()
to = NewDefaultTransactionOptions()
)
// create
ensure.Nil(t, db.Put(wo, givenKey, givenVal1))
// retrieve
v1, err := db.Get(ro, givenKey)
defer v1.Free()
ensure.Nil(t, err)
ensure.DeepEqual(t, v1.Data(), givenVal1)
// update
ensure.Nil(t, db.Put(wo, givenKey, givenVal2))
v2, err := db.Get(ro, givenKey)
defer v2.Free()
ensure.Nil(t, err)
ensure.DeepEqual(t, v2.Data(), givenVal2)
// delete
ensure.Nil(t, db.Delete(wo, givenKey))
v3, err := db.Get(ro, givenKey)
defer v3.Free()
ensure.Nil(t, err)
ensure.True(t, v3.Data() == nil)
// transaction
txn := db.TransactionBegin(wo, to, nil)
defer txn.Destroy()
// create
ensure.Nil(t, txn.Put(givenTxnKey, givenTxnVal1))
v4, err := txn.Get(ro, givenTxnKey)
defer v4.Free()
ensure.Nil(t, err)
ensure.DeepEqual(t, v4.Data(), givenTxnVal1)
ensure.Nil(t, txn.Commit())
v5, err := db.Get(ro, givenTxnKey)
defer v5.Free()
ensure.Nil(t, err)
ensure.DeepEqual(t, v5.Data(), givenTxnVal1)
// transaction
txn2 := db.TransactionBegin(wo, to, nil)
defer txn2.Destroy()
// create
ensure.Nil(t, txn2.Put(givenTxnKey2, givenTxnVal1))
// rollback
ensure.Nil(t, txn2.Rollback())
v6, err := txn2.Get(ro, givenTxnKey2)
defer v6.Free()
ensure.Nil(t, err)
ensure.True(t, v6.Data() == nil)
// transaction
txn3 := db.TransactionBegin(wo, to, nil)
defer txn3.Destroy()
// delete
ensure.Nil(t, txn3.Delete(givenTxnKey))
ensure.Nil(t, txn3.Commit())
v7, err := db.Get(ro, givenTxnKey)
defer v7.Free()
ensure.Nil(t, err)
ensure.True(t, v7.Data() == nil)
}
func newTestTransactionDB(t *testing.T, name string, applyOpts func(opts *Options, transactionDBOpts *TransactionDBOptions)) *TransactionDB {
dir, err := ioutil.TempDir("", "gorockstransactiondb-"+name)
ensure.Nil(t, err)
opts := NewDefaultOptions()
opts.SetCreateIfMissing(true)
transactionDBOpts := NewDefaultTransactionDBOptions()
if applyOpts != nil {
applyOpts(opts, transactionDBOpts)
}
db, err := OpenTransactionDb(opts, transactionDBOpts, dir)
ensure.Nil(t, err)
return db
}