From 3fed7b8eec0c0484735362708489936dcf369475 Mon Sep 17 00:00:00 2001 From: AnnaShaleva Date: Wed, 27 Oct 2021 18:36:40 +0300 Subject: [PATCH] core: handle empty MPT batch properly It's OK to have it. --- pkg/core/mpt/batch.go | 3 +++ pkg/core/mpt/batch_test.go | 2 ++ 2 files changed, 5 insertions(+) diff --git a/pkg/core/mpt/batch.go b/pkg/core/mpt/batch.go index d2b0349ac..11f26752c 100644 --- a/pkg/core/mpt/batch.go +++ b/pkg/core/mpt/batch.go @@ -43,6 +43,9 @@ func (b *Batch) Add(key []byte, value []byte) { // and won't strip the resulting branch node. // However it is used mostly after the block processing to update MPT and error is not expected. func (t *Trie) PutBatch(b Batch) (int, error) { + if len(b.kv) == 0 { + return 0, nil + } r, n, err := t.putBatch(b.kv) t.root = r return n, err diff --git a/pkg/core/mpt/batch_test.go b/pkg/core/mpt/batch_test.go index 8e27f00a4..6d763b61e 100644 --- a/pkg/core/mpt/batch_test.go +++ b/pkg/core/mpt/batch_test.go @@ -329,6 +329,8 @@ func TestTrie_PutBatch(t *testing.T) { ps = pairs{[2][]byte{{4}, nil}} testPut(t, ps, tr1, tr2) + + testPut(t, pairs{}, tr1, tr2) } var _ = printNode