prysm-pulse/shared/hashutil/merkleRoot_test.go

32 lines
707 B
Go
Raw Normal View History

package hashutil_test
import (
"bytes"
"testing"
"github.com/prysmaticlabs/prysm/shared/hashutil"
)
func TestMerkleRoot(t *testing.T) {
valueSet := [][]byte{
{'a'},
{'b'},
{'c'},
{'d'},
}
hashedV1 := []byte{'a'}
hashedV2 := []byte{'b'}
hashedV3 := []byte{'c'}
hashedV4 := []byte{'d'}
2018-12-30 11:03:36 +08:00
leftNode := hashutil.Hash(append(hashedV1[:], hashedV2[:]...))
rightNode := hashutil.Hash(append(hashedV3[:], hashedV4[:]...))
expectedRoot := hashutil.Hash(append(leftNode[:], rightNode[:]...))
if !bytes.Equal(expectedRoot[:], hashutil.MerkleRoot(valueSet)) {
t.Errorf("Expected Merkle root and computed merkle root are not equal %#x , %#x", expectedRoot, hashutil.MerkleRoot(valueSet))
}
}