mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-22 04:31:02 +00:00
002d9260f9
**Update:** Pushed additional changes based on the review comments. **This pull request fixes various spelling mistakes in this repository.** Most of the changes are contained in the first **3** commits: - `Fix spelling mistakes in comments and docs` - `Fix spelling mistakes in test names` - `Fix spelling mistakes in error messages, panic messages, logs and tracing` Other source code spelling mistakes are separated into individual commits for easier reviewing: - `Fix the spelling of 'authority'` - `Fix the spelling of 'REASONABLE_HEADERS_IN_JUSTIFICATION_ANCESTRY'` - `Fix the spelling of 'prev_enqueud_messages'` - `Fix the spelling of 'endpoint'` - `Fix the spelling of 'children'` - `Fix the spelling of 'PenpalSiblingSovereignAccount'` - `Fix the spelling of 'PenpalSudoAccount'` - `Fix the spelling of 'insufficient'` - `Fix the spelling of 'PalletXcmExtrinsicsBenchmark'` - `Fix the spelling of 'subtracted'` - `Fix the spelling of 'CandidatePendingAvailability'` - `Fix the spelling of 'exclusive'` - `Fix the spelling of 'until'` - `Fix the spelling of 'discriminator'` - `Fix the spelling of 'nonexistent'` - `Fix the spelling of 'subsystem'` - `Fix the spelling of 'indices'` - `Fix the spelling of 'committed'` - `Fix the spelling of 'topology'` - `Fix the spelling of 'response'` - `Fix the spelling of 'beneficiary'` - `Fix the spelling of 'formatted'` - `Fix the spelling of 'UNKNOWN_PROOF_REQUEST'` - `Fix the spelling of 'succeeded'` - `Fix the spelling of 'reopened'` - `Fix the spelling of 'proposer'` - `Fix the spelling of 'InstantiationNonce'` - `Fix the spelling of 'depositor'` - `Fix the spelling of 'expiration'` - `Fix the spelling of 'phantom'` - `Fix the spelling of 'AggregatedKeyValue'` - `Fix the spelling of 'randomness'` - `Fix the spelling of 'defendant'` - `Fix the spelling of 'AquaticMammal'` - `Fix the spelling of 'transactions'` - `Fix the spelling of 'PassingTracingSubscriber'` - `Fix the spelling of 'TxSignaturePayload'` - `Fix the spelling of 'versioning'` - `Fix the spelling of 'descendant'` - `Fix the spelling of 'overridden'` - `Fix the spelling of 'network'` Let me know if this structure is adequate. **Note:** The usage of the words `Merkle`, `Merkelize`, `Merklization`, `Merkelization`, `Merkleization`, is somewhat inconsistent but I left it as it is. ~~**Note:** In some places the term `Receival` is used to refer to message reception, IMO `Reception` is the correct word here, but I left it as it is.~~ ~~**Note:** In some places the term `Overlayed` is used instead of the more acceptable version `Overlaid` but I also left it as it is.~~ ~~**Note:** In some places the term `Applyable` is used instead of the correct version `Applicable` but I also left it as it is.~~ **Note:** Some usage of British vs American english e.g. `judgement` vs `judgment`, `initialise` vs `initialize`, `optimise` vs `optimize` etc. are both present in different places, but I suppose that's understandable given the number of contributors. ~~**Note:** There is a spelling mistake in `.github/CODEOWNERS` but it triggers errors in CI when I make changes to it, so I left it as it is.~~
236 lines
7.1 KiB
Rust
236 lines
7.1 KiB
Rust
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// This file is part of Polkadot.
|
|
|
|
// Polkadot 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.
|
|
|
|
// Polkadot 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 Polkadot. If not, see <http://www.gnu.org/licenses/>.
|
|
//
|
|
|
|
//! Mock data and utility functions for unit tests in this subsystem.
|
|
|
|
use std::{
|
|
collections::{HashMap, HashSet},
|
|
sync::Arc,
|
|
time::Instant,
|
|
};
|
|
|
|
use async_trait::async_trait;
|
|
use lazy_static::lazy_static;
|
|
|
|
use polkadot_node_network_protocol::{authority_discovery::AuthorityDiscovery, PeerId};
|
|
use sc_keystore::LocalKeystore;
|
|
use sp_application_crypto::AppCrypto;
|
|
use sp_keyring::Sr25519Keyring;
|
|
use sp_keystore::{Keystore, KeystorePtr};
|
|
|
|
use polkadot_node_primitives::{DisputeMessage, SignedDisputeStatement};
|
|
use polkadot_primitives::{
|
|
AuthorityDiscoveryId, CandidateHash, CandidateReceipt, Hash, SessionIndex, SessionInfo,
|
|
ValidatorId, ValidatorIndex,
|
|
};
|
|
use polkadot_primitives_test_helpers::dummy_candidate_descriptor;
|
|
|
|
use crate::LOG_TARGET;
|
|
|
|
pub const MOCK_SESSION_INDEX: SessionIndex = 1;
|
|
pub const MOCK_NEXT_SESSION_INDEX: SessionIndex = 2;
|
|
pub const MOCK_VALIDATORS: [Sr25519Keyring; 6] = [
|
|
Sr25519Keyring::Ferdie,
|
|
Sr25519Keyring::Alice,
|
|
Sr25519Keyring::Bob,
|
|
Sr25519Keyring::Charlie,
|
|
Sr25519Keyring::Dave,
|
|
Sr25519Keyring::Eve,
|
|
];
|
|
|
|
pub const MOCK_AUTHORITIES_NEXT_SESSION: [Sr25519Keyring; 2] =
|
|
[Sr25519Keyring::One, Sr25519Keyring::Two];
|
|
|
|
pub const FERDIE_INDEX: ValidatorIndex = ValidatorIndex(0);
|
|
pub const ALICE_INDEX: ValidatorIndex = ValidatorIndex(1);
|
|
pub const BOB_INDEX: ValidatorIndex = ValidatorIndex(2);
|
|
pub const CHARLIE_INDEX: ValidatorIndex = ValidatorIndex(3);
|
|
|
|
lazy_static! {
|
|
|
|
/// Mocked `AuthorityDiscovery` service.
|
|
pub static ref MOCK_AUTHORITY_DISCOVERY: MockAuthorityDiscovery = MockAuthorityDiscovery::new();
|
|
// Creating an innocent looking `SessionInfo` is really expensive in a debug build. Around
|
|
// 700ms on my machine, We therefore cache those keys here:
|
|
pub static ref MOCK_VALIDATORS_DISCOVERY_KEYS: HashMap<Sr25519Keyring, AuthorityDiscoveryId> =
|
|
MOCK_VALIDATORS
|
|
.iter()
|
|
.chain(MOCK_AUTHORITIES_NEXT_SESSION.iter())
|
|
.map(|v| (*v, v.public().into()))
|
|
.collect()
|
|
;
|
|
pub static ref FERDIE_DISCOVERY_KEY: AuthorityDiscoveryId =
|
|
MOCK_VALIDATORS_DISCOVERY_KEYS.get(&Sr25519Keyring::Ferdie).unwrap().clone();
|
|
|
|
pub static ref MOCK_SESSION_INFO: SessionInfo =
|
|
SessionInfo {
|
|
validators: MOCK_VALIDATORS.iter().take(4).map(|k| k.public().into()).collect(),
|
|
discovery_keys: MOCK_VALIDATORS
|
|
.iter()
|
|
.map(|k| MOCK_VALIDATORS_DISCOVERY_KEYS.get(&k).unwrap().clone())
|
|
.collect(),
|
|
assignment_keys: vec![],
|
|
validator_groups: Default::default(),
|
|
n_cores: 0,
|
|
zeroth_delay_tranche_width: 0,
|
|
relay_vrf_modulo_samples: 0,
|
|
n_delay_tranches: 0,
|
|
no_show_slots: 0,
|
|
needed_approvals: 0,
|
|
active_validator_indices: vec![],
|
|
dispute_period: 6,
|
|
random_seed: [0u8; 32],
|
|
};
|
|
|
|
/// `SessionInfo` for the second session. (No more validators, but two more authorities.
|
|
pub static ref MOCK_NEXT_SESSION_INFO: SessionInfo =
|
|
SessionInfo {
|
|
discovery_keys:
|
|
MOCK_AUTHORITIES_NEXT_SESSION
|
|
.iter()
|
|
.map(|k| MOCK_VALIDATORS_DISCOVERY_KEYS.get(&k).unwrap().clone())
|
|
.collect(),
|
|
validators: Default::default(),
|
|
assignment_keys: vec![],
|
|
validator_groups: Default::default(),
|
|
n_cores: 0,
|
|
zeroth_delay_tranche_width: 0,
|
|
relay_vrf_modulo_samples: 0,
|
|
n_delay_tranches: 0,
|
|
no_show_slots: 0,
|
|
needed_approvals: 0,
|
|
active_validator_indices: vec![],
|
|
dispute_period: 6,
|
|
random_seed: [0u8; 32],
|
|
};
|
|
}
|
|
|
|
pub fn make_candidate_receipt(relay_parent: Hash) -> CandidateReceipt {
|
|
CandidateReceipt {
|
|
descriptor: dummy_candidate_descriptor(relay_parent),
|
|
commitments_hash: Hash::random(),
|
|
}
|
|
}
|
|
|
|
pub fn make_explicit_signed(
|
|
validator: Sr25519Keyring,
|
|
candidate_hash: CandidateHash,
|
|
valid: bool,
|
|
) -> SignedDisputeStatement {
|
|
let keystore: KeystorePtr = Arc::new(LocalKeystore::in_memory());
|
|
Keystore::sr25519_generate_new(&*keystore, ValidatorId::ID, Some(&validator.to_seed()))
|
|
.expect("Insert key into keystore");
|
|
|
|
SignedDisputeStatement::sign_explicit(
|
|
&keystore,
|
|
valid,
|
|
candidate_hash,
|
|
MOCK_SESSION_INDEX,
|
|
validator.public().into(),
|
|
)
|
|
.expect("Keystore should be fine.")
|
|
.expect("Signing should work.")
|
|
}
|
|
|
|
pub fn make_dispute_message(
|
|
candidate: CandidateReceipt,
|
|
valid_validator: ValidatorIndex,
|
|
invalid_validator: ValidatorIndex,
|
|
) -> DisputeMessage {
|
|
let candidate_hash = candidate.hash();
|
|
let before_request = Instant::now();
|
|
let valid_vote =
|
|
make_explicit_signed(MOCK_VALIDATORS[valid_validator.0 as usize], candidate_hash, true);
|
|
gum::trace!(
|
|
"Passed time for valid vote: {:#?}",
|
|
Instant::now().saturating_duration_since(before_request)
|
|
);
|
|
let before_request = Instant::now();
|
|
let invalid_vote =
|
|
make_explicit_signed(MOCK_VALIDATORS[invalid_validator.0 as usize], candidate_hash, false);
|
|
gum::trace!(
|
|
"Passed time for invalid vote: {:#?}",
|
|
Instant::now().saturating_duration_since(before_request)
|
|
);
|
|
DisputeMessage::from_signed_statements(
|
|
valid_vote,
|
|
valid_validator,
|
|
invalid_vote,
|
|
invalid_validator,
|
|
candidate,
|
|
&MOCK_SESSION_INFO,
|
|
)
|
|
.expect("DisputeMessage construction should work.")
|
|
}
|
|
|
|
/// Dummy `AuthorityDiscovery` service.
|
|
#[derive(Debug, Clone)]
|
|
pub struct MockAuthorityDiscovery {
|
|
peer_ids: HashMap<Sr25519Keyring, PeerId>,
|
|
}
|
|
|
|
impl MockAuthorityDiscovery {
|
|
pub fn new() -> Self {
|
|
let mut peer_ids = HashMap::new();
|
|
peer_ids.insert(Sr25519Keyring::Alice, PeerId::random());
|
|
peer_ids.insert(Sr25519Keyring::Bob, PeerId::random());
|
|
peer_ids.insert(Sr25519Keyring::Ferdie, PeerId::random());
|
|
peer_ids.insert(Sr25519Keyring::Charlie, PeerId::random());
|
|
peer_ids.insert(Sr25519Keyring::Dave, PeerId::random());
|
|
peer_ids.insert(Sr25519Keyring::Eve, PeerId::random());
|
|
peer_ids.insert(Sr25519Keyring::One, PeerId::random());
|
|
peer_ids.insert(Sr25519Keyring::Two, PeerId::random());
|
|
|
|
Self { peer_ids }
|
|
}
|
|
|
|
pub fn get_peer_id_by_authority(&self, authority: Sr25519Keyring) -> PeerId {
|
|
*self.peer_ids.get(&authority).expect("Tester only picks valid authorities")
|
|
}
|
|
}
|
|
|
|
#[async_trait]
|
|
impl AuthorityDiscovery for MockAuthorityDiscovery {
|
|
async fn get_addresses_by_authority_id(
|
|
&mut self,
|
|
_authority: polkadot_primitives::AuthorityDiscoveryId,
|
|
) -> Option<HashSet<sc_network::Multiaddr>> {
|
|
panic!("Not implemented");
|
|
}
|
|
|
|
async fn get_authority_ids_by_peer_id(
|
|
&mut self,
|
|
peer_id: polkadot_node_network_protocol::PeerId,
|
|
) -> Option<HashSet<polkadot_primitives::AuthorityDiscoveryId>> {
|
|
for (a, p) in self.peer_ids.iter() {
|
|
if p == &peer_id {
|
|
let result =
|
|
HashSet::from([MOCK_VALIDATORS_DISCOVERY_KEYS.get(&a).unwrap().clone()]);
|
|
gum::trace!(
|
|
target: LOG_TARGET,
|
|
%peer_id,
|
|
?result,
|
|
"Returning authority ids for peer id"
|
|
);
|
|
return Some(result)
|
|
}
|
|
}
|
|
|
|
None
|
|
}
|
|
}
|