Merge pull request #21023 from karalabe/snapshot-verify-iterator-release

core/state/snapshot: release iterator after verification
This commit is contained in:
Péter Szilágyi 2020-05-04 17:10:17 +03:00 committed by GitHub
commit 587656619d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 5 additions and 1 deletions

View File

@ -63,11 +63,15 @@ func VerifyState(snaptree *Tree, root common.Hash) error {
if err != nil {
return err
}
defer acctIt.Release()
got, err := generateTrieRoot(acctIt, common.Hash{}, stdGenerate, func(account common.Hash, stat *generateStats) common.Hash {
storageIt, err := snaptree.StorageIterator(root, account, common.Hash{})
if err != nil {
return common.Hash{}
}
defer storageIt.Release()
hash, err := generateTrieRoot(storageIt, account, stdGenerate, nil, stat, false)
if err != nil {
return common.Hash{}
@ -79,7 +83,7 @@ func VerifyState(snaptree *Tree, root common.Hash) error {
return err
}
if got != root {
return fmt.Errorf("State root hash mismatch, got %x, want %x", got, root)
return fmt.Errorf("state root hash mismatch: got %x, want %x", got, root)
}
return nil
}