Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/oss' into fix_inserts_remove_l…
Browse files Browse the repository at this point in the history
…eaks
  • Loading branch information
cchudant committed Sep 16, 2024
2 parents e7b7e0b + 5b919ca commit e0b0c7f
Show file tree
Hide file tree
Showing 4 changed files with 75 additions and 3 deletions.
1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ indexmap = "2.2.6"
criterion = "0.5.1"
proptest = "1.4.0"
proptest-derive = "0.4.0"
serde_json = "1.0.68"

[[bench]]
name = "storage"
Expand Down
3 changes: 1 addition & 2 deletions src/key_value_db.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,7 @@ use crate::{
/// Crate Trie <= KeyValueDB => BonsaiDatabase
#[cfg_attr(feature = "bench", derive(Clone))]
#[derive(Debug)]
pub struct KeyValueDB<DB: BonsaiDatabase, ID: Id>
{
pub struct KeyValueDB<DB: BonsaiDatabase, ID: Id> {
pub(crate) db: DB,
pub(crate) changes_store: ChangeStore<ID>,
pub(crate) snap_holder: BTreeSet<ID>,
Expand Down
49 changes: 48 additions & 1 deletion src/tests/proof.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
#![cfg(all(feature = "std", feature = "rocksdb"))]
use bitvec::vec::BitVec;
use bitvec::{order::Msb0, vec::BitVec, view::BitView};
use pathfinder_common::{hash::PedersenHash, trie::TrieNode};
use pathfinder_crypto::Felt as PathfinderFelt;
use pathfinder_merkle_tree::tree::{MerkleTree, TestStorage};
Expand Down Expand Up @@ -111,6 +111,53 @@ fn assert_eq_proof(bonsai_proof: &[ProofNode], pathfinder_proof: &[TrieNode]) {
}
}

#[test]
fn debug_deoxys() {
// Load storage_data.json file
let storage_data = include_str!("storage_data.json");
let storage_data: Vec<Vec<(String, String)>> = serde_json::from_str(storage_data).unwrap();
let tempdir = tempfile::tempdir().unwrap();
let db = create_rocks_db(tempdir.path()).unwrap();
let config = BonsaiStorageConfig::default();
let mut storage = pathfinder_merkle_tree::tree::TestStorage::default();
let mut id_builder = BasicIdBuilder::new();
let mut bonsai_storage =
BonsaiStorage::<_, _, Pedersen>::new(RocksDB::new(&db, RocksDBConfig::default()), config)
.unwrap();
let mut pathfinder_merkle_tree: MerkleTree<PedersenHash, 251> =
pathfinder_merkle_tree::tree::MerkleTree::empty();
let identifier =
Felt::from_hex("0x04acd4b2a59eae7196f6a5c26ead8cb5f9d7ad3d911096418a23357bb2eac075")
.unwrap()
.to_bytes_be()
.to_vec();
for block_changes in storage_data.iter() {
for pair in block_changes.iter() {
let key = keyer(Felt::from_hex(&pair.0).unwrap());
let value = Felt::from_hex(&pair.1).unwrap();
bonsai_storage.insert(&identifier, &key, &value).unwrap();
pathfinder_merkle_tree
.set(
&storage,
key,
PathfinderFelt::from_hex_str(&pair.1).unwrap(),
)
.unwrap();
}
bonsai_storage.commit(id_builder.new_id()).unwrap();
let (_, root_id) = commit_and_persist(pathfinder_merkle_tree.clone(), &mut storage);
let pathfinder_root = storage.nodes.get(&root_id).unwrap().0;
let bonsai_root = bonsai_storage.root_hash(&identifier).unwrap();
println!("{:#02x}", bonsai_root);
println!("{:#02x}", pathfinder_root);
assert_eq!(pathfinder_root.to_be_bytes(), bonsai_root.to_bytes_be());
}
}

fn keyer(felt: Felt) -> BitVec<u8, Msb0> {
felt.to_bytes_be().view_bits()[5..].to_bitvec()
}

#[test]
fn basic_proof() {
let identifier = vec![];
Expand Down
25 changes: 25 additions & 0 deletions src/tests/storage_data.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
[
[
[
"0x00a76c5ddd7dfe35c6511a0d8085a9ab719e85edfc8ef4abbccf60dc1340b558",
"0x05c1bca21a1851421fbbf73ad2e0f82c50bc67fb09fdb221bdc2fd96fed49db8"
],
[
"0x00a76c5ddd7dfe35c6511a0d8085a9ab719e85edfc8ef4abbccf60dc1340b559",
"0x03dbd160736e9b9b51ea9a79a8ed86f427a62e0e377d60335d2ec895c27025bb"
]
],
[
[
"0x00a76c5ddd7dfe35c6511a0d8085a9ab719e85edfc8ef4abbccf60dc1340b559",
"0x00dd45c619a4842d6e392a60041fc2a2a896f4e6e2d056acdff7e9c64d9a1819"
]
],
[
[
"0x00a76c5ddd7dfe35c6511a0d8085a9ab719e85edfc8ef4abbccf60dc1340b559",
"0x03dbd160736e9b9b51ea9a79a8ed86f427a62e0e377d60335d2ec895c27025bb"
]
]
]

0 comments on commit e0b0c7f

Please sign in to comment.