2016-02-05 13:40:41 +01:00
|
|
|
// Copyright 2015, 2016 Ethcore (UK) Ltd.
|
|
|
|
// This file is part of Parity.
|
|
|
|
|
|
|
|
// Parity is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
|
|
|
|
// Parity is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2016-01-12 16:20:29 +01:00
|
|
|
use super::test_common::*;
|
|
|
|
use evm;
|
|
|
|
|
|
|
|
fn do_json_test(json_data: &[u8]) -> Vec<String> {
|
|
|
|
let json = Json::from_str(::std::str::from_utf8(json_data).unwrap()).expect("Json is invalid");
|
|
|
|
let mut failed = Vec::new();
|
|
|
|
let old_schedule = evm::Schedule::new_frontier();
|
|
|
|
let new_schedule = evm::Schedule::new_homestead();
|
2016-02-04 23:48:29 +01:00
|
|
|
let ot = RefCell::new(None);
|
2016-01-12 16:20:29 +01:00
|
|
|
for (name, test) in json.as_object().unwrap() {
|
|
|
|
let mut fail = false;
|
2016-01-19 13:47:30 +01:00
|
|
|
let mut fail_unless = |cond: bool| if !cond && !fail { failed.push(name.clone()); println!("Transaction: {:?}", ot.borrow()); fail = true };
|
2016-01-12 16:20:29 +01:00
|
|
|
let schedule = match test.find("blocknumber")
|
|
|
|
.and_then(|j| j.as_string())
|
|
|
|
.and_then(|s| BlockNumber::from_str(s).ok())
|
2016-01-29 14:43:18 +01:00
|
|
|
.unwrap_or(0) { x if x < 1_000_000 => &old_schedule, _ => &new_schedule };
|
2016-01-14 21:58:37 +01:00
|
|
|
let rlp = Bytes::from_json(&test["rlp"]);
|
2016-02-04 23:48:29 +01:00
|
|
|
let res = UntrustedRlp::new(&rlp).as_val().map_err(From::from).and_then(|t: SignedTransaction| t.validate(schedule, schedule.have_delegate_call));
|
2016-01-12 16:20:29 +01:00
|
|
|
fail_unless(test.find("transaction").is_none() == res.is_err());
|
|
|
|
if let (Some(&Json::Object(ref tx)), Some(&Json::String(ref expect_sender))) = (test.find("transaction"), test.find("sender")) {
|
|
|
|
let t = res.unwrap();
|
|
|
|
fail_unless(t.sender().unwrap() == address_from_hex(clean(expect_sender)));
|
2016-01-14 21:58:37 +01:00
|
|
|
fail_unless(t.data == Bytes::from_json(&tx["data"]));
|
2016-01-14 21:23:46 +01:00
|
|
|
fail_unless(t.gas == xjson!(&tx["gasLimit"]));
|
|
|
|
fail_unless(t.gas_price == xjson!(&tx["gasPrice"]));
|
|
|
|
fail_unless(t.nonce == xjson!(&tx["nonce"]));
|
|
|
|
fail_unless(t.value == xjson!(&tx["value"]));
|
2016-01-12 16:20:29 +01:00
|
|
|
if let Action::Call(ref to) = t.action {
|
2016-02-04 23:48:29 +01:00
|
|
|
*ot.borrow_mut() = Some(t.clone());
|
2016-01-14 21:58:37 +01:00
|
|
|
fail_unless(to == &xjson!(&tx["to"]));
|
2016-01-12 16:20:29 +01:00
|
|
|
} else {
|
2016-02-04 23:48:29 +01:00
|
|
|
*ot.borrow_mut() = Some(t.clone());
|
2016-01-19 13:47:30 +01:00
|
|
|
fail_unless(Bytes::from_json(&tx["to"]).is_empty());
|
2016-01-12 16:20:29 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-01-19 13:47:30 +01:00
|
|
|
for f in &failed {
|
2016-01-12 16:20:29 +01:00
|
|
|
println!("FAILED: {:?}", f);
|
|
|
|
}
|
|
|
|
failed
|
|
|
|
}
|
|
|
|
|
|
|
|
// Once we have interpolate idents.
|
|
|
|
/*macro_rules! declare_test {
|
|
|
|
($test_set_name: ident / $name: ident) => {
|
|
|
|
#[test]
|
|
|
|
#[allow(non_snake_case)]
|
|
|
|
fn $name() {
|
|
|
|
assert!(do_json_test(include_bytes!(concat!("../res/ethereum/tests/", stringify!($test_set_name), "/", stringify!($name), ".json"))).len() == 0);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
($test_set_name: ident / $prename: ident / $name: ident) => {
|
|
|
|
#[test]
|
|
|
|
#[allow(non_snake_case)]
|
|
|
|
interpolate_idents! { fn [$prename _ $name]()
|
|
|
|
{
|
|
|
|
let json = include_bytes!(concat!("../res/ethereum/tests/", stringify!($test_set_name), "/", stringify!($prename), "/", stringify!($name), ".json"));
|
|
|
|
assert!(do_json_test(json).len() == 0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
declare_test!{TransactionTests/ttTransactionTest}
|
|
|
|
declare_test!{TransactionTests/tt10mbDataField}
|
|
|
|
declare_test!{TransactionTests/ttWrongRLPTransaction}
|
|
|
|
declare_test!{TransactionTests/Homestead/ttTransactionTest}
|
2016-01-21 19:32:48 +01:00
|
|
|
declare_test!{heavy => TransactionTests/Homestead/tt10mbDataField}
|
2016-01-12 16:20:29 +01:00
|
|
|
declare_test!{TransactionTests/Homestead/ttWrongRLPTransaction}
|
|
|
|
declare_test!{TransactionTests/RandomTests/tr201506052141PYTHON}*/
|
|
|
|
|
|
|
|
declare_test!{TransactionTests_ttTransactionTest, "TransactionTests/ttTransactionTest"}
|
2016-01-22 08:07:53 +01:00
|
|
|
declare_test!{heavy => TransactionTests_tt10mbDataField, "TransactionTests/tt10mbDataField"}
|
2016-01-12 16:20:29 +01:00
|
|
|
declare_test!{TransactionTests_ttWrongRLPTransaction, "TransactionTests/ttWrongRLPTransaction"}
|
|
|
|
declare_test!{TransactionTests_Homestead_ttTransactionTest, "TransactionTests/Homestead/ttTransactionTest"}
|
2016-01-21 19:32:48 +01:00
|
|
|
declare_test!{heavy => TransactionTests_Homestead_tt10mbDataField, "TransactionTests/Homestead/tt10mbDataField"}
|
2016-01-12 16:20:29 +01:00
|
|
|
declare_test!{TransactionTests_Homestead_ttWrongRLPTransaction, "TransactionTests/Homestead/ttWrongRLPTransaction"}
|
|
|
|
declare_test!{TransactionTests_RandomTests_tr201506052141PYTHON, "TransactionTests/RandomTests/tr201506052141PYTHON"}
|