Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: state migration from IAVL to SMT (ADR-040) #10962

Merged
merged 41 commits into from
Mar 20, 2022
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
4cc992f
feat: add migration for adr40
Jan 18, 2022
df0dc4f
chore: removed sort from migration func
Jan 19, 2022
fca170d
Merge branch 'master' into sai/migration_for_adr40
gsk967 Jan 21, 2022
79583ec
chore: address the pr comments
Jan 27, 2022
bcfeff1
Merge branch 'sai/migration_for_adr40' of github.com:vulcanize/cosmos…
Jan 27, 2022
d511fa3
Merge branch 'master' into sai/migration_for_adr40
gsk967 Jan 27, 2022
00b99a7
Merge branch 'master' into sai/migration_for_adr40
gsk967 Jan 27, 2022
0eaec31
Merge branch 'master' into sai/migration_for_adr40
gsk967 Jan 28, 2022
9f496e9
test: add test for migrationv2
Jan 29, 2022
39b303b
Merge branch 'master' into sai/migration_for_adr40
gsk967 Jan 29, 2022
8b16dad
Merge branch 'master' into sai/migration_for_adr40
gsk967 Jan 31, 2022
b305280
chore: change the `MigrationV2`
Jan 31, 2022
ebc1d3b
Merge branch 'master' into sai/migration_for_adr40
gsk967 Jan 31, 2022
64e1cb4
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 1, 2022
39d51cf
chore: refactored the migrationV2
Feb 1, 2022
242939e
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 1, 2022
a9fa647
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 2, 2022
ada2859
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 3, 2022
38527f7
chore: address the pr review comments
Feb 15, 2022
1e884cf
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 15, 2022
1b79269
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 17, 2022
00b6360
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 22, 2022
dc57212
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 25, 2022
4695365
fix: fix the build issue
Feb 25, 2022
3a5bdf0
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 25, 2022
c103f16
Merge branch 'master' into sai/migration_for_adr40
gsk967 Feb 28, 2022
4a9feb5
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 4, 2022
677639e
chore: address the pr comments
Mar 4, 2022
074da95
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 4, 2022
a05f72e
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 6, 2022
6eb51d1
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 9, 2022
c16dc89
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 10, 2022
119b77a
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 11, 2022
a97ed5a
address the pr comments
Mar 11, 2022
179743c
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 15, 2022
bb61b5d
address the pr comments
Mar 15, 2022
f381e09
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 16, 2022
7eec931
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 17, 2022
1af9b3b
chore: update changelog
Mar 17, 2022
ec331a0
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 18, 2022
e21a6f8
Merge branch 'master' into sai/migration_for_adr40
gsk967 Mar 20, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
64 changes: 35 additions & 29 deletions store/v2/multi/migration.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package root
gsk967 marked this conversation as resolved.
Show resolved Hide resolved

import (
prefixdb "github.com/cosmos/cosmos-sdk/db/prefix"
dbm "github.com/cosmos/cosmos-sdk/db"
"github.com/cosmos/cosmos-sdk/store/iavl"
"github.com/cosmos/cosmos-sdk/store/mem"
v1Store "github.com/cosmos/cosmos-sdk/store/rootmulti"
Expand All @@ -11,44 +11,50 @@ import (
)

// MigrateV2 will migrate the state from iavl to smt
func MigrateV2(rs *v1Store.Store, rootStore *Store) error {
if len(rootStore.schema) != 0 {
// schema already exists
return sdkerrors.Wrapf(sdkerrors.ErrLogic, "smt store already have schema")
func MigrateV2(rs *v1Store.Store, db dbm.DBConnection, storeConfig StoreConfig) (*Store, error) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit - let's named these stores better, rs vs rootstore isn't so clear

type namedStore struct {
*iavl.Store
name string
}

// set the schema to smt store
schemaWriter := prefixdb.NewPrefixWriter(rootStore.stateTxn, schemaPrefix)

var stores []namedStore
for key := range rs.GetStores() {
switch store := rs.GetCommitKVStore(key).(type) {
case *iavl.Store:
rootStore.schema[key.Name()] = types.StoreTypePersistent
err := schemaWriter.Set([]byte(key.Name()), []byte{byte(types.StoreTypePersistent)})
if err != nil {
return sdkerrors.Wrap(err, "error at set the store schema key values")
}

subStore, err := rootStore.getSubstore(key.Name())
if err != nil {
return err
}
// iterate all iavl tree node key/values
iterator := store.Iterator(nil, nil)
for ; iterator.Valid(); iterator.Next() {
// set the iavl key,values into smt node
subStore.Set(iterator.Key(), iterator.Value())
}

storeConfig.prefixRegistry.StoreSchema[key.Name()] = types.StoreTypePersistent
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
storeConfig.prefixRegistry.StoreSchema[key.Name()] = types.StoreTypePersistent
err = storeConfig.RegisterSubstore(key.Name(), types.StoreTypePersistent)
if err !=nil{return err}

otherwise we skip the conflict check

stores = append(stores, namedStore{name: key.Name(), Store: store})
case *transient.Store, *mem.Store:
// Non-persisted stores shouldn't be snapshotted
continue
default:
continue
return nil, sdkerrors.Wrapf(sdkerrors.ErrLogic, "don't know how to snapshot store %q of type %T", key.Name(), store)
}
}

// creating the new store of smt tree
rootStore, err := NewStore(db, storeConfig)
if err != nil {
return nil, err
}

// iterate through the rootmulti stores and save the key/values into smt tree
for _, store := range stores {
subStore, err := rootStore.getSubstore(store.name)
Copy link
Collaborator

@robert-zaremba robert-zaremba Mar 11, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

shouldn't we make sure that we use the same store key when doing migration?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

if err != nil {
return nil, err
}
// iterate all iavl tree node key/values
iterator := store.Iterator(nil, nil)
for ; iterator.Valid(); iterator.Next() {
// set the iavl key,values into smt node
subStore.Set(iterator.Key(), iterator.Value())
}
}

// commit the all key/values from iavl to smt tree (SMT Store)
rootStore.Commit()
_, err = rootStore.commit(uint64(rs.LastCommitID().Version))
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this will fail when version = 0. Let's check for that case and short circuit, just returning a new empty store

if err != nil {
return nil, err
}

return nil
return rootStore, nil
}
7 changes: 3 additions & 4 deletions store/v2/multi/migration_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,16 +23,15 @@ func TestMigrationV2(t *testing.T) {
// setup a temporary test data
v1StoreKVStore := v1Store.GetKVStore(kvStoreKey)
v1StoreKVStore.Set([]byte("temp_data"), []byte("one"))
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

let's add records to multiple stores.

v1Store.Commit()

// setup a new root store of smt
db2 := memdb.NewDB()
v2Store, err := NewStore(db2, DefaultStoreConfig())
require.Nil(t, err)

// migrating the iavl store (v1) to smt store (v2)
err = MigrateV2(v1Store, v2Store)
v2Store, err := MigrateV2(v1Store, db2, DefaultStoreConfig())
require.NoError(t, err)

v2StoreKVStore := v2Store.GetKVStore(kvStoreKey)
require.Equal(t, v2StoreKVStore.Get([]byte("temp_data")), []byte("one"))
require.Equal(t, v2Store.LastCommitID().Version,v1Store.LastCommitID().Version)
}
robert-zaremba marked this conversation as resolved.
Show resolved Hide resolved