2019-01-31 02:53:58 +00:00
|
|
|
package trieutil
|
2019-01-11 08:29:30 +00:00
|
|
|
|
|
|
|
import (
|
2019-02-08 17:01:15 +00:00
|
|
|
"encoding/binary"
|
2019-01-11 08:29:30 +00:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/hashutil"
|
|
|
|
)
|
|
|
|
|
2019-02-22 15:11:26 +00:00
|
|
|
func TestDepositTrie_UpdateDeposit(t *testing.T) {
|
2019-01-11 08:29:30 +00:00
|
|
|
tests := []struct {
|
|
|
|
deposits [][]byte
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
[][]byte{
|
|
|
|
{1, 2, 3, 4},
|
|
|
|
{5, 6, 7, 8},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
[][]byte{
|
|
|
|
{0, 0, 0, 0},
|
|
|
|
{0, 0, 0, 0},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
d := NewDepositTrie()
|
|
|
|
d.UpdateDepositTrie(tt.deposits[0])
|
|
|
|
if d.depositCount != 1 {
|
|
|
|
t.Errorf("Expected deposit count to increase by 1, received %d", d.depositCount)
|
|
|
|
}
|
2019-02-08 17:01:15 +00:00
|
|
|
|
|
|
|
hashedData := hashutil.Hash(tt.deposits[0])
|
|
|
|
|
|
|
|
for i := 0; i < 32; i++ {
|
|
|
|
hashedData = hashutil.Hash(append(hashedData[:], d.zeroHashes[i][:]...))
|
|
|
|
}
|
|
|
|
if d.Root() != hashedData {
|
|
|
|
t.Errorf("Expected %#x but got %#x", hashedData, d.Root())
|
|
|
|
}
|
|
|
|
|
2019-01-11 08:29:30 +00:00
|
|
|
d.UpdateDepositTrie(tt.deposits[1])
|
|
|
|
if d.depositCount != 2 {
|
|
|
|
t.Errorf("Expected deposit count to increase by 1, received %d", d.depositCount)
|
|
|
|
}
|
2019-02-08 17:01:15 +00:00
|
|
|
|
|
|
|
hash1 := hashutil.Hash(tt.deposits[0])
|
|
|
|
hash2 := hashutil.Hash(tt.deposits[1])
|
|
|
|
|
|
|
|
hashedData = hashutil.Hash(append(hash1[:], hash2[:]...))
|
|
|
|
|
|
|
|
for i := 0; i < 31; i++ {
|
|
|
|
hashedData = hashutil.Hash(append(hashedData[:], d.zeroHashes[i+1][:]...))
|
2019-01-11 08:29:30 +00:00
|
|
|
}
|
2019-02-08 17:01:15 +00:00
|
|
|
if d.Root() != hashedData {
|
|
|
|
t.Errorf("Expected %#x but got %#x", hashedData, d.Root())
|
|
|
|
}
|
|
|
|
|
2019-01-11 08:29:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-22 15:11:26 +00:00
|
|
|
func TestVerifyMerkleBranch_OK(t *testing.T) {
|
2019-01-11 08:29:30 +00:00
|
|
|
d := NewDepositTrie()
|
|
|
|
deposit1 := []byte{1, 2, 3}
|
|
|
|
d.UpdateDepositTrie(deposit1)
|
|
|
|
deposit2 := []byte{5, 6, 7}
|
|
|
|
d.UpdateDepositTrie(deposit2)
|
|
|
|
deposit3 := []byte{8, 9, 10}
|
|
|
|
d.UpdateDepositTrie(deposit3)
|
2019-02-08 17:01:15 +00:00
|
|
|
index := make([]byte, 8)
|
2019-02-12 03:57:00 +00:00
|
|
|
binary.LittleEndian.PutUint64(index, d.depositCount-1)
|
2019-02-08 17:01:15 +00:00
|
|
|
branch := d.Branch()
|
|
|
|
root := d.Root()
|
2019-01-11 08:29:30 +00:00
|
|
|
if ok := VerifyMerkleBranch(
|
|
|
|
branch,
|
2019-02-08 17:01:15 +00:00
|
|
|
root,
|
2019-01-11 08:29:30 +00:00
|
|
|
index,
|
|
|
|
); !ok {
|
|
|
|
t.Error("Expected Merkle branch to verify, received false")
|
|
|
|
}
|
|
|
|
}
|