kvdb: make etcd tests use testify require instead of assert

This commit is contained in:
Andras Banki-Horvath 2020-06-29 14:53:38 +02:00
parent 77549f1fb8
commit 70a69ce990
No known key found for this signature in database
GPG Key ID: 80E5375C094198D8
6 changed files with 317 additions and 317 deletions

View File

@ -8,7 +8,7 @@ import (
"testing" "testing"
"github.com/btcsuite/btcwallet/walletdb" "github.com/btcsuite/btcwallet/walletdb"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/require"
) )
func TestCopy(t *testing.T) { func TestCopy(t *testing.T) {
@ -18,30 +18,30 @@ func TestCopy(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
// "apple" // "apple"
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
assert.NoError(t, apple.Put([]byte("key"), []byte("val"))) require.NoError(t, apple.Put([]byte("key"), []byte("val")))
return nil return nil
}) })
// Expect non-zero copy. // Expect non-zero copy.
var buf bytes.Buffer var buf bytes.Buffer
assert.NoError(t, db.Copy(&buf)) require.NoError(t, db.Copy(&buf))
assert.Greater(t, buf.Len(), 0) require.Greater(t, buf.Len(), 0)
assert.Nil(t, err) require.Nil(t, err)
expected := map[string]string{ expected := map[string]string{
bkey("apple"): bval("apple"), bkey("apple"): bval("apple"),
vkey("key", "apple"): "val", vkey("key", "apple"): "val",
} }
assert.Equal(t, expected, f.Dump()) require.Equal(t, expected, f.Dump())
} }
func TestAbortContext(t *testing.T) { func TestAbortContext(t *testing.T) {
@ -57,19 +57,19 @@ func TestAbortContext(t *testing.T) {
// Pass abort context and abort right away. // Pass abort context and abort right away.
db, err := newEtcdBackend(config) db, err := newEtcdBackend(config)
assert.NoError(t, err) require.NoError(t, err)
cancel() cancel()
// Expect that the update will fail. // Expect that the update will fail.
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
_, err := tx.CreateTopLevelBucket([]byte("bucket")) _, err := tx.CreateTopLevelBucket([]byte("bucket"))
assert.NoError(t, err) require.NoError(t, err)
return nil return nil
}) })
assert.Error(t, err, "context canceled") require.Error(t, err, "context canceled")
// No changes in the DB. // No changes in the DB.
assert.Equal(t, map[string]string{}, f.Dump()) require.Equal(t, map[string]string{}, f.Dump())
} }

View File

@ -6,25 +6,25 @@ import (
"testing" "testing"
"github.com/btcsuite/btcwallet/walletdb" "github.com/btcsuite/btcwallet/walletdb"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/require"
) )
func TestOpenCreateFailure(t *testing.T) { func TestOpenCreateFailure(t *testing.T) {
t.Parallel() t.Parallel()
db, err := walletdb.Open(dbType) db, err := walletdb.Open(dbType)
assert.Error(t, err) require.Error(t, err)
assert.Nil(t, db) require.Nil(t, db)
db, err = walletdb.Open(dbType, "wrong") db, err = walletdb.Open(dbType, "wrong")
assert.Error(t, err) require.Error(t, err)
assert.Nil(t, db) require.Nil(t, db)
db, err = walletdb.Create(dbType) db, err = walletdb.Create(dbType)
assert.Error(t, err) require.Error(t, err)
assert.Nil(t, db) require.Nil(t, db)
db, err = walletdb.Create(dbType, "wrong") db, err = walletdb.Create(dbType, "wrong")
assert.Error(t, err) require.Error(t, err)
assert.Nil(t, db) require.Nil(t, db)
} }

View File

@ -8,7 +8,7 @@ import (
"testing" "testing"
"github.com/btcsuite/btcwallet/walletdb" "github.com/btcsuite/btcwallet/walletdb"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/require"
) )
func TestBucketCreation(t *testing.T) { func TestBucketCreation(t *testing.T) {
@ -18,70 +18,70 @@ func TestBucketCreation(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
// empty bucket name // empty bucket name
b, err := tx.CreateTopLevelBucket(nil) b, err := tx.CreateTopLevelBucket(nil)
assert.Error(t, walletdb.ErrBucketNameRequired, err) require.Error(t, walletdb.ErrBucketNameRequired, err)
assert.Nil(t, b) require.Nil(t, b)
// empty bucket name // empty bucket name
b, err = tx.CreateTopLevelBucket([]byte("")) b, err = tx.CreateTopLevelBucket([]byte(""))
assert.Error(t, walletdb.ErrBucketNameRequired, err) require.Error(t, walletdb.ErrBucketNameRequired, err)
assert.Nil(t, b) require.Nil(t, b)
// "apple" // "apple"
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
// Check bucket tx. // Check bucket tx.
assert.Equal(t, tx, apple.Tx()) require.Equal(t, tx, apple.Tx())
// "apple" already created // "apple" already created
b, err = tx.CreateTopLevelBucket([]byte("apple")) b, err = tx.CreateTopLevelBucket([]byte("apple"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, b) require.NotNil(t, b)
// "apple/banana" // "apple/banana"
banana, err := apple.CreateBucket([]byte("banana")) banana, err := apple.CreateBucket([]byte("banana"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, banana) require.NotNil(t, banana)
banana, err = apple.CreateBucketIfNotExists([]byte("banana")) banana, err = apple.CreateBucketIfNotExists([]byte("banana"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, banana) require.NotNil(t, banana)
// Try creating "apple/banana" again // Try creating "apple/banana" again
b, err = apple.CreateBucket([]byte("banana")) b, err = apple.CreateBucket([]byte("banana"))
assert.Error(t, walletdb.ErrBucketExists, err) require.Error(t, walletdb.ErrBucketExists, err)
assert.Nil(t, b) require.Nil(t, b)
// "apple/mango" // "apple/mango"
mango, err := apple.CreateBucket([]byte("mango")) mango, err := apple.CreateBucket([]byte("mango"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, mango) require.NotNil(t, mango)
// "apple/banana/pear" // "apple/banana/pear"
pear, err := banana.CreateBucket([]byte("pear")) pear, err := banana.CreateBucket([]byte("pear"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, pear) require.NotNil(t, pear)
// empty bucket // empty bucket
assert.Nil(t, apple.NestedReadWriteBucket(nil)) require.Nil(t, apple.NestedReadWriteBucket(nil))
assert.Nil(t, apple.NestedReadWriteBucket([]byte(""))) require.Nil(t, apple.NestedReadWriteBucket([]byte("")))
// "apple/pear" doesn't exist // "apple/pear" doesn't exist
assert.Nil(t, apple.NestedReadWriteBucket([]byte("pear"))) require.Nil(t, apple.NestedReadWriteBucket([]byte("pear")))
// "apple/banana" exits // "apple/banana" exits
assert.NotNil(t, apple.NestedReadWriteBucket([]byte("banana"))) require.NotNil(t, apple.NestedReadWriteBucket([]byte("banana")))
assert.NotNil(t, apple.NestedReadBucket([]byte("banana"))) require.NotNil(t, apple.NestedReadBucket([]byte("banana")))
return nil return nil
}) })
assert.Nil(t, err) require.Nil(t, err)
expected := map[string]string{ expected := map[string]string{
bkey("apple"): bval("apple"), bkey("apple"): bval("apple"),
@ -89,7 +89,7 @@ func TestBucketCreation(t *testing.T) {
bkey("apple", "mango"): bval("apple", "mango"), bkey("apple", "mango"): bval("apple", "mango"),
bkey("apple", "banana", "pear"): bval("apple", "banana", "pear"), bkey("apple", "banana", "pear"): bval("apple", "banana", "pear"),
} }
assert.Equal(t, expected, f.Dump()) require.Equal(t, expected, f.Dump())
} }
func TestBucketDeletion(t *testing.T) { func TestBucketDeletion(t *testing.T) {
@ -99,99 +99,99 @@ func TestBucketDeletion(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
// "apple" // "apple"
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
// "apple/banana" // "apple/banana"
banana, err := apple.CreateBucket([]byte("banana")) banana, err := apple.CreateBucket([]byte("banana"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, banana) require.NotNil(t, banana)
kvs := []KV{{"key1", "val1"}, {"key2", "val2"}, {"key3", "val3"}} kvs := []KV{{"key1", "val1"}, {"key2", "val2"}, {"key3", "val3"}}
for _, kv := range kvs { for _, kv := range kvs {
assert.NoError(t, banana.Put([]byte(kv.key), []byte(kv.val))) require.NoError(t, banana.Put([]byte(kv.key), []byte(kv.val)))
assert.Equal(t, []byte(kv.val), banana.Get([]byte(kv.key))) require.Equal(t, []byte(kv.val), banana.Get([]byte(kv.key)))
} }
// Delete a k/v from "apple/banana" // Delete a k/v from "apple/banana"
assert.NoError(t, banana.Delete([]byte("key2"))) require.NoError(t, banana.Delete([]byte("key2")))
// Try getting/putting/deleting invalid k/v's. // Try getting/putting/deleting invalid k/v's.
assert.Nil(t, banana.Get(nil)) require.Nil(t, banana.Get(nil))
assert.Error(t, walletdb.ErrKeyRequired, banana.Put(nil, []byte("val"))) require.Error(t, walletdb.ErrKeyRequired, banana.Put(nil, []byte("val")))
assert.Error(t, walletdb.ErrKeyRequired, banana.Delete(nil)) require.Error(t, walletdb.ErrKeyRequired, banana.Delete(nil))
// Try deleting a k/v that doesn't exist. // Try deleting a k/v that doesn't exist.
assert.NoError(t, banana.Delete([]byte("nokey"))) require.NoError(t, banana.Delete([]byte("nokey")))
// "apple/pear" // "apple/pear"
pear, err := apple.CreateBucket([]byte("pear")) pear, err := apple.CreateBucket([]byte("pear"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, pear) require.NotNil(t, pear)
// Put some values into "apple/pear" // Put some values into "apple/pear"
for _, kv := range kvs { for _, kv := range kvs {
assert.Nil(t, pear.Put([]byte(kv.key), []byte(kv.val))) require.Nil(t, pear.Put([]byte(kv.key), []byte(kv.val)))
assert.Equal(t, []byte(kv.val), pear.Get([]byte(kv.key))) require.Equal(t, []byte(kv.val), pear.Get([]byte(kv.key)))
} }
// Create nested bucket "apple/pear/cherry" // Create nested bucket "apple/pear/cherry"
cherry, err := pear.CreateBucket([]byte("cherry")) cherry, err := pear.CreateBucket([]byte("cherry"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, cherry) require.NotNil(t, cherry)
// Put some values into "apple/pear/cherry" // Put some values into "apple/pear/cherry"
for _, kv := range kvs { for _, kv := range kvs {
assert.NoError(t, cherry.Put([]byte(kv.key), []byte(kv.val))) require.NoError(t, cherry.Put([]byte(kv.key), []byte(kv.val)))
} }
// Read back values in "apple/pear/cherry" trough a read bucket. // Read back values in "apple/pear/cherry" trough a read bucket.
cherryReadBucket := pear.NestedReadBucket([]byte("cherry")) cherryReadBucket := pear.NestedReadBucket([]byte("cherry"))
for _, kv := range kvs { for _, kv := range kvs {
assert.Equal( require.Equal(
t, []byte(kv.val), t, []byte(kv.val),
cherryReadBucket.Get([]byte(kv.key)), cherryReadBucket.Get([]byte(kv.key)),
) )
} }
// Try deleting some invalid buckets. // Try deleting some invalid buckets.
assert.Error(t, require.Error(t,
walletdb.ErrBucketNameRequired, apple.DeleteNestedBucket(nil), walletdb.ErrBucketNameRequired, apple.DeleteNestedBucket(nil),
) )
// Try deleting a non existing bucket. // Try deleting a non existing bucket.
assert.Error( require.Error(
t, t,
walletdb.ErrBucketNotFound, walletdb.ErrBucketNotFound,
apple.DeleteNestedBucket([]byte("missing")), apple.DeleteNestedBucket([]byte("missing")),
) )
// Delete "apple/pear" // Delete "apple/pear"
assert.Nil(t, apple.DeleteNestedBucket([]byte("pear"))) require.Nil(t, apple.DeleteNestedBucket([]byte("pear")))
// "apple/pear" deleted // "apple/pear" deleted
assert.Nil(t, apple.NestedReadWriteBucket([]byte("pear"))) require.Nil(t, apple.NestedReadWriteBucket([]byte("pear")))
// "apple/pear/cherry" deleted // "apple/pear/cherry" deleted
assert.Nil(t, pear.NestedReadWriteBucket([]byte("cherry"))) require.Nil(t, pear.NestedReadWriteBucket([]byte("cherry")))
// Values deleted too. // Values deleted too.
for _, kv := range kvs { for _, kv := range kvs {
assert.Nil(t, pear.Get([]byte(kv.key))) require.Nil(t, pear.Get([]byte(kv.key)))
assert.Nil(t, cherry.Get([]byte(kv.key))) require.Nil(t, cherry.Get([]byte(kv.key)))
} }
// "aple/banana" exists // "aple/banana" exists
assert.NotNil(t, apple.NestedReadWriteBucket([]byte("banana"))) require.NotNil(t, apple.NestedReadWriteBucket([]byte("banana")))
return nil return nil
}) })
assert.Nil(t, err) require.Nil(t, err)
expected := map[string]string{ expected := map[string]string{
bkey("apple"): bval("apple"), bkey("apple"): bval("apple"),
@ -199,7 +199,7 @@ func TestBucketDeletion(t *testing.T) {
vkey("key1", "apple", "banana"): "val1", vkey("key1", "apple", "banana"): "val1",
vkey("key3", "apple", "banana"): "val3", vkey("key3", "apple", "banana"): "val3",
} }
assert.Equal(t, expected, f.Dump()) require.Equal(t, expected, f.Dump())
} }
func TestBucketForEach(t *testing.T) { func TestBucketForEach(t *testing.T) {
@ -209,28 +209,28 @@ func TestBucketForEach(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
// "apple" // "apple"
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
// "apple/banana" // "apple/banana"
banana, err := apple.CreateBucket([]byte("banana")) banana, err := apple.CreateBucket([]byte("banana"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, banana) require.NotNil(t, banana)
kvs := []KV{{"key1", "val1"}, {"key2", "val2"}, {"key3", "val3"}} kvs := []KV{{"key1", "val1"}, {"key2", "val2"}, {"key3", "val3"}}
// put some values into "apple" and "apple/banana" too // put some values into "apple" and "apple/banana" too
for _, kv := range kvs { for _, kv := range kvs {
assert.Nil(t, apple.Put([]byte(kv.key), []byte(kv.val))) require.Nil(t, apple.Put([]byte(kv.key), []byte(kv.val)))
assert.Equal(t, []byte(kv.val), apple.Get([]byte(kv.key))) require.Equal(t, []byte(kv.val), apple.Get([]byte(kv.key)))
assert.Nil(t, banana.Put([]byte(kv.key), []byte(kv.val))) require.Nil(t, banana.Put([]byte(kv.key), []byte(kv.val)))
assert.Equal(t, []byte(kv.val), banana.Get([]byte(kv.key))) require.Equal(t, []byte(kv.val), banana.Get([]byte(kv.key)))
} }
got := make(map[string]string) got := make(map[string]string)
@ -246,8 +246,8 @@ func TestBucketForEach(t *testing.T) {
"banana": "", "banana": "",
} }
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, expected, got) require.Equal(t, expected, got)
got = make(map[string]string) got = make(map[string]string)
err = banana.ForEach(func(key, val []byte) error { err = banana.ForEach(func(key, val []byte) error {
@ -255,15 +255,15 @@ func TestBucketForEach(t *testing.T) {
return nil return nil
}) })
assert.NoError(t, err) require.NoError(t, err)
// remove the sub-bucket key // remove the sub-bucket key
delete(expected, "banana") delete(expected, "banana")
assert.Equal(t, expected, got) require.Equal(t, expected, got)
return nil return nil
}) })
assert.Nil(t, err) require.Nil(t, err)
expected := map[string]string{ expected := map[string]string{
bkey("apple"): bval("apple"), bkey("apple"): bval("apple"),
@ -275,7 +275,7 @@ func TestBucketForEach(t *testing.T) {
vkey("key2", "apple", "banana"): "val2", vkey("key2", "apple", "banana"): "val2",
vkey("key3", "apple", "banana"): "val3", vkey("key3", "apple", "banana"): "val3",
} }
assert.Equal(t, expected, f.Dump()) require.Equal(t, expected, f.Dump())
} }
func TestBucketForEachWithError(t *testing.T) { func TestBucketForEachWithError(t *testing.T) {
@ -285,30 +285,30 @@ func TestBucketForEachWithError(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
// "apple" // "apple"
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
// "apple/banana" // "apple/banana"
banana, err := apple.CreateBucket([]byte("banana")) banana, err := apple.CreateBucket([]byte("banana"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, banana) require.NotNil(t, banana)
// "apple/pear" // "apple/pear"
pear, err := apple.CreateBucket([]byte("pear")) pear, err := apple.CreateBucket([]byte("pear"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, pear) require.NotNil(t, pear)
kvs := []KV{{"key1", "val1"}, {"key2", "val2"}} kvs := []KV{{"key1", "val1"}, {"key2", "val2"}}
// Put some values into "apple" and "apple/banana" too. // Put some values into "apple" and "apple/banana" too.
for _, kv := range kvs { for _, kv := range kvs {
assert.Nil(t, apple.Put([]byte(kv.key), []byte(kv.val))) require.Nil(t, apple.Put([]byte(kv.key), []byte(kv.val)))
assert.Equal(t, []byte(kv.val), apple.Get([]byte(kv.key))) require.Equal(t, []byte(kv.val), apple.Get([]byte(kv.key)))
} }
got := make(map[string]string) got := make(map[string]string)
@ -328,8 +328,8 @@ func TestBucketForEachWithError(t *testing.T) {
"key1": "val1", "key1": "val1",
} }
assert.Equal(t, expected, got) require.Equal(t, expected, got)
assert.Error(t, err) require.Error(t, err)
got = make(map[string]string) got = make(map[string]string)
i = 0 i = 0
@ -350,12 +350,12 @@ func TestBucketForEachWithError(t *testing.T) {
"banana": "", "banana": "",
} }
assert.Equal(t, expected, got) require.Equal(t, expected, got)
assert.Error(t, err) require.Error(t, err)
return nil return nil
}) })
assert.Nil(t, err) require.Nil(t, err)
expected := map[string]string{ expected := map[string]string{
bkey("apple"): bval("apple"), bkey("apple"): bval("apple"),
@ -364,7 +364,7 @@ func TestBucketForEachWithError(t *testing.T) {
vkey("key1", "apple"): "val1", vkey("key1", "apple"): "val1",
vkey("key2", "apple"): "val2", vkey("key2", "apple"): "val2",
} }
assert.Equal(t, expected, f.Dump()) require.Equal(t, expected, f.Dump())
} }
func TestBucketSequence(t *testing.T) { func TestBucketSequence(t *testing.T) {
@ -374,31 +374,31 @@ func TestBucketSequence(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
banana, err := apple.CreateBucket([]byte("banana")) banana, err := apple.CreateBucket([]byte("banana"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, banana) require.NotNil(t, banana)
assert.Equal(t, uint64(0), apple.Sequence()) require.Equal(t, uint64(0), apple.Sequence())
assert.Equal(t, uint64(0), banana.Sequence()) require.Equal(t, uint64(0), banana.Sequence())
assert.Nil(t, apple.SetSequence(math.MaxUint64)) require.Nil(t, apple.SetSequence(math.MaxUint64))
assert.Equal(t, uint64(math.MaxUint64), apple.Sequence()) require.Equal(t, uint64(math.MaxUint64), apple.Sequence())
for i := uint64(0); i < uint64(5); i++ { for i := uint64(0); i < uint64(5); i++ {
s, err := apple.NextSequence() s, err := apple.NextSequence()
assert.Nil(t, err) require.Nil(t, err)
assert.Equal(t, i, s) require.Equal(t, i, s)
} }
return nil return nil
}) })
assert.Nil(t, err) require.Nil(t, err)
} }

View File

@ -6,7 +6,7 @@ import (
"testing" "testing"
"github.com/btcsuite/btcwallet/walletdb" "github.com/btcsuite/btcwallet/walletdb"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/require"
) )
func TestReadCursorEmptyInterval(t *testing.T) { func TestReadCursorEmptyInterval(t *testing.T) {
@ -16,41 +16,41 @@ func TestReadCursorEmptyInterval(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
b, err := tx.CreateTopLevelBucket([]byte("alma")) b, err := tx.CreateTopLevelBucket([]byte("alma"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, b) require.NotNil(t, b)
return nil return nil
}) })
assert.NoError(t, err) require.NoError(t, err)
err = db.View(func(tx walletdb.ReadTx) error { err = db.View(func(tx walletdb.ReadTx) error {
b := tx.ReadBucket([]byte("alma")) b := tx.ReadBucket([]byte("alma"))
assert.NotNil(t, b) require.NotNil(t, b)
cursor := b.ReadCursor() cursor := b.ReadCursor()
k, v := cursor.First() k, v := cursor.First()
assert.Nil(t, k) require.Nil(t, k)
assert.Nil(t, v) require.Nil(t, v)
k, v = cursor.Next() k, v = cursor.Next()
assert.Nil(t, k) require.Nil(t, k)
assert.Nil(t, v) require.Nil(t, v)
k, v = cursor.Last() k, v = cursor.Last()
assert.Nil(t, k) require.Nil(t, k)
assert.Nil(t, v) require.Nil(t, v)
k, v = cursor.Prev() k, v = cursor.Prev()
assert.Nil(t, k) require.Nil(t, k)
assert.Nil(t, v) require.Nil(t, v)
return nil return nil
}) })
assert.NoError(t, err) require.NoError(t, err)
} }
func TestReadCursorNonEmptyInterval(t *testing.T) { func TestReadCursorNonEmptyInterval(t *testing.T) {
@ -60,7 +60,7 @@ func TestReadCursorNonEmptyInterval(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
testKeyValues := []KV{ testKeyValues := []KV{
{"b", "1"}, {"b", "1"},
@ -71,20 +71,20 @@ func TestReadCursorNonEmptyInterval(t *testing.T) {
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
b, err := tx.CreateTopLevelBucket([]byte("alma")) b, err := tx.CreateTopLevelBucket([]byte("alma"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, b) require.NotNil(t, b)
for _, kv := range testKeyValues { for _, kv := range testKeyValues {
assert.NoError(t, b.Put([]byte(kv.key), []byte(kv.val))) require.NoError(t, b.Put([]byte(kv.key), []byte(kv.val)))
} }
return nil return nil
}) })
assert.NoError(t, err) require.NoError(t, err)
err = db.View(func(tx walletdb.ReadTx) error { err = db.View(func(tx walletdb.ReadTx) error {
b := tx.ReadBucket([]byte("alma")) b := tx.ReadBucket([]byte("alma"))
assert.NotNil(t, b) require.NotNil(t, b)
// Iterate from the front. // Iterate from the front.
var kvs []KV var kvs []KV
@ -95,7 +95,7 @@ func TestReadCursorNonEmptyInterval(t *testing.T) {
kvs = append(kvs, KV{string(k), string(v)}) kvs = append(kvs, KV{string(k), string(v)})
k, v = cursor.Next() k, v = cursor.Next()
} }
assert.Equal(t, testKeyValues, kvs) require.Equal(t, testKeyValues, kvs)
// Iterate from the back. // Iterate from the back.
kvs = []KV{} kvs = []KV{}
@ -105,29 +105,29 @@ func TestReadCursorNonEmptyInterval(t *testing.T) {
kvs = append(kvs, KV{string(k), string(v)}) kvs = append(kvs, KV{string(k), string(v)})
k, v = cursor.Prev() k, v = cursor.Prev()
} }
assert.Equal(t, reverseKVs(testKeyValues), kvs) require.Equal(t, reverseKVs(testKeyValues), kvs)
// Random access // Random access
perm := []int{3, 0, 2, 1} perm := []int{3, 0, 2, 1}
for _, i := range perm { for _, i := range perm {
k, v := cursor.Seek([]byte(testKeyValues[i].key)) k, v := cursor.Seek([]byte(testKeyValues[i].key))
assert.Equal(t, []byte(testKeyValues[i].key), k) require.Equal(t, []byte(testKeyValues[i].key), k)
assert.Equal(t, []byte(testKeyValues[i].val), v) require.Equal(t, []byte(testKeyValues[i].val), v)
} }
// Seek to nonexisting key. // Seek to nonexisting key.
k, v = cursor.Seek(nil) k, v = cursor.Seek(nil)
assert.Nil(t, k) require.Nil(t, k)
assert.Nil(t, v) require.Nil(t, v)
k, v = cursor.Seek([]byte("x")) k, v = cursor.Seek([]byte("x"))
assert.Nil(t, k) require.Nil(t, k)
assert.Nil(t, v) require.Nil(t, v)
return nil return nil
}) })
assert.NoError(t, err) require.NoError(t, err)
} }
func TestReadWriteCursor(t *testing.T) { func TestReadWriteCursor(t *testing.T) {
@ -137,7 +137,7 @@ func TestReadWriteCursor(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
testKeyValues := []KV{ testKeyValues := []KV{
{"b", "1"}, {"b", "1"},
@ -149,24 +149,24 @@ func TestReadWriteCursor(t *testing.T) {
count := len(testKeyValues) count := len(testKeyValues)
// Pre-store the first half of the interval. // Pre-store the first half of the interval.
assert.NoError(t, db.Update(func(tx walletdb.ReadWriteTx) error { require.NoError(t, db.Update(func(tx walletdb.ReadWriteTx) error {
b, err := tx.CreateTopLevelBucket([]byte("apple")) b, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, b) require.NotNil(t, b)
for i := 0; i < count/2; i++ { for i := 0; i < count/2; i++ {
err = b.Put( err = b.Put(
[]byte(testKeyValues[i].key), []byte(testKeyValues[i].key),
[]byte(testKeyValues[i].val), []byte(testKeyValues[i].val),
) )
assert.NoError(t, err) require.NoError(t, err)
} }
return nil return nil
})) }))
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
b := tx.ReadWriteBucket([]byte("apple")) b := tx.ReadWriteBucket([]byte("apple"))
assert.NotNil(t, b) require.NotNil(t, b)
// Store the second half of the interval. // Store the second half of the interval.
for i := count / 2; i < count; i++ { for i := count / 2; i < count; i++ {
@ -174,77 +174,77 @@ func TestReadWriteCursor(t *testing.T) {
[]byte(testKeyValues[i].key), []byte(testKeyValues[i].key),
[]byte(testKeyValues[i].val), []byte(testKeyValues[i].val),
) )
assert.NoError(t, err) require.NoError(t, err)
} }
cursor := b.ReadWriteCursor() cursor := b.ReadWriteCursor()
// First on valid interval. // First on valid interval.
fk, fv := cursor.First() fk, fv := cursor.First()
assert.Equal(t, []byte("b"), fk) require.Equal(t, []byte("b"), fk)
assert.Equal(t, []byte("1"), fv) require.Equal(t, []byte("1"), fv)
// Prev(First()) = nil // Prev(First()) = nil
k, v := cursor.Prev() k, v := cursor.Prev()
assert.Nil(t, k) require.Nil(t, k)
assert.Nil(t, v) require.Nil(t, v)
// Last on valid interval. // Last on valid interval.
lk, lv := cursor.Last() lk, lv := cursor.Last()
assert.Equal(t, []byte("e"), lk) require.Equal(t, []byte("e"), lk)
assert.Equal(t, []byte("4"), lv) require.Equal(t, []byte("4"), lv)
// Next(Last()) = nil // Next(Last()) = nil
k, v = cursor.Next() k, v = cursor.Next()
assert.Nil(t, k) require.Nil(t, k)
assert.Nil(t, v) require.Nil(t, v)
// Delete first item, then add an item before the // Delete first item, then add an item before the
// deleted one. Check that First/Next will "jump" // deleted one. Check that First/Next will "jump"
// over the deleted item and return the new first. // over the deleted item and return the new first.
_, _ = cursor.First() _, _ = cursor.First()
assert.NoError(t, cursor.Delete()) require.NoError(t, cursor.Delete())
assert.NoError(t, b.Put([]byte("a"), []byte("0"))) require.NoError(t, b.Put([]byte("a"), []byte("0")))
fk, fv = cursor.First() fk, fv = cursor.First()
assert.Equal(t, []byte("a"), fk) require.Equal(t, []byte("a"), fk)
assert.Equal(t, []byte("0"), fv) require.Equal(t, []byte("0"), fv)
k, v = cursor.Next() k, v = cursor.Next()
assert.Equal(t, []byte("c"), k) require.Equal(t, []byte("c"), k)
assert.Equal(t, []byte("2"), v) require.Equal(t, []byte("2"), v)
// Similarly test that a new end is returned if // Similarly test that a new end is returned if
// the old end is deleted first. // the old end is deleted first.
_, _ = cursor.Last() _, _ = cursor.Last()
assert.NoError(t, cursor.Delete()) require.NoError(t, cursor.Delete())
assert.NoError(t, b.Put([]byte("f"), []byte("5"))) require.NoError(t, b.Put([]byte("f"), []byte("5")))
lk, lv = cursor.Last() lk, lv = cursor.Last()
assert.Equal(t, []byte("f"), lk) require.Equal(t, []byte("f"), lk)
assert.Equal(t, []byte("5"), lv) require.Equal(t, []byte("5"), lv)
k, v = cursor.Prev() k, v = cursor.Prev()
assert.Equal(t, []byte("da"), k) require.Equal(t, []byte("da"), k)
assert.Equal(t, []byte("3"), v) require.Equal(t, []byte("3"), v)
// Overwrite k/v in the middle of the interval. // Overwrite k/v in the middle of the interval.
assert.NoError(t, b.Put([]byte("c"), []byte("3"))) require.NoError(t, b.Put([]byte("c"), []byte("3")))
k, v = cursor.Prev() k, v = cursor.Prev()
assert.Equal(t, []byte("c"), k) require.Equal(t, []byte("c"), k)
assert.Equal(t, []byte("3"), v) require.Equal(t, []byte("3"), v)
// Insert new key/values. // Insert new key/values.
assert.NoError(t, b.Put([]byte("cx"), []byte("x"))) require.NoError(t, b.Put([]byte("cx"), []byte("x")))
assert.NoError(t, b.Put([]byte("cy"), []byte("y"))) require.NoError(t, b.Put([]byte("cy"), []byte("y")))
k, v = cursor.Next() k, v = cursor.Next()
assert.Equal(t, []byte("cx"), k) require.Equal(t, []byte("cx"), k)
assert.Equal(t, []byte("x"), v) require.Equal(t, []byte("x"), v)
k, v = cursor.Next() k, v = cursor.Next()
assert.Equal(t, []byte("cy"), k) require.Equal(t, []byte("cy"), k)
assert.Equal(t, []byte("y"), v) require.Equal(t, []byte("y"), v)
expected := []KV{ expected := []KV{
{"a", "0"}, {"a", "0"},
@ -263,7 +263,7 @@ func TestReadWriteCursor(t *testing.T) {
kvs = append(kvs, KV{string(k), string(v)}) kvs = append(kvs, KV{string(k), string(v)})
k, v = cursor.Next() k, v = cursor.Next()
} }
assert.Equal(t, expected, kvs) require.Equal(t, expected, kvs)
// Iterate from the back. // Iterate from the back.
kvs = []KV{} kvs = []KV{}
@ -273,12 +273,12 @@ func TestReadWriteCursor(t *testing.T) {
kvs = append(kvs, KV{string(k), string(v)}) kvs = append(kvs, KV{string(k), string(v)})
k, v = cursor.Prev() k, v = cursor.Prev()
} }
assert.Equal(t, reverseKVs(expected), kvs) require.Equal(t, reverseKVs(expected), kvs)
return nil return nil
}) })
assert.NoError(t, err) require.NoError(t, err)
expected := map[string]string{ expected := map[string]string{
bkey("apple"): bval("apple"), bkey("apple"): bval("apple"),
@ -289,5 +289,5 @@ func TestReadWriteCursor(t *testing.T) {
vkey("da", "apple"): "3", vkey("da", "apple"): "3",
vkey("f", "apple"): "5", vkey("f", "apple"): "5",
} }
assert.Equal(t, expected, f.Dump()) require.Equal(t, expected, f.Dump())
} }

View File

@ -6,7 +6,7 @@ import (
"testing" "testing"
"github.com/btcsuite/btcwallet/walletdb" "github.com/btcsuite/btcwallet/walletdb"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/require"
) )
func TestTxManualCommit(t *testing.T) { func TestTxManualCommit(t *testing.T) {
@ -16,11 +16,11 @@ func TestTxManualCommit(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
tx, err := db.BeginReadWriteTx() tx, err := db.BeginReadWriteTx()
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, tx) require.NotNil(t, tx)
committed := false committed := false
@ -29,24 +29,24 @@ func TestTxManualCommit(t *testing.T) {
}) })
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
assert.NoError(t, apple.Put([]byte("testKey"), []byte("testVal"))) require.NoError(t, apple.Put([]byte("testKey"), []byte("testVal")))
banana, err := tx.CreateTopLevelBucket([]byte("banana")) banana, err := tx.CreateTopLevelBucket([]byte("banana"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, banana) require.NotNil(t, banana)
assert.NoError(t, banana.Put([]byte("testKey"), []byte("testVal"))) require.NoError(t, banana.Put([]byte("testKey"), []byte("testVal")))
assert.NoError(t, tx.DeleteTopLevelBucket([]byte("banana"))) require.NoError(t, tx.DeleteTopLevelBucket([]byte("banana")))
assert.NoError(t, tx.Commit()) require.NoError(t, tx.Commit())
assert.True(t, committed) require.True(t, committed)
expected := map[string]string{ expected := map[string]string{
bkey("apple"): bval("apple"), bkey("apple"): bval("apple"),
vkey("testKey", "apple"): "testVal", vkey("testKey", "apple"): "testVal",
} }
assert.Equal(t, expected, f.Dump()) require.Equal(t, expected, f.Dump())
} }
func TestTxRollback(t *testing.T) { func TestTxRollback(t *testing.T) {
@ -56,21 +56,21 @@ func TestTxRollback(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
tx, err := db.BeginReadWriteTx() tx, err := db.BeginReadWriteTx()
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, tx) require.NotNil(t, tx)
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
assert.NoError(t, apple.Put([]byte("testKey"), []byte("testVal"))) require.NoError(t, apple.Put([]byte("testKey"), []byte("testVal")))
assert.NoError(t, tx.Rollback()) require.NoError(t, tx.Rollback())
assert.Error(t, walletdb.ErrTxClosed, tx.Commit()) require.Error(t, walletdb.ErrTxClosed, tx.Commit())
assert.Equal(t, map[string]string{}, f.Dump()) require.Equal(t, map[string]string{}, f.Dump())
} }
func TestChangeDuringManualTx(t *testing.T) { func TestChangeDuringManualTx(t *testing.T) {
@ -80,24 +80,24 @@ func TestChangeDuringManualTx(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
tx, err := db.BeginReadWriteTx() tx, err := db.BeginReadWriteTx()
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, tx) require.NotNil(t, tx)
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.Nil(t, err) require.Nil(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
assert.NoError(t, apple.Put([]byte("testKey"), []byte("testVal"))) require.NoError(t, apple.Put([]byte("testKey"), []byte("testVal")))
// Try overwriting the bucket key. // Try overwriting the bucket key.
f.Put(bkey("apple"), "banana") f.Put(bkey("apple"), "banana")
// TODO: translate error // TODO: translate error
assert.NotNil(t, tx.Commit()) require.NotNil(t, tx.Commit())
assert.Equal(t, map[string]string{ require.Equal(t, map[string]string{
bkey("apple"): "banana", bkey("apple"): "banana",
}, f.Dump()) }, f.Dump())
} }
@ -109,16 +109,16 @@ func TestChangeDuringUpdate(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
count := 0 count := 0
err = db.Update(func(tx walletdb.ReadWriteTx) error { err = db.Update(func(tx walletdb.ReadWriteTx) error {
apple, err := tx.CreateTopLevelBucket([]byte("apple")) apple, err := tx.CreateTopLevelBucket([]byte("apple"))
assert.NoError(t, err) require.NoError(t, err)
assert.NotNil(t, apple) require.NotNil(t, apple)
assert.NoError(t, apple.Put([]byte("key"), []byte("value"))) require.NoError(t, apple.Put([]byte("key"), []byte("value")))
if count == 0 { if count == 0 {
f.Put(vkey("key", "apple"), "new_value") f.Put(vkey("key", "apple"), "new_value")
@ -127,30 +127,30 @@ func TestChangeDuringUpdate(t *testing.T) {
cursor := apple.ReadCursor() cursor := apple.ReadCursor()
k, v := cursor.First() k, v := cursor.First()
assert.Equal(t, []byte("key"), k) require.Equal(t, []byte("key"), k)
assert.Equal(t, []byte("value"), v) require.Equal(t, []byte("value"), v)
assert.Equal(t, v, apple.Get([]byte("key"))) require.Equal(t, v, apple.Get([]byte("key")))
k, v = cursor.Next() k, v = cursor.Next()
if count == 0 { if count == 0 {
assert.Nil(t, k) require.Nil(t, k)
assert.Nil(t, v) require.Nil(t, v)
} else { } else {
assert.Equal(t, []byte("key2"), k) require.Equal(t, []byte("key2"), k)
assert.Equal(t, []byte("value2"), v) require.Equal(t, []byte("value2"), v)
} }
count++ count++
return nil return nil
}) })
assert.Nil(t, err) require.Nil(t, err)
assert.Equal(t, count, 2) require.Equal(t, count, 2)
expected := map[string]string{ expected := map[string]string{
bkey("apple"): bval("apple"), bkey("apple"): bval("apple"),
vkey("key", "apple"): "value", vkey("key", "apple"): "value",
vkey("key2", "apple"): "value2", vkey("key2", "apple"): "value2",
} }
assert.Equal(t, expected, f.Dump()) require.Equal(t, expected, f.Dump())
} }

View File

@ -6,7 +6,7 @@ import (
"errors" "errors"
"testing" "testing"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/require"
) )
func reverseKVs(a []KV) []KV { func reverseKVs(a []KV) []KV {
@ -24,7 +24,7 @@ func TestPutToEmpty(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
apply := func(stm STM) error { apply := func(stm STM) error {
stm.Put("123", "abc") stm.Put("123", "abc")
@ -32,9 +32,9 @@ func TestPutToEmpty(t *testing.T) {
} }
err = RunSTM(db.cli, apply) err = RunSTM(db.cli, apply)
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, "abc", f.Get("123")) require.Equal(t, "abc", f.Get("123"))
} }
func TestGetPutDel(t *testing.T) { func TestGetPutDel(t *testing.T) {
@ -56,64 +56,64 @@ func TestGetPutDel(t *testing.T) {
} }
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
apply := func(stm STM) error { apply := func(stm STM) error {
// Get some non existing keys. // Get some non existing keys.
v, err := stm.Get("") v, err := stm.Get("")
assert.NoError(t, err) require.NoError(t, err)
assert.Nil(t, v) require.Nil(t, v)
v, err = stm.Get("x") v, err = stm.Get("x")
assert.NoError(t, err) require.NoError(t, err)
assert.Nil(t, v) require.Nil(t, v)
// Get all existing keys. // Get all existing keys.
for _, kv := range testKeyValues { for _, kv := range testKeyValues {
v, err = stm.Get(kv.key) v, err = stm.Get(kv.key)
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, []byte(kv.val), v) require.Equal(t, []byte(kv.val), v)
} }
// Overwrite, then delete an existing key. // Overwrite, then delete an existing key.
stm.Put("c", "6") stm.Put("c", "6")
v, err = stm.Get("c") v, err = stm.Get("c")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, []byte("6"), v) require.Equal(t, []byte("6"), v)
stm.Del("c") stm.Del("c")
v, err = stm.Get("c") v, err = stm.Get("c")
assert.NoError(t, err) require.NoError(t, err)
assert.Nil(t, v) require.Nil(t, v)
// Re-add the deleted key. // Re-add the deleted key.
stm.Put("c", "7") stm.Put("c", "7")
v, err = stm.Get("c") v, err = stm.Get("c")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, []byte("7"), v) require.Equal(t, []byte("7"), v)
// Add a new key. // Add a new key.
stm.Put("x", "x") stm.Put("x", "x")
v, err = stm.Get("x") v, err = stm.Get("x")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, []byte("x"), v) require.Equal(t, []byte("x"), v)
return nil return nil
} }
err = RunSTM(db.cli, apply) err = RunSTM(db.cli, apply)
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, "1", f.Get("a")) require.Equal(t, "1", f.Get("a"))
assert.Equal(t, "2", f.Get("b")) require.Equal(t, "2", f.Get("b"))
assert.Equal(t, "7", f.Get("c")) require.Equal(t, "7", f.Get("c"))
assert.Equal(t, "4", f.Get("d")) require.Equal(t, "4", f.Get("d"))
assert.Equal(t, "5", f.Get("e")) require.Equal(t, "5", f.Get("e"))
assert.Equal(t, "x", f.Get("x")) require.Equal(t, "x", f.Get("x"))
} }
func TestFirstLastNextPrev(t *testing.T) { func TestFirstLastNextPrev(t *testing.T) {
@ -134,44 +134,44 @@ func TestFirstLastNextPrev(t *testing.T) {
} }
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
apply := func(stm STM) error { apply := func(stm STM) error {
// First/Last on valid multi item interval. // First/Last on valid multi item interval.
kv, err := stm.First("k") kv, err := stm.First("k")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"kb", "1"}, kv) require.Equal(t, &KV{"kb", "1"}, kv)
kv, err = stm.Last("k") kv, err = stm.Last("k")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"ke", "4"}, kv) require.Equal(t, &KV{"ke", "4"}, kv)
// First/Last on single item interval. // First/Last on single item interval.
kv, err = stm.First("w") kv, err = stm.First("w")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"w", "w"}, kv) require.Equal(t, &KV{"w", "w"}, kv)
kv, err = stm.Last("w") kv, err = stm.Last("w")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"w", "w"}, kv) require.Equal(t, &KV{"w", "w"}, kv)
// Next/Prev on start/end. // Next/Prev on start/end.
kv, err = stm.Next("k", "ke") kv, err = stm.Next("k", "ke")
assert.NoError(t, err) require.NoError(t, err)
assert.Nil(t, kv) require.Nil(t, kv)
kv, err = stm.Prev("k", "kb") kv, err = stm.Prev("k", "kb")
assert.NoError(t, err) require.NoError(t, err)
assert.Nil(t, kv) require.Nil(t, kv)
// Next/Prev in the middle. // Next/Prev in the middle.
kv, err = stm.Next("k", "kc") kv, err = stm.Next("k", "kc")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"kda", "3"}, kv) require.Equal(t, &KV{"kda", "3"}, kv)
kv, err = stm.Prev("k", "ke") kv, err = stm.Prev("k", "ke")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"kda", "3"}, kv) require.Equal(t, &KV{"kda", "3"}, kv)
// Delete first item, then add an item before the // Delete first item, then add an item before the
// deleted one. Check that First/Next will "jump" // deleted one. Check that First/Next will "jump"
@ -180,12 +180,12 @@ func TestFirstLastNextPrev(t *testing.T) {
stm.Put("ka", "0") stm.Put("ka", "0")
kv, err = stm.First("k") kv, err = stm.First("k")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"ka", "0"}, kv) require.Equal(t, &KV{"ka", "0"}, kv)
kv, err = stm.Prev("k", "kc") kv, err = stm.Prev("k", "kc")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"ka", "0"}, kv) require.Equal(t, &KV{"ka", "0"}, kv)
// Similarly test that a new end is returned if // Similarly test that a new end is returned if
// the old end is deleted first. // the old end is deleted first.
@ -193,19 +193,19 @@ func TestFirstLastNextPrev(t *testing.T) {
stm.Put("kf", "5") stm.Put("kf", "5")
kv, err = stm.Last("k") kv, err = stm.Last("k")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"kf", "5"}, kv) require.Equal(t, &KV{"kf", "5"}, kv)
kv, err = stm.Next("k", "kda") kv, err = stm.Next("k", "kda")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"kf", "5"}, kv) require.Equal(t, &KV{"kf", "5"}, kv)
// Overwrite one in the middle. // Overwrite one in the middle.
stm.Put("kda", "6") stm.Put("kda", "6")
kv, err = stm.Next("k", "kc") kv, err = stm.Next("k", "kc")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, &KV{"kda", "6"}, kv) require.Equal(t, &KV{"kda", "6"}, kv)
// Add three in the middle, then delete one. // Add three in the middle, then delete one.
stm.Put("kdb", "7") stm.Put("kdb", "7")
@ -218,12 +218,12 @@ func TestFirstLastNextPrev(t *testing.T) {
var kvs []KV var kvs []KV
curr, err := stm.First("k") curr, err := stm.First("k")
assert.NoError(t, err) require.NoError(t, err)
for curr != nil { for curr != nil {
kvs = append(kvs, *curr) kvs = append(kvs, *curr)
curr, err = stm.Next("k", curr.key) curr, err = stm.Next("k", curr.key)
assert.NoError(t, err) require.NoError(t, err)
} }
expected := []KV{ expected := []KV{
@ -234,37 +234,37 @@ func TestFirstLastNextPrev(t *testing.T) {
{"kdd", "9"}, {"kdd", "9"},
{"kf", "5"}, {"kf", "5"},
} }
assert.Equal(t, expected, kvs) require.Equal(t, expected, kvs)
// Similarly check that stepping from last to first // Similarly check that stepping from last to first
// returns the expected sequence. // returns the expected sequence.
kvs = []KV{} kvs = []KV{}
curr, err = stm.Last("k") curr, err = stm.Last("k")
assert.NoError(t, err) require.NoError(t, err)
for curr != nil { for curr != nil {
kvs = append(kvs, *curr) kvs = append(kvs, *curr)
curr, err = stm.Prev("k", curr.key) curr, err = stm.Prev("k", curr.key)
assert.NoError(t, err) require.NoError(t, err)
} }
expected = reverseKVs(expected) expected = reverseKVs(expected)
assert.Equal(t, expected, kvs) require.Equal(t, expected, kvs)
return nil return nil
} }
err = RunSTM(db.cli, apply) err = RunSTM(db.cli, apply)
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, "0", f.Get("ka")) require.Equal(t, "0", f.Get("ka"))
assert.Equal(t, "2", f.Get("kc")) require.Equal(t, "2", f.Get("kc"))
assert.Equal(t, "6", f.Get("kda")) require.Equal(t, "6", f.Get("kda"))
assert.Equal(t, "7", f.Get("kdb")) require.Equal(t, "7", f.Get("kdb"))
assert.Equal(t, "9", f.Get("kdd")) require.Equal(t, "9", f.Get("kdd"))
assert.Equal(t, "5", f.Get("kf")) require.Equal(t, "5", f.Get("kf"))
assert.Equal(t, "w", f.Get("w")) require.Equal(t, "w", f.Get("w"))
} }
func TestCommitError(t *testing.T) { func TestCommitError(t *testing.T) {
@ -274,7 +274,7 @@ func TestCommitError(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
// Preset DB state. // Preset DB state.
f.Put("123", "xyz") f.Put("123", "xyz")
@ -285,10 +285,10 @@ func TestCommitError(t *testing.T) {
apply := func(stm STM) error { apply := func(stm STM) error {
// STM must have the key/value. // STM must have the key/value.
val, err := stm.Get("123") val, err := stm.Get("123")
assert.NoError(t, err) require.NoError(t, err)
if cnt == 0 { if cnt == 0 {
assert.Equal(t, []byte("xyz"), val) require.Equal(t, []byte("xyz"), val)
// Put a conflicting key/value during the first apply. // Put a conflicting key/value during the first apply.
f.Put("123", "def") f.Put("123", "def")
@ -302,10 +302,10 @@ func TestCommitError(t *testing.T) {
} }
err = RunSTM(db.cli, apply) err = RunSTM(db.cli, apply)
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, 2, cnt) require.Equal(t, 2, cnt)
assert.Equal(t, "abc", f.Get("123")) require.Equal(t, "abc", f.Get("123"))
} }
func TestManualTxError(t *testing.T) { func TestManualTxError(t *testing.T) {
@ -315,7 +315,7 @@ func TestManualTxError(t *testing.T) {
defer f.Cleanup() defer f.Cleanup()
db, err := newEtcdBackend(f.BackendConfig()) db, err := newEtcdBackend(f.BackendConfig())
assert.NoError(t, err) require.NoError(t, err)
// Preset DB state. // Preset DB state.
f.Put("123", "xyz") f.Put("123", "xyz")
@ -323,22 +323,22 @@ func TestManualTxError(t *testing.T) {
stm := NewSTM(db.cli) stm := NewSTM(db.cli)
val, err := stm.Get("123") val, err := stm.Get("123")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, []byte("xyz"), val) require.Equal(t, []byte("xyz"), val)
// Put a conflicting key/value. // Put a conflicting key/value.
f.Put("123", "def") f.Put("123", "def")
// Should still get the original version. // Should still get the original version.
val, err = stm.Get("123") val, err = stm.Get("123")
assert.NoError(t, err) require.NoError(t, err)
assert.Equal(t, []byte("xyz"), val) require.Equal(t, []byte("xyz"), val)
// Commit will fail with CommitError. // Commit will fail with CommitError.
err = stm.Commit() err = stm.Commit()
var e CommitError var e CommitError
assert.True(t, errors.As(err, &e)) require.True(t, errors.As(err, &e))
// We expect that the transacton indeed did not commit. // We expect that the transacton indeed did not commit.
assert.Equal(t, "def", f.Get("123")) require.Equal(t, "def", f.Get("123"))
} }