141 lines
3.8 KiB
Rust
Raw Normal View History

2024-02-03 12:21:38 -05:00
use anyhow::Result;
use eth_trie_utils::partial_trie::PartialTrie;
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;
use crate::cpu::kernel::tests::account_code::initialize_mpts;
use crate::cpu::kernel::tests::mpt::{extension_to_leaf, test_account_1_rlp, test_account_2_rlp};
2022-10-01 21:55:47 -07:00
use crate::generation::TrieInputs;
2023-03-27 17:30:11 -06:00
use crate::Node;
2022-10-01 21:55:47 -07:00
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]
fn mpt_hash_empty_branch() -> Result<()> {
2023-03-27 17:30:11 -06:00
let children = core::array::from_fn(|_| Node::Empty.into());
let state_trie = Node::Branch {
children,
value: vec![],
2023-03-27 17:30:11 -06:00
}
.into();
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
};
test_state_trie(trie_inputs)
}
2022-10-01 21:55:47 -07:00
#[test]
fn mpt_hash_hash() -> Result<()> {
let hash = H256::random();
let trie_inputs = TrieInputs {
2023-03-27 17:30:11 -06:00
state_trie: Node::Hash(hash).into(),
transactions_trie: Default::default(),
receipts_trie: Default::default(),
storage_tries: vec![],
};
test_state_trie(trie_inputs)
}
#[test]
fn mpt_hash_leaf() -> Result<()> {
2023-03-27 17:30:11 -06:00
let state_trie = Node::Leaf {
2022-10-31 15:15:10 -06:00
nibbles: 0xABC_u64.into(),
value: test_account_1_rlp(),
2023-03-27 17:30:11 -06:00
}
.into();
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<()> {
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<()> {
2023-03-27 17:30:11 -06:00
let leaf = Node::Leaf {
2022-10-31 15:15:10 -06:00
nibbles: 0xABC_u64.into(),
value: test_account_2_rlp(),
2022-10-11 20:15:33 -06:00
}
.into();
2023-03-27 17:30:11 -06:00
let mut children = core::array::from_fn(|_| Node::Empty.into());
2022-10-11 20:15:33 -06:00
children[3] = leaf;
2023-03-27 17:30:11 -06:00
let state_trie = Node::Branch {
2022-10-06 16:05:28 -07:00
children,
value: vec![],
2023-03-27 17:30:11 -06:00
}
.into();
2022-10-06 16:05:28 -07:00
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 mpt_hash_state_trie = KERNEL.global_labels["mpt_hash_state_trie"];
let initial_stack = vec![];
let mut interpreter = Interpreter::new_with_kernel(0, initial_stack);
initialize_mpts(&mut interpreter, &trie_inputs);
2022-10-01 21:55:47 -07:00
assert_eq!(interpreter.stack(), vec![]);
// Now, execute mpt_hash_state_trie.
2022-12-02 19:18:37 -08:00
interpreter.generation_state.registers.program_counter = mpt_hash_state_trie;
interpreter
.push(0xDEADBEEFu32.into())
.expect("The stack should not overflow");
interpreter
.push(1.into()) // Initial length of the trie data segment, unused.
.expect("The stack should not overflow");
2022-10-01 21:55:47 -07:00
interpreter.run()?;
2022-10-06 16:05:28 -07:00
assert_eq!(
interpreter.stack().len(),
2,
"Expected 2 items on stack, found {:?}",
2022-10-06 16:05:28 -07:00
interpreter.stack()
);
let hash = H256::from_uint(&interpreter.stack()[1]);
2023-03-27 17:30:11 -06:00
let expected_state_trie_hash = trie_inputs.state_trie.hash();
2022-10-06 16:05:28 -07:00
assert_eq!(hash, expected_state_trie_hash);
2022-10-01 21:55:47 -07:00
Ok(())
}