2016-05-26 16:59:59 +02:00
|
|
|
//! RPC unit test moduleS
|
2016-03-11 10:17:20 +01:00
|
|
|
|
2016-03-17 23:58:30 +01:00
|
|
|
pub mod helpers;
|
2016-05-26 16:59:59 +02:00
|
|
|
|
2016-05-27 18:40:48 +02:00
|
|
|
// extract a chain from the given JSON file,
|
|
|
|
// stored in ethcore/res/ethereum/tests/.
|
|
|
|
//
|
|
|
|
// usage:
|
|
|
|
// `extract_chain!("Folder/File")` will load Folder/File.json and extract
|
|
|
|
// the first block chain stored within.
|
|
|
|
//
|
|
|
|
// `extract_chain!("Folder/File", "with_name")` will load Folder/File.json and
|
|
|
|
// extract the chain with that name. This will panic if no chain by that name
|
|
|
|
// is found.
|
|
|
|
macro_rules! extract_chain {
|
2016-05-31 19:30:40 +02:00
|
|
|
(iter $file:expr) => {{
|
2016-05-27 18:40:48 +02:00
|
|
|
const RAW_DATA: &'static [u8] =
|
|
|
|
include_bytes!(concat!("../../../../ethcore/res/ethereum/tests/", $file, ".json"));
|
2016-05-31 19:30:40 +02:00
|
|
|
::ethjson::blockchain::Test::load(RAW_DATA).unwrap().into_iter()
|
|
|
|
}};
|
|
|
|
|
|
|
|
($file:expr, $name:expr) => {{
|
2016-05-27 18:40:48 +02:00
|
|
|
let mut chain = None;
|
2016-05-31 19:30:40 +02:00
|
|
|
for (name, c) in extract_chain!(iter $file) {
|
2016-05-27 18:40:48 +02:00
|
|
|
if name == $name {
|
|
|
|
chain = Some(c);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
chain.unwrap()
|
|
|
|
}};
|
|
|
|
|
|
|
|
($file:expr) => {{
|
2016-05-31 19:30:40 +02:00
|
|
|
extract_chain!(iter $file).next().unwrap().1
|
2016-05-27 18:40:48 +02:00
|
|
|
}};
|
|
|
|
}
|
|
|
|
|
2016-05-31 19:30:40 +02:00
|
|
|
macro_rules! register_test {
|
|
|
|
($name:ident, $cb:expr, $file:expr) => {
|
|
|
|
#[test]
|
|
|
|
fn $name() {
|
|
|
|
for (name, chain) in extract_chain!(iter $file) {
|
|
|
|
$cb(name, chain);
|
|
|
|
}
|
|
|
|
}
|
2016-05-31 19:51:24 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
(heavy $name:ident, $cb:expr, $file:expr) => {
|
|
|
|
#[test]
|
|
|
|
#[cfg(feature = "test-heavy")]
|
|
|
|
fn $name() {
|
|
|
|
for (name, chain) in extract_chain!(iter $file) {
|
|
|
|
$cb(name, chain);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
(ignore $name:ident, $cb:expr, $file:expr) => {
|
|
|
|
#[test]
|
|
|
|
#[ignore]
|
|
|
|
fn $name() {
|
|
|
|
for (name, chain) in extract_chain!(iter $file) {
|
|
|
|
$cb(name, chain);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2016-05-31 19:30:40 +02:00
|
|
|
}
|
|
|
|
|
2016-03-17 23:58:30 +01:00
|
|
|
#[cfg(test)]
|
2016-05-26 16:59:59 +02:00
|
|
|
mod mocked;
|
2016-05-04 14:03:29 +02:00
|
|
|
#[cfg(test)]
|
2016-05-27 18:40:48 +02:00
|
|
|
mod eth;
|