erigon-pulse/ethdb/kv_migrator_test.go
Alex Sharov 49351b0091
KV: to support multiple databases and multiple set of buckets (#1002)
* don't use global variables

* up deps

* clean

* use joined flags

* use single non-global buckets config

* clean

* copy map

* fix tests

* fix tests

* clean

* clean
2020-08-30 18:34:18 +01:00

75 lines
1.9 KiB
Go

package ethdb
import (
"context"
"errors"
"github.com/ledgerwatch/lmdb-go/lmdb"
"github.com/ledgerwatch/turbo-geth/common/dbutils"
"github.com/stretchr/testify/require"
"testing"
)
func TestBucketCRUD(t *testing.T) {
require := require.New(t)
kv := NewLMDB().InMem().MustOpen()
defer kv.Close()
ctx := context.Background()
tx, err := kv.Begin(ctx, nil, true)
require.NoError(err)
defer tx.Rollback()
normalBucket := dbutils.Buckets[15]
deprecatedBucket := dbutils.DeprecatedBuckets[0]
migrator, ok := tx.(BucketMigrator)
if !ok {
return
}
// check thad buckets have unique DBI's
uniquness := map[lmdb.DBI]bool{}
castedKv := kv.(*LmdbKV)
for _, bucketCfg := range castedKv.buckets {
if bucketCfg.DBI == NonExistingDBI {
continue
}
_, ok := uniquness[bucketCfg.DBI]
require.False(ok)
uniquness[bucketCfg.DBI] = true
}
require.True(migrator.ExistsBucket(normalBucket))
require.True(errors.Is(migrator.DropBucket(normalBucket), ErrAttemptToDeleteNonDeprecatedBucket))
require.False(migrator.ExistsBucket(deprecatedBucket))
require.NoError(migrator.CreateBucket(deprecatedBucket))
require.True(migrator.ExistsBucket(deprecatedBucket))
require.NoError(migrator.DropBucket(deprecatedBucket))
require.False(migrator.ExistsBucket(deprecatedBucket))
require.NoError(migrator.CreateBucket(deprecatedBucket))
require.True(migrator.ExistsBucket(deprecatedBucket))
err = tx.Cursor(deprecatedBucket).Put([]byte{1}, []byte{1})
require.NoError(err)
v, err := tx.Get(deprecatedBucket, []byte{1})
require.NoError(err)
require.Equal([]byte{1}, v)
buckets, err := migrator.ExistingBuckets()
require.NoError(err)
require.True(len(buckets) > 10)
// check thad buckets have unique DBI's
uniquness = map[lmdb.DBI]bool{}
for _, bucketCfg := range castedKv.buckets {
if bucketCfg.DBI == NonExistingDBI {
continue
}
_, ok := uniquness[bucketCfg.DBI]
require.False(ok)
uniquness[bucketCfg.DBI] = true
}
}