openethereum/rpc/src/v1/tests/helpers/miner_service.rs

80 lines
2.9 KiB
Rust
Raw Normal View History

2016-03-13 17:01:50 +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-03-18 19:16:46 +01:00
//! Test implementation of miner service.
2016-03-16 10:48:31 +01:00
use util::{Address, H256, Bytes};
2016-03-13 17:01:50 +01:00
use util::standard::*;
use ethcore::error::Error;
use ethcore::client::BlockChainClient;
use ethcore::block::ClosedBlock;
use ethcore::transaction::SignedTransaction;
use ethminer::{MinerService, MinerStatus, AccountDetails};
2016-03-13 17:01:50 +01:00
2016-03-18 19:16:46 +01:00
/// Test miner service.
2016-03-16 10:37:08 +01:00
pub struct TestMinerService {
2016-03-18 19:16:46 +01:00
/// Imported transactions.
2016-03-16 10:37:08 +01:00
pub imported_transactions: RwLock<Vec<H256>>,
2016-03-18 19:16:46 +01:00
/// Latest closed block.
2016-03-16 10:37:08 +01:00
pub latest_closed_block: Mutex<Option<ClosedBlock>>,
}
impl Default for TestMinerService {
fn default() -> TestMinerService {
TestMinerService {
imported_transactions: RwLock::new(Vec::new()),
latest_closed_block: Mutex::new(None),
}
}
}
2016-03-13 17:01:50 +01:00
impl MinerService for TestMinerService {
/// Returns miner's status.
fn status(&self) -> MinerStatus {
MinerStatus {
transactions_in_pending_queue: 0,
transactions_in_future_queue: 0,
transactions_in_pending_block: 1
}
}
2016-03-13 17:01:50 +01:00
/// Imports transactions to transaction queue.
fn import_transactions<T>(&self, _transactions: Vec<SignedTransaction>, _fetch_account: T) -> Vec<Result<(), Error>>
where T: Fn(&Address) -> AccountDetails { unimplemented!(); }
2016-03-13 17:01:50 +01:00
/// Returns hashes of transactions currently in pending
fn pending_transactions_hashes(&self) -> Vec<H256> { vec![] }
2016-03-13 17:01:50 +01:00
/// Removes all transactions from the queue and restart mining operation.
fn clear_and_reset(&self, _chain: &BlockChainClient) { unimplemented!(); }
/// Called when blocks are imported to chain, updates transactions queue.
fn chain_new_blocks(&self, _chain: &BlockChainClient, _imported: &[H256], _invalid: &[H256], _enacted: &[H256], _retracted: &[H256]) { unimplemented!(); }
/// New chain head event. Restart mining operation.
fn update_sealing(&self, _chain: &BlockChainClient) { unimplemented!(); }
2016-03-13 17:01:50 +01:00
/// Grab the `ClosedBlock` that we want to be sealed. Comes as a mutex that you have to lock.
2016-03-16 10:37:08 +01:00
fn sealing_block(&self, _chain: &BlockChainClient) -> &Mutex<Option<ClosedBlock>> {
&self.latest_closed_block
}
2016-03-13 17:01:50 +01:00
/// Submit `seal` as a valid solution for the header of `pow_hash`.
/// Will check the seal, but not actually insert the block into the chain.
fn submit_seal(&self, _chain: &BlockChainClient, _pow_hash: H256, _seal: Vec<Bytes>) -> Result<(), Error> { unimplemented!(); }
2016-03-16 10:37:08 +01:00
}