From 4fdd980a34e8e88615c026447b426e26509b7c2e Mon Sep 17 00:00:00 2001 From: Guillaume Ballet <3272758+gballet@users.noreply.github.com> Date: Tue, 7 Jan 2025 09:54:10 +0100 Subject: [PATCH] fix: EoA pattern recognition --- encoding_test.go | 37 ++++++++++++++++++------------------- tree.go | 4 ++-- 2 files changed, 20 insertions(+), 21 deletions(-) diff --git a/encoding_test.go b/encoding_test.go index 935c966..ef7d4ea 100644 --- a/encoding_test.go +++ b/encoding_test.go @@ -2,6 +2,8 @@ package verkle import ( "bytes" + "encoding/binary" + "math/big" "testing" "github.com/crate-crypto/go-ipa/banderwagon" @@ -62,11 +64,10 @@ func TestInvalidNodeEncoding(t *testing.T) { func TestParseNodeEoA(t *testing.T) { values := make([][]byte, 256) - values[0] = zero32[:] - values[1] = EmptyCodeHash[:] // set empty code hash as balance, because why not - values[2] = fourtyKeyTest[:] // set nonce to 64 - values[3] = EmptyCodeHash[:] // set empty code hash - values[4] = zero32[:] // zero-size + values[0] = make([]byte, 32) + binary.BigEndian.PutUint64(values[0][8:], 64) // nonce = 64 + copy(values[0][30:], big.NewInt(1337).Bytes()) // balance = 1337 + values[1] = EmptyCodeHash[:] // set empty code hash as balance, because why not ln, err := NewLeafNode(ffx32KeyTest[:31], values) if err != nil { t.Fatalf("error creating leaf node: %v", err) @@ -77,10 +78,8 @@ func TestParseNodeEoA(t *testing.T) { t.Fatalf("error serializing leaf node: %v", err) } - // TODO uncomment when the EoA serialization issue is fixed - // if serialized[0] != eoAccountType { - if serialized[0] != leafType { - t.Fatalf("invalid encoding type, got %d, expected %d", serialized[0], leafType) + if serialized[0] != eoAccountType { + t.Fatalf("invalid encoding type, got %d, expected %d", serialized[0], eoAccountType) } deserialized, err := ParseNode(serialized, 5) @@ -101,24 +100,24 @@ func TestParseNodeEoA(t *testing.T) { t.Fatalf("invalid stem, got %x, expected %x", lnd.stem, ffx32KeyTest[:31]) } - if !bytes.Equal(lnd.values[0], zero32[:]) { - t.Fatalf("invalid version, got %x, expected %x", lnd.values[0], zero32[:]) + if lnd.values[0][0] != 0 { + t.Fatalf("invalid version, got %x, expected %x", lnd.values[0][0], 0) } - if !bytes.Equal(lnd.values[1], EmptyCodeHash[:]) { - t.Fatalf("invalid balance, got %x, expected %x", lnd.values[1], EmptyCodeHash[:]) + if cs := binary.BigEndian.Uint32(lnd.values[0][4:]); cs != 0 { + t.Fatalf("invalid code size, got %x, expected %x", cs, 0) } - if !bytes.Equal(lnd.values[2], fourtyKeyTest[:]) { - t.Fatalf("invalid nonce, got %x, expected %x", lnd.values[2], fourtyKeyTest[:]) + if nonce := binary.BigEndian.Uint64(lnd.values[0][8:]); nonce != 64 { + t.Fatalf("invalid nonce, got %x, expected %x", nonce, 64) } - if !bytes.Equal(lnd.values[3], EmptyCodeHash[:]) { - t.Fatalf("invalid code hash, got %x, expected %x", lnd.values[3], EmptyCodeHash[:]) + if balance := new(big.Int).SetBytes(lnd.values[0][16:]); balance.Cmp(big.NewInt(1337)) != 0 { + t.Fatalf("invalid balance, got %x, expected %x", balance, 1337) } - if !bytes.Equal(lnd.values[4], zero32[:]) { - t.Fatalf("invalid code size, got %x, expected %x", lnd.values[4], zero32[:]) + if !bytes.Equal(lnd.values[1], EmptyCodeHash[:]) { + t.Fatalf("invalid balance, got %x, expected %x", lnd.values[1], EmptyCodeHash[:]) } if !lnd.c2.Equal(&banderwagon.Identity) { diff --git a/tree.go b/tree.go index b62e732..cccfa5b 100644 --- a/tree.go +++ b/tree.go @@ -1861,8 +1861,8 @@ func (n *LeafNode) serializeLeafWithUncompressedCommitments(cBytes, c1Bytes, c2B if isEoA { switch i { case 0: - // Version should be 0 - isEoA = v != nil + // Version + reserved fields + code size should be 0 + isEoA = v != nil && bytes.Equal(v[0:8], zero32[0:8]) case 1: // Code hash should be the empty code hash isEoA = v != nil && bytes.Equal(v, EmptyCodeHash[:])