Skip to content

Commit

Permalink
fix some bugs
Browse files Browse the repository at this point in the history
  • Loading branch information
programskillforverification committed Sep 18, 2024
1 parent e6f2203 commit a9cc6d1
Show file tree
Hide file tree
Showing 4 changed files with 50 additions and 42 deletions.
5 changes: 3 additions & 2 deletions polkadot/node/network/dispute-distribution/src/tests/mock.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
use std::{
collections::{HashMap, HashSet},
sync::{Arc, LazyLock, OnceLock},
sync::{Arc, LazyLock},
time::Instant,
};

Expand Down Expand Up @@ -60,7 +60,8 @@ pub const BOB_INDEX: ValidatorIndex = ValidatorIndex(2);
pub const CHARLIE_INDEX: ValidatorIndex = ValidatorIndex(3);

/// Mocked `AuthorityDiscovery` service.
pub static MOCK_AUTHORITY_DISCOVERY: OnceLock<MockAuthorityDiscovery> = OnceLock::new();
pub static MOCK_AUTHORITY_DISCOVERY: LazyLock<MockAuthorityDiscovery> =
LazyLock::new(|| 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 MOCK_VALIDATORS_DISCOVERY_KEYS: LazyLock<HashMap<Sr25519Keyring, AuthorityDiscoveryId>> =
Expand Down
43 changes: 9 additions & 34 deletions polkadot/node/network/dispute-distribution/src/tests/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -208,10 +208,7 @@ fn received_request_triggers_import() {
nested_network_dispute_request(
&mut handle,
req_tx,
MOCK_AUTHORITY_DISCOVERY
.get()
.unwrap()
.get_peer_id_by_authority(Sr25519Keyring::Alice),
MOCK_AUTHORITY_DISCOVERY.get_peer_id_by_authority(Sr25519Keyring::Alice),
message.clone().into(),
ImportStatementsResult::ValidImport,
true,
Expand Down Expand Up @@ -240,10 +237,7 @@ fn batching_works() {
nested_network_dispute_request(
&mut handle,
req_tx,
MOCK_AUTHORITY_DISCOVERY
.get()
.unwrap()
.get_peer_id_by_authority(Sr25519Keyring::Alice),
MOCK_AUTHORITY_DISCOVERY.get_peer_id_by_authority(Sr25519Keyring::Alice),
message.clone().into(),
ImportStatementsResult::ValidImport,
true,
Expand All @@ -254,17 +248,11 @@ fn batching_works() {
let mut rx_responses = Vec::new();

let message = make_dispute_message(candidate.clone(), BOB_INDEX, FERDIE_INDEX);
let peer = MOCK_AUTHORITY_DISCOVERY
.get()
.unwrap()
.get_peer_id_by_authority(Sr25519Keyring::Bob);
let peer = MOCK_AUTHORITY_DISCOVERY.get_peer_id_by_authority(Sr25519Keyring::Bob);
rx_responses.push(send_network_dispute_request(req_tx, peer, message.clone().into()).await);

let message = make_dispute_message(candidate.clone(), CHARLIE_INDEX, FERDIE_INDEX);
let peer = MOCK_AUTHORITY_DISCOVERY
.get()
.unwrap()
.get_peer_id_by_authority(Sr25519Keyring::Charlie);
let peer = MOCK_AUTHORITY_DISCOVERY.get_peer_id_by_authority(Sr25519Keyring::Charlie);
rx_responses.push(send_network_dispute_request(req_tx, peer, message.clone().into()).await);
gum::trace!("Imported 3 votes into batch");

Expand All @@ -275,18 +263,12 @@ fn batching_works() {
gum::trace!("Importing duplicate votes");
let mut rx_responses_duplicate = Vec::new();
let message = make_dispute_message(candidate.clone(), BOB_INDEX, FERDIE_INDEX);
let peer = MOCK_AUTHORITY_DISCOVERY
.get()
.unwrap()
.get_peer_id_by_authority(Sr25519Keyring::Bob);
let peer = MOCK_AUTHORITY_DISCOVERY.get_peer_id_by_authority(Sr25519Keyring::Bob);
rx_responses_duplicate
.push(send_network_dispute_request(req_tx, peer, message.clone().into()).await);

let message = make_dispute_message(candidate.clone(), CHARLIE_INDEX, FERDIE_INDEX);
let peer = MOCK_AUTHORITY_DISCOVERY
.get()
.unwrap()
.get_peer_id_by_authority(Sr25519Keyring::Charlie);
let peer = MOCK_AUTHORITY_DISCOVERY.get_peer_id_by_authority(Sr25519Keyring::Charlie);
rx_responses_duplicate
.push(send_network_dispute_request(req_tx, peer, message.clone().into()).await);

Expand Down Expand Up @@ -380,10 +362,7 @@ fn receive_rate_limit_is_enforced() {
nested_network_dispute_request(
&mut handle,
req_tx,
MOCK_AUTHORITY_DISCOVERY
.get()
.unwrap()
.get_peer_id_by_authority(Sr25519Keyring::Alice),
MOCK_AUTHORITY_DISCOVERY.get_peer_id_by_authority(Sr25519Keyring::Alice),
message.clone().into(),
ImportStatementsResult::ValidImport,
true,
Expand All @@ -393,10 +372,7 @@ fn receive_rate_limit_is_enforced() {

let mut rx_responses = Vec::new();

let peer = MOCK_AUTHORITY_DISCOVERY
.get()
.unwrap()
.get_peer_id_by_authority(Sr25519Keyring::Bob);
let peer = MOCK_AUTHORITY_DISCOVERY.get_peer_id_by_authority(Sr25519Keyring::Bob);

let message = make_dispute_message(candidate.clone(), BOB_INDEX, FERDIE_INDEX);
rx_responses.push(send_network_dispute_request(req_tx, peer, message.clone().into()).await);
Expand Down Expand Up @@ -899,7 +875,6 @@ where
Fut: Future<Output = ()>,
{
sp_tracing::try_init_simple();
MOCK_AUTHORITY_DISCOVERY.get_or_init(|| mock::MockAuthorityDiscovery::new());
let keystore = make_ferdie_keystore();

let genesis_hash = Hash::repeat_byte(0xff);
Expand All @@ -911,7 +886,7 @@ where
let subsystem = DisputeDistributionSubsystem::new(
keystore,
req_receiver,
MOCK_AUTHORITY_DISCOVERY.get().unwrap().clone(),
MOCK_AUTHORITY_DISCOVERY.clone(),
Metrics::new_dummy(),
);

Expand Down
7 changes: 1 addition & 6 deletions polkadot/node/zombienet-backchannel/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,7 @@ license.workspace = true
workspace = true

[dependencies]
tokio = { features = [
"macros",
"net",
"rt-multi-thread",
"sync",
], workspace = true }
tokio = { features = ["macros", "net", "rt-multi-thread", "sync",], workspace = true }
url = { workspace = true }
tokio-tungstenite = { workspace = true }
futures-util = { workspace = true, default-features = true }
Expand Down
37 changes: 37 additions & 0 deletions prdoc/pr_5716.prdoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# Schema: Polkadot SDK PRDoc Schema (prdoc) v1.0.0
# See doc at https://raw.githubusercontent.com/paritytech/polkadot-sdk/master/prdoc/schema_user.json

title: Replace `lazy_static` with `LazyLock`

doc:
- audience: Node Dev
description: |
Replace all lazy_static usages with LazyLock from the Rust standard library. This will bring us less dependencies.

crates:
- name: sp-core
bump: Patch
- name: sp-panic-handler
bump: Patch
- name: sp-trie
bump: Patch
- name: sc-utils
bump: Major
- name: cumulus-pallet-parachain-system
bump: Patch
- name: sp-consensus-beefy
bump: Patch
- name: polkadot-node-primitives
bump: Patch
- name: polkadot-node-jaeger
bump: Patch
- name: frame-benchmarking-cli
bump: Major
- name: sc-offchain
bump: Patch
- name: polkadot-dispute-distribution
bump: Patch
- name: polkadot-gossip-support
bump: Patch
- name: xcm-emulator
bump: Patch

0 comments on commit a9cc6d1

Please sign in to comment.