2016-04-11 21:06:32 +02: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/>.
|
|
|
|
|
|
|
|
use std::sync::Arc;
|
2016-08-11 17:19:20 +02:00
|
|
|
use util::log::RotatingLogger;
|
2016-11-06 12:51:53 +01:00
|
|
|
use util::Address;
|
2016-08-11 17:19:20 +02:00
|
|
|
use ethsync::ManageNetwork;
|
2016-11-06 12:51:53 +01:00
|
|
|
use ethcore::account_provider::AccountProvider;
|
2016-11-16 17:54:54 +01:00
|
|
|
use ethcore::client::{TestBlockChainClient};
|
|
|
|
use ethcore::miner::LocalTransactionStatus;
|
2016-10-15 14:44:08 +02:00
|
|
|
use ethstore::ethkey::{Generator, Random};
|
2016-08-11 17:19:20 +02:00
|
|
|
|
2016-04-11 21:06:32 +02:00
|
|
|
use jsonrpc_core::IoHandler;
|
2016-11-06 12:51:53 +01:00
|
|
|
use v1::{Parity, ParityClient};
|
2016-09-21 12:44:49 +02:00
|
|
|
use v1::helpers::{SignerService, NetworkSettings};
|
2016-11-06 12:51:53 +01:00
|
|
|
use v1::tests::helpers::{TestSyncProvider, Config, TestMinerService};
|
2016-08-11 17:19:20 +02:00
|
|
|
use super::manage_network::TestManageNetwork;
|
2016-04-11 21:06:32 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
pub type TestParityClient = ParityClient<TestBlockChainClient, TestMinerService, TestSyncProvider>;
|
2016-04-21 19:19:42 +02:00
|
|
|
|
2016-10-24 12:21:15 +02:00
|
|
|
pub struct Dependencies {
|
|
|
|
pub miner: Arc<TestMinerService>,
|
|
|
|
pub client: Arc<TestBlockChainClient>,
|
|
|
|
pub sync: Arc<TestSyncProvider>,
|
|
|
|
pub logger: Arc<RotatingLogger>,
|
|
|
|
pub settings: Arc<NetworkSettings>,
|
|
|
|
pub network: Arc<ManageNetwork>,
|
2016-11-06 12:51:53 +01:00
|
|
|
pub accounts: Arc<AccountProvider>,
|
2016-11-09 19:41:47 +01:00
|
|
|
pub dapps_interface: Option<String>,
|
2016-10-24 12:21:15 +02:00
|
|
|
pub dapps_port: Option<u16>,
|
2016-08-11 17:19:20 +02:00
|
|
|
}
|
|
|
|
|
2016-10-24 12:21:15 +02:00
|
|
|
impl Dependencies {
|
|
|
|
pub fn new() -> Self {
|
|
|
|
Dependencies {
|
|
|
|
miner: Arc::new(TestMinerService::default()),
|
|
|
|
client: Arc::new(TestBlockChainClient::default()),
|
|
|
|
sync: Arc::new(TestSyncProvider::new(Config {
|
2016-11-03 22:22:25 +01:00
|
|
|
network_id: 3,
|
2016-10-24 12:21:15 +02:00
|
|
|
num_peers: 120,
|
|
|
|
})),
|
|
|
|
logger: Arc::new(RotatingLogger::new("rpc=trace".to_owned())),
|
|
|
|
settings: Arc::new(NetworkSettings {
|
|
|
|
name: "mynode".to_owned(),
|
|
|
|
chain: "testchain".to_owned(),
|
|
|
|
network_port: 30303,
|
|
|
|
rpc_enabled: true,
|
|
|
|
rpc_interface: "all".to_owned(),
|
|
|
|
rpc_port: 8545,
|
|
|
|
}),
|
|
|
|
network: Arc::new(TestManageNetwork),
|
2016-11-06 12:51:53 +01:00
|
|
|
accounts: Arc::new(AccountProvider::transient_provider()),
|
2016-11-09 19:41:47 +01:00
|
|
|
dapps_interface: Some("127.0.0.1".into()),
|
2016-10-24 12:21:15 +02:00
|
|
|
dapps_port: Some(18080),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
pub fn client(&self, signer: Option<Arc<SignerService>>) -> TestParityClient {
|
|
|
|
ParityClient::new(
|
2016-10-24 12:21:15 +02:00
|
|
|
&self.client,
|
|
|
|
&self.miner,
|
|
|
|
&self.sync,
|
|
|
|
&self.network,
|
2016-11-06 12:51:53 +01:00
|
|
|
&self.accounts,
|
2016-10-24 12:21:15 +02:00
|
|
|
self.logger.clone(),
|
|
|
|
self.settings.clone(),
|
|
|
|
signer,
|
2016-11-09 19:41:47 +01:00
|
|
|
self.dapps_interface.clone(),
|
2016-10-24 12:21:15 +02:00
|
|
|
self.dapps_port,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn default_client(&self) -> IoHandler {
|
|
|
|
let io = IoHandler::new();
|
|
|
|
io.add_delegate(self.client(None).to_delegate());
|
|
|
|
io
|
|
|
|
}
|
|
|
|
|
|
|
|
fn with_signer(&self, signer: SignerService) -> IoHandler {
|
|
|
|
let io = IoHandler::new();
|
|
|
|
io.add_delegate(self.client(Some(Arc::new(signer))).to_delegate());
|
|
|
|
io
|
|
|
|
}
|
2016-06-07 22:52:48 +02:00
|
|
|
}
|
|
|
|
|
2016-04-11 21:06:32 +02:00
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_extra_data() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-11 21:06:32 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_extraData", "params": [], "id": 1}"#;
|
2016-04-11 21:06:32 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":"0x01020304","id":1}"#;
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-11 21:06:32 +02:00
|
|
|
}
|
|
|
|
|
2016-05-08 22:34:15 +02:00
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_default_extra_data() {
|
2016-05-08 22:34:15 +02:00
|
|
|
use util::misc;
|
|
|
|
use util::ToPretty;
|
|
|
|
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-05-08 22:34:15 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_defaultExtraData", "params": [], "id": 1}"#;
|
2016-05-08 22:34:15 +02:00
|
|
|
let response = format!(r#"{{"jsonrpc":"2.0","result":"0x{}","id":1}}"#, misc::version_data().to_hex());
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response));
|
2016-05-08 22:34:15 +02:00
|
|
|
}
|
2016-04-11 21:06:32 +02:00
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_gas_floor_target() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-11 21:06:32 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_gasFloorTarget", "params": [], "id": 1}"#;
|
2016-04-11 21:06:32 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":"0x3039","id":1}"#;
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-11 21:06:32 +02:00
|
|
|
}
|
|
|
|
|
2016-04-13 00:04:40 +02:00
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_min_gas_price() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-13 00:04:40 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_minGasPrice", "params": [], "id": 1}"#;
|
2016-09-02 11:38:16 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":"0x1312d00","id":1}"#;
|
2016-04-13 00:04:40 +02:00
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-13 00:04:40 +02:00
|
|
|
}
|
|
|
|
|
2016-04-19 19:08:13 +02:00
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_dev_logs() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
deps.logger.append("a".to_owned());
|
|
|
|
deps.logger.append("b".to_owned());
|
|
|
|
|
|
|
|
let io = deps.default_client();
|
2016-04-19 19:08:13 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_devLogs", "params":[], "id": 1}"#;
|
2016-04-19 19:08:13 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":["b","a"],"id":1}"#;
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-19 19:08:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_dev_logs_levels() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-19 19:08:13 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_devLogsLevels", "params":[], "id": 1}"#;
|
2016-04-19 19:08:13 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":"rpc=trace","id":1}"#;
|
2016-04-18 23:13:38 +02:00
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-19 19:38:41 +02:00
|
|
|
}
|
|
|
|
|
2016-04-18 23:13:38 +02:00
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_transactions_limit() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-18 23:13:38 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_transactionsLimit", "params":[], "id": 1}"#;
|
2016-04-18 23:13:38 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":1024,"id":1}"#;
|
2016-04-19 19:08:13 +02:00
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-19 19:08:13 +02:00
|
|
|
}
|
2016-04-21 19:19:42 +02:00
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_net_chain() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-21 19:19:42 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_netChain", "params":[], "id": 1}"#;
|
2016-04-21 19:19:42 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":"testchain","id":1}"#;
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-21 19:19:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_net_peers() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-21 19:19:42 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_netPeers", "params":[], "id": 1}"#;
|
2016-10-12 20:18:59 +02:00
|
|
|
let response = "{\"jsonrpc\":\"2.0\",\"result\":{\"active\":0,\"connected\":120,\"max\":50,\"peers\":[{\"caps\":[\"eth/62\",\"eth/63\"],\
|
|
|
|
\"id\":\"node1\",\"name\":\"Parity/1\",\"network\":{\"localAddress\":\"127.0.0.1:8888\",\"remoteAddress\":\"127.0.0.1:7777\"}\
|
|
|
|
,\"protocols\":{\"eth\":{\"difficulty\":\"0x28\",\"head\":\"0000000000000000000000000000000000000000000000000000000000000032\"\
|
|
|
|
,\"version\":62}}},{\"caps\":[\"eth/63\",\"eth/64\"],\"id\":null,\"name\":\"Parity/2\",\"network\":{\"localAddress\":\
|
|
|
|
\"127.0.0.1:3333\",\"remoteAddress\":\"Handshake\"},\"protocols\":{\"eth\":{\"difficulty\":null,\"head\":\
|
|
|
|
\"000000000000000000000000000000000000000000000000000000000000003c\",\"version\":64}}}]},\"id\":1}";
|
2016-04-21 19:19:42 +02:00
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-21 19:19:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_net_port() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-21 19:19:42 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_netPort", "params":[], "id": 1}"#;
|
2016-04-21 19:19:42 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":30303,"id":1}"#;
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-21 19:19:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_rpc_settings() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-21 19:19:42 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_rpcSettings", "params":[], "id": 1}"#;
|
2016-04-21 19:19:42 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":{"enabled":true,"interface":"all","port":8545},"id":1}"#;
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-21 19:19:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_node_name() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-04-21 19:19:42 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_nodeName", "params":[], "id": 1}"#;
|
2016-04-21 19:19:42 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":"mynode","id":1}"#;
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-04-21 19:19:42 +02:00
|
|
|
}
|
2016-06-21 14:55:25 +02:00
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_unsigned_transactions_count() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
2016-11-09 19:41:47 +01:00
|
|
|
let io = deps.with_signer(SignerService::new_test(Some(("127.0.0.1".into(), 18180))));
|
2016-06-21 14:55:25 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_unsignedTransactionsCount", "params":[], "id": 1}"#;
|
2016-06-21 14:55:25 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":0,"id":1}"#;
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-06-21 14:55:25 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_unsigned_transactions_count_when_signer_disabled() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-06-21 14:55:25 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_unsignedTransactionsCount", "params":[], "id": 1}"#;
|
2016-06-21 14:55:25 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","error":{"code":-32030,"message":"Trusted Signer is disabled. This API is not available.","data":null},"id":1}"#;
|
|
|
|
|
2016-09-01 12:00:00 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-06-21 14:55:25 +02:00
|
|
|
}
|
2016-09-23 18:13:03 +02:00
|
|
|
|
2016-09-27 16:27:06 +02:00
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_pending_transactions() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-09-23 18:13:03 +02:00
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_pendingTransactions", "params":[], "id": 1}"#;
|
2016-09-23 18:13:03 +02:00
|
|
|
let response = r#"{"jsonrpc":"2.0","result":[],"id":1}"#;
|
|
|
|
|
2016-09-26 12:24:52 +02:00
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
2016-09-23 18:13:03 +02:00
|
|
|
}
|
2016-10-15 14:44:08 +02:00
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_encrypt() {
|
2016-10-24 12:21:15 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
2016-10-15 14:44:08 +02:00
|
|
|
let key = format!("{:?}", Random.generate().unwrap().public());
|
|
|
|
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_encryptMessage", "params":["0x"#.to_owned() + &key + r#"", "0x01"], "id": 1}"#;
|
2016-10-15 14:44:08 +02:00
|
|
|
assert!(io.handle_request_sync(&request).unwrap().contains("result"), "Should return success.");
|
|
|
|
}
|
2016-10-24 12:21:15 +02:00
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_signer_port() {
|
2016-10-24 12:21:15 +02:00
|
|
|
// given
|
|
|
|
let deps = Dependencies::new();
|
2016-11-09 19:41:47 +01:00
|
|
|
let io1 = deps.with_signer(SignerService::new_test(Some(("127.0.0.1".into(), 18180))));
|
2016-10-24 12:21:15 +02:00
|
|
|
let io2 = deps.default_client();
|
|
|
|
|
|
|
|
// when
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_signerPort", "params": [], "id": 1}"#;
|
2016-10-24 12:21:15 +02:00
|
|
|
let response1 = r#"{"jsonrpc":"2.0","result":18180,"id":1}"#;
|
|
|
|
let response2 = r#"{"jsonrpc":"2.0","error":{"code":-32030,"message":"Trusted Signer is disabled. This API is not available.","data":null},"id":1}"#;
|
|
|
|
|
|
|
|
// then
|
|
|
|
assert_eq!(io1.handle_request_sync(request), Some(response1.to_owned()));
|
|
|
|
assert_eq!(io2.handle_request_sync(request), Some(response2.to_owned()));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_dapps_port() {
|
2016-10-24 12:21:15 +02:00
|
|
|
// given
|
|
|
|
let mut deps = Dependencies::new();
|
|
|
|
let io1 = deps.default_client();
|
|
|
|
deps.dapps_port = None;
|
|
|
|
let io2 = deps.default_client();
|
|
|
|
|
|
|
|
// when
|
2016-11-06 12:51:53 +01:00
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_dappsPort", "params": [], "id": 1}"#;
|
2016-10-24 12:21:15 +02:00
|
|
|
let response1 = r#"{"jsonrpc":"2.0","result":18080,"id":1}"#;
|
2016-11-09 19:41:47 +01:00
|
|
|
let response2 = r#"{"jsonrpc":"2.0","error":{"code":-32031,"message":"Dapps Server is disabled. This API is not available.","data":null},"id":1}"#;
|
|
|
|
|
|
|
|
// then
|
|
|
|
assert_eq!(io1.handle_request_sync(request), Some(response1.to_owned()));
|
|
|
|
assert_eq!(io2.handle_request_sync(request), Some(response2.to_owned()));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rpc_parity_dapps_interface() {
|
|
|
|
// given
|
|
|
|
let mut deps = Dependencies::new();
|
|
|
|
let io1 = deps.default_client();
|
|
|
|
deps.dapps_interface = None;
|
|
|
|
let io2 = deps.default_client();
|
|
|
|
|
|
|
|
// when
|
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_dappsInterface", "params": [], "id": 1}"#;
|
|
|
|
let response1 = r#"{"jsonrpc":"2.0","result":"127.0.0.1","id":1}"#;
|
2016-10-24 12:21:15 +02:00
|
|
|
let response2 = r#"{"jsonrpc":"2.0","error":{"code":-32031,"message":"Dapps Server is disabled. This API is not available.","data":null},"id":1}"#;
|
|
|
|
|
|
|
|
// then
|
|
|
|
assert_eq!(io1.handle_request_sync(request), Some(response1.to_owned()));
|
|
|
|
assert_eq!(io2.handle_request_sync(request), Some(response2.to_owned()));
|
|
|
|
}
|
2016-10-27 19:29:55 +02:00
|
|
|
|
|
|
|
#[test]
|
2016-11-06 12:51:53 +01:00
|
|
|
fn rpc_parity_next_nonce() {
|
2016-10-27 19:29:55 +02:00
|
|
|
let deps = Dependencies::new();
|
|
|
|
let address = Address::default();
|
|
|
|
let io1 = deps.default_client();
|
|
|
|
let deps = Dependencies::new();
|
|
|
|
deps.miner.last_nonces.write().insert(address.clone(), 2.into());
|
|
|
|
let io2 = deps.default_client();
|
|
|
|
|
|
|
|
let request = r#"{
|
|
|
|
"jsonrpc": "2.0",
|
2016-11-06 12:51:53 +01:00
|
|
|
"method": "parity_nextNonce",
|
2016-10-27 19:29:55 +02:00
|
|
|
"params": [""#.to_owned() + &format!("0x{:?}", address) + r#""],
|
|
|
|
"id": 1
|
|
|
|
}"#;
|
|
|
|
let response1 = r#"{"jsonrpc":"2.0","result":"0x0","id":1}"#;
|
|
|
|
let response2 = r#"{"jsonrpc":"2.0","result":"0x3","id":1}"#;
|
|
|
|
|
|
|
|
assert_eq!(io1.handle_request_sync(&request), Some(response1.to_owned()));
|
|
|
|
assert_eq!(io2.handle_request_sync(&request), Some(response2.to_owned()));
|
|
|
|
}
|
2016-11-16 13:37:21 +01:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn rpc_parity_transactions_stats() {
|
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
|
|
|
|
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_pendingTransactionsStats", "params":[], "id": 1}"#;
|
|
|
|
let response = r#"{"jsonrpc":"2.0","result":{"0x0000000000000000000000000000000000000000000000000000000000000001":{"firstSeen":10,"propagatedTo":{"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000080":16}},"0x0000000000000000000000000000000000000000000000000000000000000005":{"firstSeen":16,"propagatedTo":{"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000010":1}}},"id":1}"#;
|
|
|
|
|
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
|
|
|
}
|
|
|
|
|
2016-11-16 17:54:54 +01:00
|
|
|
#[test]
|
|
|
|
fn rpc_parity_local_transactions() {
|
|
|
|
let deps = Dependencies::new();
|
|
|
|
let io = deps.default_client();
|
|
|
|
deps.miner.local_transactions.lock().insert(10.into(), LocalTransactionStatus::Pending);
|
|
|
|
deps.miner.local_transactions.lock().insert(15.into(), LocalTransactionStatus::Future);
|
|
|
|
|
|
|
|
let request = r#"{"jsonrpc": "2.0", "method": "parity_localTransactions", "params":[], "id": 1}"#;
|
|
|
|
let response = r#"{"jsonrpc":"2.0","result":{"0x000000000000000000000000000000000000000000000000000000000000000a":{"status":"pending"},"0x000000000000000000000000000000000000000000000000000000000000000f":{"status":"future"}},"id":1}"#;
|
|
|
|
|
|
|
|
assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
|
|
|
|
}
|
|
|
|
|