erigon-pulse/cl/merkle_tree/merkle_root_test.go

52 lines
1.9 KiB
Go
Raw Normal View History

package merkle_tree_test
import (
"testing"
libcommon "github.com/ledgerwatch/erigon-lib/common"
"github.com/stretchr/testify/require"
"github.com/ledgerwatch/erigon/cl/merkle_tree"
"github.com/ledgerwatch/erigon/cmd/erigon-cl/core/state/state_encoding"
)
func TestEmptyArraysRoot(t *testing.T) {
expected := libcommon.HexToHash("df6af5f5bbdb6be9ef8aa618e4bf8073960867171e29676f8b284dea6a08a85e")
root, err := merkle_tree.ArraysRoot([][32]byte{}, state_encoding.StateRootsLength)
require.NoError(t, err)
require.Equal(t, expected, libcommon.Hash(root))
}
func TestEmptyArraysWithLengthRoot(t *testing.T) {
expected := libcommon.HexToHash("0xf770287da731841c38eb035da016bd2daad53bf0bca607461c0685b0ea54c5f9")
roots := [][32]byte{
libcommon.BytesToHash([]byte{1}),
libcommon.BytesToHash([]byte{2}),
libcommon.BytesToHash([]byte{3}),
libcommon.BytesToHash([]byte{4}),
libcommon.BytesToHash([]byte{5}),
libcommon.BytesToHash([]byte{6}),
libcommon.BytesToHash([]byte{7}),
libcommon.BytesToHash([]byte{8}),
}
root, err := merkle_tree.ArraysRootWithLimit(roots, 8192)
require.NoError(t, err)
require.Equal(t, expected, libcommon.Hash(root))
}
func TestUint64ListRootWithLimit(t *testing.T) {
expected := libcommon.HexToHash("0xfbe583f8fbcc3683d98c12ae969e93aaa5ac472e15422c14759cb7f3ef60673c")
nums := []uint64{1, 2, 4, 5, 2, 5, 6, 7, 1, 4, 3, 5, 100, 6, 64, 2}
root, err := merkle_tree.Uint64ListRootWithLimit(nums, 274877906944)
require.NoError(t, err)
require.Equal(t, expected, libcommon.Hash(root))
}
func TestParticipationBitsRoot(t *testing.T) {
expected := libcommon.HexToHash("0x8e6653ba3656afddaf5e6c69c149e63a2e26ff91a2e361b3c40b11f08c039572")
bits := []byte{1, 2, 4, 5, 2, 5, 6, 7, 1, 4, 3, 5, 100, 6, 64, 2}
root, err := merkle_tree.BitlistRootWithLimitForState(bits, 1099511627776)
require.NoError(t, err)
require.Equal(t, expected, libcommon.Hash(root))
}