|
@ -1,11 +1,11 @@ |
|
|
use super::*;
|
|
|
use super::*;
|
|
|
use crate::{
|
|
|
use crate::{
|
|
|
hash::rpo::Rpo256,
|
|
|
hash::rpo::Rpo256,
|
|
|
merkle::{int_to_node, MerklePathSet},
|
|
|
|
|
|
|
|
|
merkle::{int_to_node, MerklePathSet, MerkleTree, SimpleSmt},
|
|
|
Felt, Word, WORD_SIZE, ZERO,
|
|
|
Felt, Word, WORD_SIZE, ZERO,
|
|
|
};
|
|
|
};
|
|
|
|
|
|
|
|
|
#[cfg(std)]
|
|
|
|
|
|
|
|
|
#[cfg(feature = "std")]
|
|
|
use std::error::Error;
|
|
|
use std::error::Error;
|
|
|
|
|
|
|
|
|
const KEYS4: [u64; 4] = [0, 1, 2, 3];
|
|
|
const KEYS4: [u64; 4] = [0, 1, 2, 3];
|
|
@ -15,7 +15,7 @@ const EMPTY: Word = [ZERO; WORD_SIZE]; |
|
|
#[test]
|
|
|
#[test]
|
|
|
fn test_root_not_in_store() -> Result<(), MerkleError> {
|
|
|
fn test_root_not_in_store() -> Result<(), MerkleError> {
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec())?;
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec())?;
|
|
|
let store = MerkleStore::default().with_merkle_tree(LEAVES4)?;
|
|
|
|
|
|
|
|
|
let store = MerkleStore::from(&mtree);
|
|
|
assert_eq!(
|
|
|
assert_eq!(
|
|
|
store.get_node(LEAVES4[0], NodeIndex::make(mtree.depth(), 0)),
|
|
|
store.get_node(LEAVES4[0], NodeIndex::make(mtree.depth(), 0)),
|
|
|
Err(MerkleError::RootNotInStore(LEAVES4[0])),
|
|
|
Err(MerkleError::RootNotInStore(LEAVES4[0])),
|
|
@ -32,10 +32,8 @@ fn test_root_not_in_store() -> Result<(), MerkleError> { |
|
|
|
|
|
|
|
|
#[test]
|
|
|
#[test]
|
|
|
fn test_merkle_tree() -> Result<(), MerkleError> {
|
|
|
fn test_merkle_tree() -> Result<(), MerkleError> {
|
|
|
let mut store = MerkleStore::default();
|
|
|
|
|
|
|
|
|
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec())?;
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec())?;
|
|
|
store.add_merkle_tree(LEAVES4.to_vec())?;
|
|
|
|
|
|
|
|
|
let store = MerkleStore::from(&mtree);
|
|
|
|
|
|
|
|
|
// STORE LEAVES ARE CORRECT ==============================================================
|
|
|
// STORE LEAVES ARE CORRECT ==============================================================
|
|
|
// checks the leaves in the store corresponds to the expected values
|
|
|
// checks the leaves in the store corresponds to the expected values
|
|
@ -176,24 +174,20 @@ fn test_leaf_paths_for_empty_trees() -> Result<(), MerkleError> { |
|
|
|
|
|
|
|
|
#[test]
|
|
|
#[test]
|
|
|
fn test_get_invalid_node() {
|
|
|
fn test_get_invalid_node() {
|
|
|
let mut store = MerkleStore::default();
|
|
|
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec()).expect("creating a merkle tree must work");
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec()).expect("creating a merkle tree must work");
|
|
|
store
|
|
|
|
|
|
.add_merkle_tree(LEAVES4.to_vec())
|
|
|
|
|
|
.expect("adding a merkle tree to the store must work");
|
|
|
|
|
|
|
|
|
let store = MerkleStore::from(&mtree);
|
|
|
let _ = store.get_node(mtree.root(), NodeIndex::make(mtree.depth(), 3));
|
|
|
let _ = store.get_node(mtree.root(), NodeIndex::make(mtree.depth(), 3));
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
#[test]
|
|
|
fn test_add_sparse_merkle_tree_one_level() -> Result<(), MerkleError> {
|
|
|
fn test_add_sparse_merkle_tree_one_level() -> Result<(), MerkleError> {
|
|
|
let mut store = MerkleStore::default();
|
|
|
|
|
|
let keys2: [u64; 2] = [0, 1];
|
|
|
let keys2: [u64; 2] = [0, 1];
|
|
|
let leaves2: [Word; 2] = [int_to_node(1), int_to_node(2)];
|
|
|
let leaves2: [Word; 2] = [int_to_node(1), int_to_node(2)];
|
|
|
store.add_sparse_merkle_tree(48, keys2.into_iter().zip(leaves2.into_iter()))?;
|
|
|
|
|
|
let smt = SimpleSmt::new(1)
|
|
|
let smt = SimpleSmt::new(1)
|
|
|
.unwrap()
|
|
|
.unwrap()
|
|
|
.with_leaves(keys2.into_iter().zip(leaves2.into_iter()))
|
|
|
.with_leaves(keys2.into_iter().zip(leaves2.into_iter()))
|
|
|
.unwrap();
|
|
|
.unwrap();
|
|
|
|
|
|
let store = MerkleStore::from(&smt);
|
|
|
|
|
|
|
|
|
let idx = NodeIndex::make(1, 0);
|
|
|
let idx = NodeIndex::make(1, 0);
|
|
|
assert_eq!(smt.get_node(idx).unwrap(), leaves2[0]);
|
|
|
assert_eq!(smt.get_node(idx).unwrap(), leaves2[0]);
|
|
@ -208,15 +202,13 @@ fn test_add_sparse_merkle_tree_one_level() -> Result<(), MerkleError> { |
|
|
|
|
|
|
|
|
#[test]
|
|
|
#[test]
|
|
|
fn test_sparse_merkle_tree() -> Result<(), MerkleError> {
|
|
|
fn test_sparse_merkle_tree() -> Result<(), MerkleError> {
|
|
|
let mut store = MerkleStore::default();
|
|
|
|
|
|
store
|
|
|
|
|
|
.add_sparse_merkle_tree(SimpleSmt::MAX_DEPTH, KEYS4.into_iter().zip(LEAVES4.into_iter()))?;
|
|
|
|
|
|
|
|
|
|
|
|
let smt = SimpleSmt::new(SimpleSmt::MAX_DEPTH)
|
|
|
let smt = SimpleSmt::new(SimpleSmt::MAX_DEPTH)
|
|
|
.unwrap()
|
|
|
.unwrap()
|
|
|
.with_leaves(KEYS4.into_iter().zip(LEAVES4.into_iter()))
|
|
|
.with_leaves(KEYS4.into_iter().zip(LEAVES4.into_iter()))
|
|
|
.unwrap();
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
|
|
|
|
let store = MerkleStore::from(&smt);
|
|
|
|
|
|
|
|
|
// STORE LEAVES ARE CORRECT ==============================================================
|
|
|
// STORE LEAVES ARE CORRECT ==============================================================
|
|
|
// checks the leaves in the store corresponds to the expected values
|
|
|
// checks the leaves in the store corresponds to the expected values
|
|
|
assert_eq!(
|
|
|
assert_eq!(
|
|
@ -472,7 +464,8 @@ fn wont_open_to_different_depth_root() { |
|
|
// For this example, the depth of the Merkle tree is 1, as we have only two leaves. Here we
|
|
|
// For this example, the depth of the Merkle tree is 1, as we have only two leaves. Here we
|
|
|
// attempt to fetch a node on the maximum depth, and it should fail because the root shouldn't
|
|
|
// attempt to fetch a node on the maximum depth, and it should fail because the root shouldn't
|
|
|
// exist for the set.
|
|
|
// exist for the set.
|
|
|
let store = MerkleStore::default().with_merkle_tree([a, b]).unwrap();
|
|
|
|
|
|
|
|
|
let mtree = MerkleTree::new(vec![a, b]).unwrap();
|
|
|
|
|
|
let store = MerkleStore::from(&mtree);
|
|
|
let index = NodeIndex::root();
|
|
|
let index = NodeIndex::root();
|
|
|
let err = store.get_node(root, index).err().unwrap();
|
|
|
let err = store.get_node(root, index).err().unwrap();
|
|
|
assert_eq!(err, MerkleError::RootNotInStore(root));
|
|
|
assert_eq!(err, MerkleError::RootNotInStore(root));
|
|
@ -499,7 +492,8 @@ fn store_path_opens_from_leaf() { |
|
|
|
|
|
|
|
|
let root = Rpo256::merge(&[m.into(), n.into()]);
|
|
|
let root = Rpo256::merge(&[m.into(), n.into()]);
|
|
|
|
|
|
|
|
|
let store = MerkleStore::default().with_merkle_tree([a, b, c, d, e, f, g, h]).unwrap();
|
|
|
|
|
|
|
|
|
let mtree = MerkleTree::new(vec![a, b, c, d, e, f, g, h]).unwrap();
|
|
|
|
|
|
let store = MerkleStore::from(&mtree);
|
|
|
let path = store.get_path(root.into(), NodeIndex::make(3, 1)).unwrap().path;
|
|
|
let path = store.get_path(root.into(), NodeIndex::make(3, 1)).unwrap().path;
|
|
|
|
|
|
|
|
|
let expected = MerklePath::new([a.into(), j.into(), n.into()].to_vec());
|
|
|
let expected = MerklePath::new([a.into(), j.into(), n.into()].to_vec());
|
|
@ -509,7 +503,7 @@ fn store_path_opens_from_leaf() { |
|
|
#[test]
|
|
|
#[test]
|
|
|
fn test_set_node() -> Result<(), MerkleError> {
|
|
|
fn test_set_node() -> Result<(), MerkleError> {
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec())?;
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec())?;
|
|
|
let mut store = MerkleStore::default().with_merkle_tree(LEAVES4)?;
|
|
|
|
|
|
|
|
|
let mut store = MerkleStore::from(&mtree);
|
|
|
let value = int_to_node(42);
|
|
|
let value = int_to_node(42);
|
|
|
let index = NodeIndex::make(mtree.depth(), 0);
|
|
|
let index = NodeIndex::make(mtree.depth(), 0);
|
|
|
let new_root = store.set_node(mtree.root(), index, value)?.root;
|
|
|
let new_root = store.set_node(mtree.root(), index, value)?.root;
|
|
@ -520,8 +514,8 @@ fn test_set_node() -> Result<(), MerkleError> { |
|
|
|
|
|
|
|
|
#[test]
|
|
|
#[test]
|
|
|
fn test_constructors() -> Result<(), MerkleError> {
|
|
|
fn test_constructors() -> Result<(), MerkleError> {
|
|
|
let store = MerkleStore::new().with_merkle_tree(LEAVES4)?;
|
|
|
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec())?;
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec())?;
|
|
|
|
|
|
let store = MerkleStore::from(&mtree);
|
|
|
|
|
|
|
|
|
let depth = mtree.depth();
|
|
|
let depth = mtree.depth();
|
|
|
let leaves = 2u64.pow(depth.into());
|
|
|
let leaves = 2u64.pow(depth.into());
|
|
@ -532,12 +526,11 @@ fn test_constructors() -> Result<(), MerkleError> { |
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
let depth = 32;
|
|
|
let depth = 32;
|
|
|
let store = MerkleStore::default()
|
|
|
|
|
|
.with_sparse_merkle_tree(depth, KEYS4.into_iter().zip(LEAVES4.into_iter()))?;
|
|
|
|
|
|
let smt = SimpleSmt::new(depth)
|
|
|
let smt = SimpleSmt::new(depth)
|
|
|
.unwrap()
|
|
|
.unwrap()
|
|
|
.with_leaves(KEYS4.into_iter().zip(LEAVES4.into_iter()))
|
|
|
.with_leaves(KEYS4.into_iter().zip(LEAVES4.into_iter()))
|
|
|
.unwrap();
|
|
|
.unwrap();
|
|
|
|
|
|
let store = MerkleStore::from(&smt);
|
|
|
let depth = smt.depth();
|
|
|
let depth = smt.depth();
|
|
|
|
|
|
|
|
|
for key in KEYS4 {
|
|
|
for key in KEYS4 {
|
|
@ -554,12 +547,14 @@ fn test_constructors() -> Result<(), MerkleError> { |
|
|
(3, LEAVES4[3], mtree.get_path(NodeIndex::make(d, 3)).unwrap()),
|
|
|
(3, LEAVES4[3], mtree.get_path(NodeIndex::make(d, 3)).unwrap()),
|
|
|
];
|
|
|
];
|
|
|
|
|
|
|
|
|
let store1 = MerkleStore::default().with_merkle_paths(paths.clone())?;
|
|
|
|
|
|
let store2 = MerkleStore::default()
|
|
|
|
|
|
.with_merkle_path(0, LEAVES4[0], mtree.get_path(NodeIndex::make(d, 0))?)?
|
|
|
|
|
|
.with_merkle_path(1, LEAVES4[1], mtree.get_path(NodeIndex::make(d, 1))?)?
|
|
|
|
|
|
.with_merkle_path(2, LEAVES4[2], mtree.get_path(NodeIndex::make(d, 2))?)?
|
|
|
|
|
|
.with_merkle_path(3, LEAVES4[3], mtree.get_path(NodeIndex::make(d, 3))?)?;
|
|
|
|
|
|
|
|
|
let mut store1 = MerkleStore::default();
|
|
|
|
|
|
store1.add_merkle_paths(paths.clone())?;
|
|
|
|
|
|
|
|
|
|
|
|
let mut store2 = MerkleStore::default();
|
|
|
|
|
|
store2.add_merkle_path(0, LEAVES4[0], mtree.get_path(NodeIndex::make(d, 0))?)?;
|
|
|
|
|
|
store2.add_merkle_path(1, LEAVES4[1], mtree.get_path(NodeIndex::make(d, 1))?)?;
|
|
|
|
|
|
store2.add_merkle_path(2, LEAVES4[2], mtree.get_path(NodeIndex::make(d, 2))?)?;
|
|
|
|
|
|
store2.add_merkle_path(3, LEAVES4[3], mtree.get_path(NodeIndex::make(d, 3))?)?;
|
|
|
let set = MerklePathSet::new(d).with_paths(paths).unwrap();
|
|
|
let set = MerklePathSet::new(d).with_paths(paths).unwrap();
|
|
|
|
|
|
|
|
|
for key in [0, 1, 2, 3] {
|
|
|
for key in [0, 1, 2, 3] {
|
|
@ -723,11 +718,12 @@ fn get_leaf_depth_works_with_depth_8() { |
|
|
assert_eq!(Err(MerkleError::DepthTooBig(9)), store.get_leaf_depth(root, 8, a));
|
|
|
assert_eq!(Err(MerkleError::DepthTooBig(9)), store.get_leaf_depth(root, 8, a));
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
#[cfg(std)]
|
|
|
|
|
|
|
|
|
#[cfg(feature = "std")]
|
|
|
#[test]
|
|
|
#[test]
|
|
|
fn test_serialization() -> Result<(), Box<dyn Error>> {
|
|
|
fn test_serialization() -> Result<(), Box<dyn Error>> {
|
|
|
let original = MerkleStore::new().with_merkle_tree(LEAVES4)?;
|
|
|
|
|
|
let decoded = MerkleStore::read_from_bytes(&original.to_bytes())?;
|
|
|
|
|
|
assert_eq!(original, decoded);
|
|
|
|
|
|
|
|
|
let mtree = MerkleTree::new(LEAVES4.to_vec())?;
|
|
|
|
|
|
let store = MerkleStore::from(&mtree);
|
|
|
|
|
|
let decoded = MerkleStore::read_from_bytes(&store.to_bytes()).expect("deserialization failed");
|
|
|
|
|
|
assert_eq!(store, decoded);
|
|
|
Ok(())
|
|
|
Ok(())
|
|
|
}
|
|
|
}
|