Skip to content

Commit

Permalink
add unit test case
Browse files Browse the repository at this point in the history
  • Loading branch information
KaoImin committed Sep 27, 2023
1 parent 592fdef commit f000c0f
Showing 1 changed file with 41 additions and 1 deletion.
42 changes: 41 additions & 1 deletion core/run/src/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,11 @@ use common_config_parser::types::{
Config, ConfigValueParser,
};
use common_crypto::Secp256k1RecoverablePrivateKey;
use core_executor::{AxonExecutorApplyAdapter, MetadataHandle};
use protocol::{
codec::hex_decode,
tokio,
types::{RichBlock, H256},
types::{Header, Metadata, Proposal, RichBlock, H256},
};

use crate::{components::chain_spec::ChainSpecExt as _, execute_transactions, DatabaseGroup};
Expand Down Expand Up @@ -116,6 +117,8 @@ async fn check_genesis_data<'a>(case: &TestCase<'a>) {
};
let genesis = chain_spec.generate_genesis_block(key);

assert!(genesis.txs.is_empty());

println!("checking genesis hash");
check_hashes(
case.chain_name,
Expand Down Expand Up @@ -164,6 +167,10 @@ async fn check_genesis_data<'a>(case: &TestCase<'a>) {
])
.expect("execute transactions");

let mut header = genesis.block.header.clone();
header.state_root = resp.state_root;
header.receipts_root = resp.receipt_root;

println!("checking state root");
check_hashes(
case.chain_name,
Expand All @@ -180,9 +187,35 @@ async fn check_genesis_data<'a>(case: &TestCase<'a>) {
resp.receipt_root,
);

println!("checking state");
check_state(&chain_spec, &header, &db_group);

set_current_dir(current_dir).expect("change back to original work directory");
}

fn check_state(spec: &ChainSpec, genesis_header: &Header, db_group: &DatabaseGroup) {
let backend = AxonExecutorApplyAdapter::from_root(
genesis_header.state_root,
db_group.trie_db(),
db_group.storage(),
Proposal::new_without_state_root(genesis_header).into(),
)
.unwrap();

let metadata_0 = spec.params.clone();
let metadata_1 = {
let mut tmp = metadata_0.clone();
tmp.epoch = metadata_0.epoch + 1;
tmp.version.start = metadata_0.version.end + 1;
tmp.version.end = tmp.version.start + metadata_0.version.end - 1;
tmp
};
let handle = MetadataHandle::new(backend.get_metadata_root());

assert_metadata(metadata_0, handle.get_metadata_by_epoch(0).unwrap());
assert_metadata(metadata_1, handle.get_metadata_by_epoch(1).unwrap());
}

fn check_hashes(chain: &str, name: &str, expected_str: &str, actual: H256) {
let expected = H256::from_str(expected_str)
.unwrap_or_else(|err| panic!("failed to parse hash {name} of chain {chain} since {err}"));
Expand All @@ -192,6 +225,13 @@ fn check_hashes(chain: &str, name: &str, expected_str: &str, actual: H256) {
);
}

fn assert_metadata(metadata_0: Metadata, metadata_1: Metadata) {
assert_eq!(metadata_0.version, metadata_1.version);
assert_eq!(metadata_0.epoch, metadata_1.epoch);
assert_eq!(metadata_0.verifier_list, metadata_1.verifier_list);
assert_eq!(metadata_0.consensus_config, metadata_1.consensus_config);
}

fn copy_dir(src: impl AsRef<Path>, dst: impl AsRef<Path>) -> io::Result<()> {
fs::create_dir_all(&dst)?;
for entry in fs::read_dir(src)? {
Expand Down

0 comments on commit f000c0f

Please sign in to comment.