prysm-pulse/shared/trieutil/deposit_trie_test.go
Raul Jordan 5dc5f1d1c8 Update Contract to Use Little Endian And Encoding Across Entire Repo (#1536)
* using little endian and tests for encoding dep inputs

* use decode value and timestamp method in state

* updated comments to match serialization format

* latest compiled contract, abi, bytecode, and bindings

* to little endian everywhere

* fix all tests except for contract tests

* include contract changes

* address broken build

* compile with vyper v8

* update readme

* fix pkg name

* add skip chainstart delay

* skip chainstart delay tests pass

* to little endian timestamp
2019-02-12 09:27:00 +05:30

83 lines
1.8 KiB
Go

package trieutil
import (
"encoding/binary"
"testing"
"github.com/prysmaticlabs/prysm/shared/hashutil"
)
func TestDepositTrie_UpdateDepositTrie(t *testing.T) {
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)
}
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())
}
d.UpdateDepositTrie(tt.deposits[1])
if d.depositCount != 2 {
t.Errorf("Expected deposit count to increase by 1, received %d", d.depositCount)
}
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][:]...))
}
if d.Root() != hashedData {
t.Errorf("Expected %#x but got %#x", hashedData, d.Root())
}
}
}
func TestDepositTrie_VerifyMerkleBranch(t *testing.T) {
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)
index := make([]byte, 8)
binary.LittleEndian.PutUint64(index, d.depositCount-1)
branch := d.Branch()
root := d.Root()
if ok := VerifyMerkleBranch(
branch,
root,
index,
); !ok {
t.Error("Expected Merkle branch to verify, received false")
}
}