Update types package, fix proof's aunt handling

This commit is contained in:
ValarDragon 2018-08-30 22:30:05 -07:00
parent 4b14e17d61
commit 1302db7dac
10 changed files with 41 additions and 45 deletions

View File

@ -18,37 +18,37 @@ func TestSimpleMap(t *testing.T) {
{ {
db := newSimpleMap() db := newSimpleMap()
db.Set("key1", strHasher("value1")) db.Set("key1", strHasher("value1"))
assert.Equal(t, "fa9bc106ffd932d919bee935ceb6cf2b3dd72d8f", fmt.Sprintf("%x", db.Hash()), "Hash didn't match") assert.Equal(t, "5e0c721faaa2e92bdb37e7d7297d6affb3bac87d", fmt.Sprintf("%x", db.Hash()), "Hash didn't match")
} }
{ {
db := newSimpleMap() db := newSimpleMap()
db.Set("key1", strHasher("value2")) db.Set("key1", strHasher("value2"))
assert.Equal(t, "e00e7dcfe54e9fafef5111e813a587f01ba9c3e8", fmt.Sprintf("%x", db.Hash()), "Hash didn't match") assert.Equal(t, "968fdd7e6e94448b0ab5d38cd9b3618b860e2443", fmt.Sprintf("%x", db.Hash()), "Hash didn't match")
} }
{ {
db := newSimpleMap() db := newSimpleMap()
db.Set("key1", strHasher("value1")) db.Set("key1", strHasher("value1"))
db.Set("key2", strHasher("value2")) db.Set("key2", strHasher("value2"))
assert.Equal(t, "eff12d1c703a1022ab509287c0f196130123d786", fmt.Sprintf("%x", db.Hash()), "Hash didn't match") assert.Equal(t, "7dc11c8e1bc6fe0aaa0d691560c25c3f33940e14", fmt.Sprintf("%x", db.Hash()), "Hash didn't match")
} }
{ {
db := newSimpleMap() db := newSimpleMap()
db.Set("key2", strHasher("value2")) // NOTE: out of order db.Set("key2", strHasher("value2")) // NOTE: out of order
db.Set("key1", strHasher("value1")) db.Set("key1", strHasher("value1"))
assert.Equal(t, "eff12d1c703a1022ab509287c0f196130123d786", fmt.Sprintf("%x", db.Hash()), "Hash didn't match") assert.Equal(t, "7dc11c8e1bc6fe0aaa0d691560c25c3f33940e14", fmt.Sprintf("%x", db.Hash()), "Hash didn't match")
} }
{ {
db := newSimpleMap() db := newSimpleMap()
db.Set("key1", strHasher("value1")) db.Set("key1", strHasher("value1"))
db.Set("key2", strHasher("value2")) db.Set("key2", strHasher("value2"))
db.Set("key3", strHasher("value3")) db.Set("key3", strHasher("value3"))
assert.Equal(t, "b2c62a277c08dbd2ad73ca53cd1d6bfdf5830d26", fmt.Sprintf("%x", db.Hash()), "Hash didn't match") assert.Equal(t, "2584d8b484db08cd807b931e0b95f64a9105d41d", fmt.Sprintf("%x", db.Hash()), "Hash didn't match")
} }
{ {
db := newSimpleMap() db := newSimpleMap()
db.Set("key2", strHasher("value2")) // NOTE: out of order db.Set("key2", strHasher("value2")) // NOTE: out of order
db.Set("key1", strHasher("value1")) db.Set("key1", strHasher("value1"))
db.Set("key3", strHasher("value3")) db.Set("key3", strHasher("value3"))
assert.Equal(t, "b2c62a277c08dbd2ad73ca53cd1d6bfdf5830d26", fmt.Sprintf("%x", db.Hash()), "Hash didn't match") assert.Equal(t, "2584d8b484db08cd807b931e0b95f64a9105d41d", fmt.Sprintf("%x", db.Hash()), "Hash didn't match")
} }
} }

View File

@ -99,7 +99,7 @@ func computeHashFromAunts(index int, total int, leafHash []byte, innerHashes [][
if len(innerHashes) == 0 { if len(innerHashes) == 0 {
return nil return nil
} }
numLeft := (total + 1) / 2 numLeft := getSplitPoint(total)
if index < numLeft { if index < numLeft {
leftHash := computeHashFromAunts(index, numLeft, leafHash, innerHashes[:len(innerHashes)-1]) leftHash := computeHashFromAunts(index, numLeft, leafHash, innerHashes[:len(innerHashes)-1])
if leftHash == nil { if leftHash == nil {

View File

@ -1,7 +1,6 @@
package merkle package merkle
import ( import (
"fmt"
"math/bits" "math/bits"
"github.com/tendermint/tendermint/crypto/tmhash" "github.com/tendermint/tendermint/crypto/tmhash"
@ -75,6 +74,5 @@ func getSplitPoint(length int) int {
if k == length { if k == length {
k >>= 1 k >>= 1
} }
fmt.Println(length, k)
return k return k
} }

View File

@ -1,11 +1,5 @@
package merkle package merkle
import (
"io"
amino "github.com/tendermint/go-amino"
)
var ( var (
LeafHashPrefix = []byte{0} LeafHashPrefix = []byte{0}
InnerHashPrefix = []byte{1} InnerHashPrefix = []byte{1}
@ -34,10 +28,3 @@ type Tree interface {
type Hasher interface { type Hasher interface {
Hash() []byte Hash() []byte
} }
//-----------------------------------------------------------------------
// Uvarint length prefixed byteslice
func encodeByteSlice(w io.Writer, bz []byte) (err error) {
return amino.EncodeByteSlice(w, bz)
}

View File

@ -419,11 +419,11 @@ func (commit *Commit) Hash() cmn.HexBytes {
return nil return nil
} }
if commit.hash == nil { if commit.hash == nil {
bs := make([]merkle.Hasher, len(commit.Precommits)) bzs := make([][]byte, len(commit.Precommits))
for i, precommit := range commit.Precommits { for i, precommit := range commit.Precommits {
bs[i] = aminoHasher(precommit) bzs[i] = cdc.MustMarshalBinaryBare(precommit)
} }
commit.hash = merkle.SimpleHashFromHashers(bs) commit.hash = merkle.SimpleHashFromByteSlices(bzs)
} }
return commit.hash return commit.hash
} }
@ -638,11 +638,8 @@ type hasher struct {
func (h hasher) Hash() []byte { func (h hasher) Hash() []byte {
hasher := tmhash.New() hasher := tmhash.New()
if h.item != nil && !cmn.IsTypedNil(h.item) && !cmn.IsEmpty(h.item) { if h.item != nil && !cmn.IsTypedNil(h.item) && !cmn.IsEmpty(h.item) {
bz, err := cdc.MarshalBinaryBare(h.item) bz := cdc.MustMarshalBinaryBare(h.item)
if err != nil { _, err := hasher.Write(bz)
panic(err)
}
_, err = hasher.Write(bz)
if err != nil { if err != nil {
panic(err) panic(err)
} }

View File

@ -88,7 +88,7 @@ func NewPartSetFromData(data []byte, partSize int) *PartSet {
// divide data into 4kb parts. // divide data into 4kb parts.
total := (len(data) + partSize - 1) / partSize total := (len(data) + partSize - 1) / partSize
parts := make([]*Part, total) parts := make([]*Part, total)
parts_ := make([]merkle.Hasher, total) parts_ := make([][]byte, total)
partsBitArray := cmn.NewBitArray(total) partsBitArray := cmn.NewBitArray(total)
for i := 0; i < total; i++ { for i := 0; i < total; i++ {
part := &Part{ part := &Part{
@ -96,11 +96,11 @@ func NewPartSetFromData(data []byte, partSize int) *PartSet {
Bytes: data[i*partSize : cmn.MinInt(len(data), (i+1)*partSize)], Bytes: data[i*partSize : cmn.MinInt(len(data), (i+1)*partSize)],
} }
parts[i] = part parts[i] = part
parts_[i] = part parts_[i] = part.Bytes
partsBitArray.SetIndex(i, true) partsBitArray.SetIndex(i, true)
} }
// Compute merkle proofs // Compute merkle proofs
root, proofs := merkle.SimpleProofsFromHashers(parts_) root, proofs := merkle.SimpleProofsFromByteSlices(parts_)
for i := 0; i < total; i++ { for i := 0; i < total; i++ {
parts[i].Proof = *proofs[i] parts[i].Proof = *proofs[i]
} }

View File

@ -54,20 +54,20 @@ func (a ABCIResults) Bytes() []byte {
func (a ABCIResults) Hash() []byte { func (a ABCIResults) Hash() []byte {
// NOTE: we copy the impl of the merkle tree for txs - // NOTE: we copy the impl of the merkle tree for txs -
// we should be consistent and either do it for both or not. // we should be consistent and either do it for both or not.
return merkle.SimpleHashFromHashers(a.toHashers()) return merkle.SimpleHashFromByteSlices(a.toByteSlices())
} }
// ProveResult returns a merkle proof of one result from the set // ProveResult returns a merkle proof of one result from the set
func (a ABCIResults) ProveResult(i int) merkle.SimpleProof { func (a ABCIResults) ProveResult(i int) merkle.SimpleProof {
_, proofs := merkle.SimpleProofsFromHashers(a.toHashers()) _, proofs := merkle.SimpleProofsFromByteSlices(a.toByteSlices())
return *proofs[i] return *proofs[i]
} }
func (a ABCIResults) toHashers() []merkle.Hasher { func (a ABCIResults) toByteSlices() [][]byte {
l := len(a) l := len(a)
hashers := make([]merkle.Hasher, l) byteslices := make([][]byte, l)
for i := 0; i < l; i++ { for i := 0; i < l; i++ {
hashers[i] = a[i] byteslices[i] = cdc.MustMarshalBinaryBare(a[i])
} }
return hashers return byteslices
} }

View File

@ -70,11 +70,11 @@ func (txs Txs) IndexByHash(hash []byte) int {
// TODO: optimize this! // TODO: optimize this!
func (txs Txs) Proof(i int) TxProof { func (txs Txs) Proof(i int) TxProof {
l := len(txs) l := len(txs)
hashers := make([]merkle.Hasher, l) bzs := make([][]byte, l)
for i := 0; i < l; i++ { for i := 0; i < l; i++ {
hashers[i] = txs[i] bzs[i] = txs[i]
} }
root, proofs := merkle.SimpleProofsFromHashers(hashers) root, proofs := merkle.SimpleProofsFromByteSlices(bzs)
return TxProof{ return TxProof{
Index: i, Index: i,

View File

@ -82,6 +82,20 @@ func (v *Validator) Hash() []byte {
}) })
} }
// hashBytes computes the bytes to be hashed of a validator with a given voting power.
// It excludes the Accum value, which changes with every round.
func (v *Validator) hashBytes() []byte {
return cdc.MustMarshalBinaryBare(struct {
Address Address
PubKey crypto.PubKey
VotingPower int64
}{
v.Address,
v.PubKey,
v.VotingPower,
})
}
//---------------------------------------- //----------------------------------------
// RandValidator // RandValidator

View File

@ -176,11 +176,11 @@ func (vals *ValidatorSet) Hash() []byte {
if len(vals.Validators) == 0 { if len(vals.Validators) == 0 {
return nil return nil
} }
hashers := make([]merkle.Hasher, len(vals.Validators)) bzs := make([][]byte, len(vals.Validators))
for i, val := range vals.Validators { for i, val := range vals.Validators {
hashers[i] = val bzs[i] = val.hashBytes()
} }
return merkle.SimpleHashFromHashers(hashers) return merkle.SimpleHashFromByteSlices(bzs)
} }
// Add adds val to the validator set and returns true. It returns false if val // Add adds val to the validator set and returns true. It returns false if val