extern crate alloc;
#[macro_export]
macro_rules! build_test {
($source:expr $(, $tail:expr)* $(,)?) => {{
let core_lib = miden_core_lib::CoreLibrary::default();
let source = $source;
miden_utils_testing::build_test_by_mode!(false, source $(, $tail)*)
.with_library(core_lib.package())
.with_event_handlers(core_lib.handlers())
}}
}
#[macro_export]
macro_rules! build_debug_test {
($source:expr $(, $tail:expr)* $(,)?) => {{
let core_lib = miden_core_lib::CoreLibrary::default();
let source = $source;
miden_utils_testing::build_test_by_mode!(true, source $(, $tail)*)
.with_library(core_lib.package())
.with_event_handlers(core_lib.handlers())
}}
}
#[macro_export]
macro_rules! expect_assert_error_message {
($test:expr $(,)?) => {
::miden_utils_testing::expect_exec_error_matches!(
$test,
::miden_processor::ExecutionError::OperationError {
err: ::miden_processor::operation::OperationError::FailedAssertion {
..
},
..
}
);
};
($test:expr, $min_len:expr $(,)?) => {
::miden_utils_testing::expect_exec_error_matches!(
$test,
::miden_processor::ExecutionError::OperationError {
err: ::miden_processor::operation::OperationError::FailedAssertion {
err_msg,
..
},
..
}
if err_msg.as_deref().map(|msg| msg.len() > $min_len).unwrap_or(false)
);
};
($test:expr, contains $needle:expr $(,)?) => {
::miden_utils_testing::expect_exec_error_matches!(
$test,
::miden_processor::ExecutionError::OperationError {
err: ::miden_processor::operation::OperationError::FailedAssertion {
err_msg,
..
},
..
}
if err_msg
.as_deref()
.map(|msg| msg.len() > 5 && msg.contains($needle))
.unwrap_or(false)
);
};
}
#[macro_export]
macro_rules! expect_assert_error_code_from_msg {
($test:expr, $msg:expr $(,)?) => {
::miden_utils_testing::expect_exec_error_matches!(
$test,
::miden_processor::ExecutionError::OperationError {
err: ::miden_processor::operation::OperationError::FailedAssertion {
err_code,
err_msg,
},
..
}
if err_code == ::miden_core::mast::error_code_from_msg($msg) && err_msg.is_none()
);
};
}
#[test]
fn core_library_does_not_export_precompile_impl_helpers() {
use miden_core_lib::CoreLibrary;
let core_lib = CoreLibrary::default();
let package = core_lib.package();
let public_paths = [
"::miden::core::crypto::hashes::keccak256::hash_bytes",
"::miden::core::crypto::hashes::sha512::hash_bytes",
"::miden::core::crypto::dsa::ecdsa_k256_keccak::verify_prehash",
"::miden::core::crypto::dsa::eddsa_ed25519::verify",
];
for path in public_paths {
assert!(
package.get_procedure_root_by_path(path).is_some(),
"expected public wrapper to be exported: {path}",
);
}
let internal_paths = [
"::miden::core::crypto::hashes::keccak256::hash_bytes_impl",
"::miden::core::crypto::hashes::sha512::hash_bytes_impl",
"::miden::core::crypto::dsa::ecdsa_k256_keccak::verify_prehash_impl",
"::miden::core::crypto::dsa::eddsa_ed25519::verify_message",
"::miden::core::crypto::dsa::eddsa_ed25519::verify_message_impl",
"::miden::core::crypto::dsa::eddsa_ed25519::verify_prehash",
];
for path in internal_paths {
assert!(
package.get_procedure_root_by_path(path).is_none(),
"internal precompile helper must not be exported: {path}",
);
}
}
#[test]
fn core_library_does_not_export_fri_preprocess_test_helper() {
use miden_core_lib::CoreLibrary;
let core_lib = CoreLibrary::default();
let package = core_lib.package();
assert!(
package
.get_procedure_root_by_path("::miden::core::pcs::fri::frie2f4::preprocess")
.is_none(),
"FRI preprocess helper must not be exported by corelib",
);
}
mod collections;
mod crypto;
mod helpers;
mod mast_forest_merge;
mod math;
mod mem;
mod stark_asserts;
mod sys;
mod word;
mod stark;