Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

Recover transaction pool on light client #3833

Merged
merged 48 commits into from
Nov 28, 2019
Merged
Show file tree
Hide file tree
Changes from 30 commits
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
34ea521
recover tx pool on light client
svyatonik Oct 14, 2019
4b6b1c9
Merge branch 'master' into light_tx_pool3
svyatonik Oct 16, 2019
5b207b9
revert local tests fix
svyatonik Oct 16, 2019
28b0388
removed import renamings
svyatonik Oct 22, 2019
736cabe
futures03::Future -> std::future::Future
svyatonik Oct 22, 2019
2d485e7
Update core/transaction-pool/graph/src/error.rs
svyatonik Oct 22, 2019
eecb819
replace remove_from_ready with remove_invalid
svyatonik Oct 22, 2019
b5cdc4e
avoid excess hashing
svyatonik Oct 22, 2019
184420b
Merge branch 'light_tx_pool3' of https://github.com/paritytech/substr…
svyatonik Oct 22, 2019
bf9d91b
debug -> warn
svyatonik Oct 22, 2019
e9f0d33
TransactionPool + BasicTransactionPool
svyatonik Oct 23, 2019
fc5406e
pause future tx reject when resubmitting
svyatonik Oct 23, 2019
a349d20
bump impl_version to make CI happy
svyatonik Oct 23, 2019
7e6712a
Merge branch 'master' into light_tx_pool3
svyatonik Oct 23, 2019
30c2a05
and revert back local test fixes
svyatonik Oct 23, 2019
b1340ab
alter doc to restart CI
svyatonik Oct 23, 2019
b283fc3
Transaction::clone() -> Transaction::duplicate()
svyatonik Oct 24, 2019
92c4eea
transactions -> updated_tranasctions
svyatonik Oct 24, 2019
1faa209
remove explicit consensus-common ref
svyatonik Oct 24, 2019
a8318ba
::std:: -> std::
svyatonik Oct 24, 2019
3a220bf
manual set/unset flag -> calling clusore with given flag value
svyatonik Oct 24, 2019
1c2f75e
removed comments
svyatonik Oct 24, 2019
f645a41
removed force argument
svyatonik Oct 24, 2019
441a771
BestIterator -> Box<Iterator>
svyatonik Oct 24, 2019
8d67a59
separate crate for TxPool + Maintainer trait
svyatonik Oct 25, 2019
3db29ec
long line fix
svyatonik Oct 25, 2019
a3e4662
Merge branch 'master' into light_tx_pool3
svyatonik Oct 25, 2019
b21f3ca
Merge branch 'master' into light_tx_pool3
svyatonik Nov 12, 2019
0edc893
pos-merge fix
svyatonik Nov 12, 2019
3a26f36
fix benches compilation
svyatonik Nov 12, 2019
50e99f2
Rename txpoolapi to txpool_api
tomusdrw Nov 22, 2019
a014b9f
Merge branch 'master' into light_tx_pool3
tomusdrw Nov 22, 2019
d7e67a5
Clean up.
tomusdrw Nov 22, 2019
deaedd2
Finalize merge.
tomusdrw Nov 23, 2019
6660f98
Merge branch 'master' into light_tx_pool3
svyatonik Nov 25, 2019
b6b4473
post-merge fix
svyatonik Nov 25, 2019
d36edbc
Move transaction pool api to primitives directly.
tomusdrw Nov 25, 2019
53b86fc
Consistent naming for txpool-runtime-api
tomusdrw Nov 25, 2019
2ce206b
Warn about missing docs.
tomusdrw Nov 25, 2019
446647d
Move abstraction for offchain calls to tx-pool-api.
tomusdrw Nov 25, 2019
1bd6c28
Merge RPC instantiation.
tomusdrw Nov 25, 2019
6e5d0cd
Merge branch 'master' into light_tx_pool3
tomusdrw Nov 26, 2019
f141a45
Update cargo.lock
tomusdrw Nov 26, 2019
416f609
Merge branch 'master' into light_tx_pool3
tomusdrw Nov 27, 2019
aa37301
Post merge fixes.
tomusdrw Nov 27, 2019
564d1f0
Avoid depending on client.
tomusdrw Nov 27, 2019
159a3a4
Merge branch 'master' into light_tx_pool3
gavofyork Nov 27, 2019
a90a7cd
Fix build
gavofyork Nov 27, 2019
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 26 additions & 2 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ members = [
"core/test-runtime",
"core/test-runtime/client",
"core/transaction-pool",
"core/transaction-pool/api",
"core/transaction-pool/graph",
"core/transaction-pool/runtime-api",
"core/trie",
Expand Down
3 changes: 2 additions & 1 deletion core/basic-authorship/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,9 @@ client = { package = "substrate-client", path = "../../core/client" }
consensus_common = { package = "substrate-consensus-common", path = "../../core/consensus/common" }
inherents = { package = "substrate-inherents", path = "../inherents" }
substrate-telemetry = { path = "../telemetry" }
transaction_pool = { package = "substrate-transaction-pool", path = "../transaction-pool" }
txpoolapi = { package = "substrate-transaction-pool-api", path = "../../core/transaction-pool/api" }
block-builder = { package = "substrate-block-builder", path = "../block-builder" }

[dev-dependencies]
test-client = { package = "substrate-test-runtime-client", path = "../../core/test-runtime/client" }
txpool = { package = "substrate-transaction-pool", path = "../../core/transaction-pool" }
40 changes: 21 additions & 19 deletions core/basic-authorship/src/basic_authorship.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,22 +32,22 @@ use sr_primitives::{
},
generic::BlockId,
};
use transaction_pool::txpool::{self, Pool as TransactionPool};
use txpoolapi::{TransactionPool, InPoolTransaction};
use substrate_telemetry::{telemetry, CONSENSUS_INFO};
use block_builder::BlockBuilderApi;

/// Proposer factory.
pub struct ProposerFactory<C, A> where A: txpool::ChainApi {
pub struct ProposerFactory<C, A> where A: TransactionPool {
/// The client instance.
pub client: Arc<C>,
/// The transaction pool.
pub transaction_pool: Arc<TransactionPool<A>>,
pub transaction_pool: Arc<A>,
}

impl<B, E, Block, RA, A> consensus_common::Environment<Block> for
ProposerFactory<SubstrateClient<B, E, Block, RA>, A>
where
A: txpool::ChainApi<Block=Block>,
A: TransactionPool<Block=Block>,
B: client::backend::Backend<Block, Blake2Hasher> + Send + Sync + 'static,
E: CallExecutor<Block, Blake2Hasher> + Send + Sync + Clone + 'static,
Block: BlockT<Hash=H256>,
Expand Down Expand Up @@ -83,19 +83,19 @@ where
}

/// The proposer logic.
pub struct Proposer<Block: BlockT, C, A: txpool::ChainApi> {
pub struct Proposer<Block: BlockT, C, A: TransactionPool> {
client: Arc<C>,
parent_hash: <Block as BlockT>::Hash,
parent_id: BlockId<Block>,
parent_number: <<Block as BlockT>::Header as HeaderT>::Number,
transaction_pool: Arc<TransactionPool<A>>,
transaction_pool: Arc<A>,
now: Box<dyn Fn() -> time::Instant>,
}

impl<B, E, Block, RA, A> consensus_common::Proposer<Block> for
Proposer<Block, SubstrateClient<B, E, Block, RA>, A>
where
A: txpool::ChainApi<Block=Block>,
A: TransactionPool<Block=Block>,
B: client::backend::Backend<Block, Blake2Hasher> + Send + Sync + 'static,
E: CallExecutor<Block, Blake2Hasher> + Send + Sync + Clone + 'static,
Block: BlockT<Hash=H256>,
Expand All @@ -120,7 +120,7 @@ where
}

impl<Block, B, E, RA, A> Proposer<Block, SubstrateClient<B, E, Block, RA>, A> where
A: txpool::ChainApi<Block=Block>,
A: TransactionPool<Block=Block>,
B: client::backend::Backend<Block, Blake2Hasher> + Send + Sync + 'static,
E: CallExecutor<Block, Blake2Hasher> + Send + Sync + Clone + 'static,
Block: BlockT<Hash=H256>,
Expand Down Expand Up @@ -161,21 +161,23 @@ impl<Block, B, E, RA, A> Proposer<Block, SubstrateClient<B, E, Block, RA>, A> wh
let pending_iterator = self.transaction_pool.ready();

debug!("Attempting to push transactions from the pool.");
for pending in pending_iterator {
for pending_tx in pending_iterator {
if (self.now)() > deadline {
debug!("Consensus deadline reached when pushing block transactions, proceeding with proposing.");
break;
}

trace!("[{:?}] Pushing to the block.", pending.hash);
match block_builder::BlockBuilder::push(&mut block_builder, pending.data.clone()) {
let pending_tx_data = pending_tx.data().clone();
let pending_tx_hash = pending_tx.hash().clone();
trace!("[{:?}] Pushing to the block.", pending_tx_hash);
match block_builder::BlockBuilder::push(&mut block_builder, pending_tx_data) {
Ok(()) => {
debug!("[{:?}] Pushed to the block.", pending.hash);
debug!("[{:?}] Pushed to the block.", pending_tx_hash);
}
Err(error::Error::ApplyExtrinsicFailed(e)) if e.exhausted_resources() => {
if is_first {
debug!("[{:?}] Invalid transaction: FullBlock on empty block", pending.hash);
unqueue_invalid.push(pending.hash.clone());
debug!("[{:?}] Invalid transaction: FullBlock on empty block", pending_tx_hash);
unqueue_invalid.push(pending_tx_hash);
} else if skipped < MAX_SKIPPED_TRANSACTIONS {
skipped += 1;
debug!(
Expand All @@ -188,8 +190,8 @@ impl<Block, B, E, RA, A> Proposer<Block, SubstrateClient<B, E, Block, RA>, A> wh
}
}
Err(e) => {
debug!("[{:?}] Invalid transaction: {}", pending.hash, e);
unqueue_invalid.push(pending.hash.clone());
debug!("[{:?}] Invalid transaction: {}", pending_tx_hash, e);
unqueue_invalid.push(pending_tx_hash);
}
}

Expand Down Expand Up @@ -234,6 +236,7 @@ mod tests {
use std::cell::RefCell;
use consensus_common::{Environment, Proposer};
use test_client::{self, runtime::{Extrinsic, Transfer}, AccountKeyring};
use txpool::{BasicPool, FullChainApi};

fn extrinsic(nonce: u64) -> Extrinsic {
Transfer {
Expand All @@ -248,11 +251,10 @@ mod tests {
fn should_cease_building_block_when_deadline_is_reached() {
// given
let client = Arc::new(test_client::new());
let chain_api = transaction_pool::FullChainApi::new(client.clone());
let txpool = Arc::new(TransactionPool::new(Default::default(), chain_api));
let txpool = Arc::new(BasicPool::new(Default::default(), FullChainApi::new(client.clone())));

futures::executor::block_on(
txpool.submit_at(&BlockId::number(0), vec![extrinsic(0), extrinsic(1)], false)
txpool.submit_at(&BlockId::number(0), vec![extrinsic(0), extrinsic(1)])
).unwrap();

let mut proposer_factory = ProposerFactory {
Expand Down
5 changes: 2 additions & 3 deletions core/basic-authorship/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,10 +24,9 @@
//! # use sr_primitives::generic::BlockId;
//! # use std::{sync::Arc, time::Duration};
//! # use test_client::{self, runtime::{Extrinsic, Transfer}, AccountKeyring};
//! # use transaction_pool::txpool::{self, Pool as TransactionPool};
//! # use txpool::{BasicPool, FullChainApi};
//! # let client = Arc::new(test_client::new());
//! # let chain_api = transaction_pool::FullChainApi::new(client.clone());
//! # let txpool = Arc::new(TransactionPool::new(Default::default(), chain_api));
//! # let txpool = Arc::new(BasicPool::new(Default::default(), FullChainApi::new(client.clone())));
//! // The first step is to create a `ProposerFactory`.
//! let mut proposer_factory = ProposerFactory {
//! client: client.clone(),
Expand Down
25 changes: 20 additions & 5 deletions core/client/src/light/fetcher.rs
Original file line number Diff line number Diff line change
Expand Up @@ -146,15 +146,30 @@ pub struct RemoteBodyRequest<Header: HeaderT> {
/// is correct (see FetchedDataChecker) and return already checked data.
pub trait Fetcher<Block: BlockT>: Send + Sync {
/// Remote header future.
type RemoteHeaderResult: Future<Output = Result<Block::Header, ClientError>> + Send + 'static;
type RemoteHeaderResult: Future<Output = Result<
Block::Header,
ClientError,
>> + Unpin + Send + 'static;
/// Remote storage read future.
type RemoteReadResult: Future<Output = Result<HashMap<Vec<u8>, Option<Vec<u8>>>, ClientError>> + Send + 'static;
type RemoteReadResult: Future<Output = Result<
HashMap<Vec<u8>, Option<Vec<u8>>>,
ClientError,
>> + Unpin + Send + 'static;
/// Remote call result future.
type RemoteCallResult: Future<Output = Result<Vec<u8>, ClientError>> + Send + 'static;
type RemoteCallResult: Future<Output = Result<
Vec<u8>,
ClientError,
>> + Unpin + Send + 'static;
/// Remote changes result future.
type RemoteChangesResult: Future<Output = Result<Vec<(NumberFor<Block>, u32)>, ClientError>> + Send + 'static;
type RemoteChangesResult: Future<Output = Result<
Vec<(NumberFor<Block>, u32)>,
ClientError,
>> + Unpin + Send + 'static;
/// Remote block body result future.
type RemoteBodyResult: Future<Output = Result<Vec<Block::Extrinsic>, ClientError>> + Send + 'static;
type RemoteBodyResult: Future<Output = Result<
Vec<Block::Extrinsic>,
ClientError,
>> + Unpin + Send + 'static;

/// Fetch remote header.
fn remote_header(&self, request: RemoteHeaderRequest<Block::Header>) -> Self::RemoteHeaderResult;
Expand Down
3 changes: 2 additions & 1 deletion core/offchain/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ parking_lot = "0.9.0"
primitives = { package = "substrate-primitives", path = "../../core/primitives" }
rand = "0.7.2"
sr-primitives = { path = "../../core/sr-primitives" }
transaction_pool = { package = "substrate-transaction-pool", path = "../../core/transaction-pool" }
txpoolapi = { package = "substrate-transaction-pool-api", path = "../../core/transaction-pool/api" }
svyatonik marked this conversation as resolved.
Show resolved Hide resolved
network = { package = "substrate-network", path = "../../core/network" }
keystore = { package = "substrate-keystore", path = "../keystore" }

Expand All @@ -36,6 +36,7 @@ env_logger = "0.7.0"
client-db = { package = "substrate-client-db", path = "../../core/client/db/", default-features = true }
test-client = { package = "substrate-test-runtime-client", path = "../../core/test-runtime/client" }
tokio = "0.1.22"
txpool = { package = "substrate-transaction-pool", path = "../../core/transaction-pool" }

[features]
default = []
Loading