2022-10-01 21:55:47 -07:00
|
|
|
use anyhow::Result;
|
2022-10-11 20:15:33 -06:00
|
|
|
use eth_trie_utils::partial_trie::PartialTrie;
|
2022-10-16 10:11:45 -07:00
|
|
|
use ethereum_types::{BigEndianHash, H256};
|
2022-10-01 21:55:47 -07:00
|
|
|
|
|
|
|
|
use crate::cpu::kernel::aggregator::KERNEL;
|
|
|
|
|
use crate::cpu::kernel::interpreter::Interpreter;
|
2022-10-16 10:11:45 -07:00
|
|
|
use crate::cpu::kernel::tests::mpt::{extension_to_leaf, test_account_1_rlp, test_account_2_rlp};
|
|
|
|
|
use crate::generation::mpt::all_mpt_prover_inputs_reversed;
|
2022-10-01 21:55:47 -07:00
|
|
|
use crate::generation::TrieInputs;
|
|
|
|
|
|
2022-10-06 16:05:28 -07:00
|
|
|
// TODO: Test with short leaf. Might need to be a storage trie.
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn mpt_hash_empty() -> Result<()> {
|
|
|
|
|
let trie_inputs = TrieInputs {
|
|
|
|
|
state_trie: Default::default(),
|
|
|
|
|
transactions_trie: Default::default(),
|
|
|
|
|
receipts_trie: Default::default(),
|
|
|
|
|
storage_tries: vec![],
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
test_state_trie(trie_inputs)
|
|
|
|
|
}
|
|
|
|
|
|
2022-10-01 21:55:47 -07:00
|
|
|
#[test]
|
2022-10-16 10:11:45 -07:00
|
|
|
fn mpt_hash_empty_branch() -> Result<()> {
|
|
|
|
|
let children = std::array::from_fn(|_| PartialTrie::Empty.into());
|
|
|
|
|
let state_trie = PartialTrie::Branch {
|
|
|
|
|
children,
|
|
|
|
|
value: vec![],
|
|
|
|
|
};
|
|
|
|
|
let trie_inputs = TrieInputs {
|
|
|
|
|
state_trie,
|
|
|
|
|
transactions_trie: Default::default(),
|
|
|
|
|
receipts_trie: Default::default(),
|
|
|
|
|
storage_tries: vec![],
|
2022-10-04 15:12:44 -07:00
|
|
|
};
|
2022-10-16 10:11:45 -07:00
|
|
|
test_state_trie(trie_inputs)
|
|
|
|
|
}
|
2022-10-01 21:55:47 -07:00
|
|
|
|
2022-10-16 10:11:45 -07:00
|
|
|
#[test]
|
|
|
|
|
fn mpt_hash_hash() -> Result<()> {
|
|
|
|
|
let hash = H256::random();
|
|
|
|
|
let trie_inputs = TrieInputs {
|
|
|
|
|
state_trie: PartialTrie::Hash(hash),
|
|
|
|
|
transactions_trie: Default::default(),
|
|
|
|
|
receipts_trie: Default::default(),
|
|
|
|
|
storage_tries: vec![],
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
test_state_trie(trie_inputs)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn mpt_hash_leaf() -> Result<()> {
|
2022-10-01 21:55:47 -07:00
|
|
|
let state_trie = PartialTrie::Leaf {
|
2022-10-31 15:15:10 -06:00
|
|
|
nibbles: 0xABC_u64.into(),
|
2022-10-16 10:11:45 -07:00
|
|
|
value: test_account_1_rlp(),
|
2022-10-01 21:55:47 -07:00
|
|
|
};
|
|
|
|
|
let trie_inputs = TrieInputs {
|
|
|
|
|
state_trie,
|
|
|
|
|
transactions_trie: Default::default(),
|
|
|
|
|
receipts_trie: Default::default(),
|
|
|
|
|
storage_tries: vec![],
|
|
|
|
|
};
|
2022-10-06 16:05:28 -07:00
|
|
|
test_state_trie(trie_inputs)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
2022-10-06 20:50:32 -07:00
|
|
|
fn mpt_hash_extension_to_leaf() -> Result<()> {
|
2022-10-16 10:11:45 -07:00
|
|
|
let state_trie = extension_to_leaf(test_account_1_rlp());
|
2022-10-06 20:50:32 -07:00
|
|
|
let trie_inputs = TrieInputs {
|
|
|
|
|
state_trie,
|
|
|
|
|
transactions_trie: Default::default(),
|
|
|
|
|
receipts_trie: Default::default(),
|
|
|
|
|
storage_tries: vec![],
|
|
|
|
|
};
|
|
|
|
|
test_state_trie(trie_inputs)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn mpt_hash_branch_to_leaf() -> Result<()> {
|
2022-10-06 16:05:28 -07:00
|
|
|
let leaf = PartialTrie::Leaf {
|
2022-10-31 15:15:10 -06:00
|
|
|
nibbles: 0xABC_u64.into(),
|
2022-10-16 10:11:45 -07:00
|
|
|
value: test_account_2_rlp(),
|
2022-10-11 20:15:33 -06:00
|
|
|
}
|
|
|
|
|
.into();
|
|
|
|
|
let mut children = std::array::from_fn(|_| PartialTrie::Empty.into());
|
|
|
|
|
children[3] = leaf;
|
2022-10-06 16:05:28 -07:00
|
|
|
let state_trie = PartialTrie::Branch {
|
|
|
|
|
children,
|
|
|
|
|
value: vec![],
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
let trie_inputs = TrieInputs {
|
|
|
|
|
state_trie,
|
|
|
|
|
transactions_trie: Default::default(),
|
|
|
|
|
receipts_trie: Default::default(),
|
|
|
|
|
storage_tries: vec![],
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
test_state_trie(trie_inputs)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn test_state_trie(trie_inputs: TrieInputs) -> Result<()> {
|
2022-10-01 21:55:47 -07:00
|
|
|
let load_all_mpts = KERNEL.global_labels["load_all_mpts"];
|
|
|
|
|
let mpt_hash_state_trie = KERNEL.global_labels["mpt_hash_state_trie"];
|
|
|
|
|
|
2022-10-06 16:05:28 -07:00
|
|
|
let initial_stack = vec![0xDEADBEEFu32.into()];
|
2022-10-01 21:55:47 -07:00
|
|
|
let mut interpreter = Interpreter::new_with_kernel(load_all_mpts, initial_stack);
|
|
|
|
|
interpreter.generation_state.mpt_prover_inputs = all_mpt_prover_inputs_reversed(&trie_inputs);
|
|
|
|
|
interpreter.run()?;
|
|
|
|
|
assert_eq!(interpreter.stack(), vec![]);
|
|
|
|
|
|
|
|
|
|
// Now, execute mpt_hash_state_trie.
|
|
|
|
|
interpreter.offset = mpt_hash_state_trie;
|
|
|
|
|
interpreter.push(0xDEADBEEFu32.into());
|
|
|
|
|
interpreter.run()?;
|
|
|
|
|
|
2022-10-06 16:05:28 -07:00
|
|
|
assert_eq!(
|
|
|
|
|
interpreter.stack().len(),
|
|
|
|
|
1,
|
|
|
|
|
"Expected 1 item on stack, found {:?}",
|
|
|
|
|
interpreter.stack()
|
|
|
|
|
);
|
2022-10-01 21:55:47 -07:00
|
|
|
let hash = H256::from_uint(&interpreter.stack()[0]);
|
2022-10-06 16:05:28 -07:00
|
|
|
let expected_state_trie_hash = trie_inputs.state_trie.calc_hash();
|
|
|
|
|
assert_eq!(hash, expected_state_trie_hash);
|
2022-10-01 21:55:47 -07:00
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
|
}
|