package hash import ( "testing" "github.com/nspcc-dev/neo-go/pkg/util" "github.com/stretchr/testify/assert" "github.com/stretchr/testify/require" ) func testComputeMerkleTree(t *testing.T, hexHashes []string, result string) { hashes := make([]util.Uint256, len(hexHashes)) for i, str := range hexHashes { hash, err := util.Uint256DecodeStringLE(str) require.NoError(t, err) hashes[i] = hash } merkle, err := NewMerkleTree(hashes) require.NoError(t, err) optimized := CalcMerkleRoot(hashes) assert.Equal(t, result, optimized.StringLE()) assert.Equal(t, result, merkle.Root().StringLE()) assert.Equal(t, true, merkle.root.IsRoot()) assert.Equal(t, false, merkle.root.IsLeaf()) leaf := merkle.root for leaf.leftChild != nil || leaf.rightChild != nil { if leaf.leftChild != nil { leaf = leaf.leftChild continue } leaf = leaf.rightChild } assert.Equal(t, true, leaf.IsLeaf()) assert.Equal(t, false, leaf.IsRoot()) } func TestComputeMerkleTree1(t *testing.T) { // Mainnet block #0 rawHashes := []string{ "fb5bd72b2d6792d75dc2f1084ffa9e9f70ca85543c717a6b13d9959b452a57d6", "c56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b", "602c79718b16e442de58778e148d0b1084e3b2dffd5de6b7b16cee7969282de7", "3631f66024ca6f5b033d7e0809eb993443374830025af904fb51b0334f127cda", } res := "803ff4abe3ea6533bcc0be574efa02f83ae8fdc651c879056b0d9be336c01bf4" testComputeMerkleTree(t, rawHashes, res) } func TestComputeMerkleTree2(t *testing.T) { // Mainnet block #4635525 rawHashes := []string{ "c832ef573136eae2c57a35989d3fb9b3a135d08ffa0faa49d8766f7c1a92ca0f", "b8606dfeb126a5963d6674f8dbfb786db7f6c27800167c3eef56ff7110ff0ffc", "498a5d58179002dd9db7b23df657ecf7e1b2e8218bd48dda035e5accc664830a", "5c350282b448c139adb1f5e3fba0e9326476a38c01ea88876ebc4a882c472d42", "cea31cc85e7310183561d4f420026984ba48354516f9274c44b52c7f9a5c6107", "744f985dd5ad6f4ad6376376b48552abf7755b2ebc5c6271950714f848d1cc3a", "02c5fc225b6ead91f73a7b3ebb19bb30a113baea60f439b654c2811d630a2c48", "2b3478e0fa91db3a309caeb4d9739f38233c1c189d6fa7e159e24afce9fae082", "4d50693cee3ac2c976c092620834d4da264583cf15a1d11dd65d0e94861d49e0", "5f179efae999f8f8086269cedd1fbfaf6e90aadf5369a12737db0fff5905b12e", "6ef2237b6c8683f626269027050c45cc4be89042ee99e4e89bfd9d9fbd24da19", "6fd5154af55b4a1e4a1a5272e33238b2a2da12a30fa06af4f740d207e54ed495", } res := "42489ad8043a834149cd8e406c90c61411a05a0ca9f8e921b456a00b5d5988d7" testComputeMerkleTree(t, rawHashes, res) } func TestComputeMerkleTree3(t *testing.T) { // Mainnet block #2097152 rawHashes := []string{ "a7ff2c6aa08d4b979d5f7605aec5a1783c9207c738b5852ed5ff17b37ada649d", "34fd42c1f47aa306ad2fd0fc04437fd5c828a25b3de59e73b18157253094a8da", "36458dffd678d9f75ed9f2a28beb58bf1ad739f8899469b8641b0ddea22fcf5d", "3e8144abe2edda263593f24defd4557d403efa1b4fa839409ac217d6f8a87d3a", "a1d2cf73841fefcd21ca9986c664518d2af61edcfe3a97b30b3cc58fab4e61f6", "c1e868aef0e8fd76b95a18e155b1fa65f30d0a4887bc953411553728664725bc", "52d2fda0fe0fd586063d801c5ba77ca123a790d7e4dae34c53398feab36da721", "fdf8d4610cb2de35ab4c18d38357b86c52966d149c8975906170dc513cc26345", "35a26a11ef65d8f7a2424f7ce5915aa1d8bf3449018516003799767c2696197e", "c9d251abfc20a0d6eeac2d5a93b77a6a0632a679a07decea2c809aead89bb503", "d92c72873f2929c621ec06433da3053db25ee396b70c83d53abd40801823f66c", } res := "09c2dbc88810c350a2e7ace56bb1b371b2a2b5c4744e7a303adace9a2c2bbf6d" testComputeMerkleTree(t, rawHashes, res) } func TestNewMerkleTreeFailWithoutHashes(t *testing.T) { var hashes []util.Uint256 _, err := NewMerkleTree(hashes) require.Error(t, err) hashes = make([]util.Uint256, 0) _, err = NewMerkleTree(hashes) require.Error(t, err) } func TestBuildMerkleTreeWithoutNodes(t *testing.T) { var leaves []*MerkleTreeNode require.Panics(t, func() { buildMerkleTree(leaves) }) leaves = make([]*MerkleTreeNode, 0) require.Panics(t, func() { buildMerkleTree(leaves) }) }