Skip to content

Commit

Permalink
review feedback
Browse files Browse the repository at this point in the history
Signed-off-by: Ignacio Hagopian <[email protected]>
  • Loading branch information
jsign committed Oct 16, 2023
1 parent 0d744bd commit 49e9eb1
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 44 deletions.
49 changes: 49 additions & 0 deletions proof_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -942,3 +942,52 @@ func TestProofOfAbsenceBorderCase(t *testing.T) {
t.Fatal("differing commitment for child #0")
}
}

func TestGenerateProofWithOnlyAbsentKeys(t *testing.T) {
t.Parallel()

// Create a tree with only one key.
root := New()
presentKey, _ := hex.DecodeString("4000000000000000000000000000000000000000000000000000000000000000")
if err := root.Insert(presentKey, zeroKeyTest, nil); err != nil {
t.Fatalf("inserting into the original failed: %v", err)
}
root.Commit()

// Create a proof with a key with the same first byte, but different second byte (i.e: absent).
absentKey, _ := hex.DecodeString("4010000000000000000000000000000000000000000000000000000000000000")
proof, cis, zis, yis, err := MakeVerkleMultiProof(root, nil, keylist{absentKey}, nil)
if err != nil {
t.Fatal(err)
}

// It must pass.
if ok, err := VerifyVerkleProof(proof, cis, zis, yis, cfg); !ok || err != nil {
t.Fatalf("original proof didn't verify: %v", err)
}

// Serialize + Deserialize + build tree from proof.
vp, statediff, err := SerializeProof(proof)
if err != nil {
t.Fatal(err)
}
dproof, err := DeserializeProof(vp, statediff)
if err != nil {
t.Fatal(err)
}
droot, err := PreStateTreeFromProof(dproof, root.Commit())
if err != nil {
t.Fatal(err)
}

// From the rebuilt tree, validate the proof.
pe, _, _, err := GetCommitmentsForMultiproof(droot, keylist{absentKey}, nil)
if err != nil {
t.Fatal(err)
}

// It must pass.
if ok, err := VerifyVerkleProof(dproof, pe.Cis, pe.Zis, pe.Yis, cfg); !ok || err != nil {
t.Fatalf("reconstructed proof didn't verify: %v", err)
}
}
44 changes: 0 additions & 44 deletions tree_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1649,47 +1649,3 @@ func TestLeafNodeInsert(t *testing.T) {
t.Fatalf("hash should not be nil")
}
}

func TestGenerateProofWithOnlyAbsentKeys(t *testing.T) {
t.Parallel()

// Create a tree with only one key.
root := New()
presentKey, _ := hex.DecodeString("4000000000000000000000000000000000000000000000000000000000000000")
if err := root.Insert(presentKey, zeroKeyTest, nil); err != nil {
t.Fatalf("inserting into the original failed: %v", err)
}
root.Commit()

// Create a proof with a key with the same first byte, but different second byte (i.e: absent).
absentKey, _ := hex.DecodeString("4010000000000000000000000000000000000000000000000000000000000000")
proof, _, _, _, err := MakeVerkleMultiProof(root, nil, keylist{absentKey}, nil)
if err != nil {
t.Fatal(err)
}

// Serialize + Deserialize + build tree from proof.
vp, statediff, err := SerializeProof(proof)
if err != nil {
t.Fatal(err)
}
dproof, err := DeserializeProof(vp, statediff)
if err != nil {
t.Fatal(err)
}
droot, err := PreStateTreeFromProof(dproof, root.Commit())
if err != nil {
t.Fatal(err)
}

// From the rebuilt tree, validate the proof.
pe, _, _, err := GetCommitmentsForMultiproof(droot, keylist{absentKey}, nil)
if err != nil {
t.Fatal(err)
}

// It must pass.
if ok, err := VerifyVerkleProof(proof, pe.Cis, pe.Zis, pe.Yis, cfg); !ok || err != nil {
t.Fatal("proof didn't verify")
}
}

0 comments on commit 49e9eb1

Please sign in to comment.