1c0e57d984
This commit systematically rebrands various references from Parity Technologies' Polkadot/Substrate ecosystem to PezkuwiChain within the kurdistan-sdk. Key changes include: - Updated external repository URLs (zombienet-sdk, parity-db, parity-scale-codec, wasm-instrument) to point to pezkuwichain forks. - Modified internal documentation and code comments to reflect PezkuwiChain naming and structure. - Replaced direct references to with or specific paths within the for XCM, Pezkuwi, and other modules. - Cleaned up deprecated issue and PR references in various and files, particularly in and modules. - Adjusted image and logo URLs in documentation to point to PezkuwiChain assets. - Removed or rephrased comments related to external Polkadot/Substrate PRs and issues. This is a significant step towards fully customizing the SDK for the PezkuwiChain ecosystem.
167 lines
5.1 KiB
Rust
167 lines
5.1 KiB
Rust
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// This file is part of Pezkuwi.
|
|
|
|
// Pezkuwi 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.
|
|
|
|
// Pezkuwi 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 Pezkuwi. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Helper functions and tools to generate mock data useful for testing this subsystem.
|
|
|
|
use std::sync::Arc;
|
|
|
|
use pezsp_keyring::Sr25519Keyring;
|
|
|
|
use pezkuwi_erasure_coding::{branches, obtain_chunks_v1 as obtain_chunks};
|
|
use pezkuwi_node_primitives::{AvailableData, BlockData, ErasureChunk, PoV, Proof};
|
|
use pezkuwi_primitives::{
|
|
CandidateCommitments, CandidateHash, ChunkIndex, CommittedCandidateReceiptV2, GroupIndex, Hash,
|
|
HeadData, Id as ParaId, IndexedVec, OccupiedCore, PersistedValidationData, SessionInfo,
|
|
ValidatorIndex,
|
|
};
|
|
use pezkuwi_primitives_test_helpers::{
|
|
dummy_collator, dummy_collator_signature, dummy_hash, dummy_validation_code,
|
|
CandidateDescriptor, CommittedCandidateReceipt,
|
|
};
|
|
|
|
/// Create dummy session info with two validator groups.
|
|
pub fn make_session_info() -> SessionInfo {
|
|
let validators = vec![
|
|
Sr25519Keyring::Ferdie, // <- this node, role: validator
|
|
Sr25519Keyring::Alice,
|
|
Sr25519Keyring::Bob,
|
|
Sr25519Keyring::Charlie,
|
|
Sr25519Keyring::Dave,
|
|
Sr25519Keyring::Eve,
|
|
Sr25519Keyring::One,
|
|
];
|
|
|
|
let validator_groups: IndexedVec<GroupIndex, Vec<ValidatorIndex>> =
|
|
[vec![5, 0, 3], vec![1, 6, 2, 4]]
|
|
.iter()
|
|
.map(|g| g.into_iter().map(|v| ValidatorIndex(*v)).collect())
|
|
.collect();
|
|
|
|
SessionInfo {
|
|
discovery_keys: validators.iter().map(|k| k.public().into()).collect(),
|
|
// Not used:
|
|
n_cores: validator_groups.len() as u32,
|
|
validator_groups,
|
|
// Not used values:
|
|
validators: validators.iter().map(|k| k.public().into()).collect(),
|
|
assignment_keys: Vec::new(),
|
|
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::new(),
|
|
dispute_period: 6,
|
|
random_seed: [0u8; 32],
|
|
}
|
|
}
|
|
|
|
/// Builder for constructing occupied cores.
|
|
///
|
|
/// Takes all the values we care about and fills the rest with dummy values on `build`.
|
|
pub struct OccupiedCoreBuilder {
|
|
pub group_responsible: GroupIndex,
|
|
pub para_id: ParaId,
|
|
pub relay_parent: Hash,
|
|
pub n_validators: usize,
|
|
pub chunk_index: ChunkIndex,
|
|
}
|
|
|
|
impl OccupiedCoreBuilder {
|
|
pub fn build(self) -> (OccupiedCore, (CandidateHash, ErasureChunk)) {
|
|
let pov = PoV { block_data: BlockData(vec![45, 46, 47]) };
|
|
let pov_hash = pov.hash();
|
|
let (erasure_root, chunk) =
|
|
get_valid_chunk_data(pov.clone(), self.n_validators, self.chunk_index);
|
|
let candidate_receipt = TestCandidateBuilder {
|
|
para_id: self.para_id,
|
|
pov_hash,
|
|
relay_parent: self.relay_parent,
|
|
erasure_root,
|
|
..Default::default()
|
|
}
|
|
.build();
|
|
let core = OccupiedCore {
|
|
next_up_on_available: None,
|
|
occupied_since: 0,
|
|
time_out_at: 0,
|
|
next_up_on_time_out: None,
|
|
availability: Default::default(),
|
|
group_responsible: self.group_responsible,
|
|
candidate_hash: candidate_receipt.hash(),
|
|
candidate_descriptor: candidate_receipt.descriptor.clone(),
|
|
};
|
|
(core, (candidate_receipt.hash(), chunk))
|
|
}
|
|
}
|
|
|
|
#[derive(Default)]
|
|
pub struct TestCandidateBuilder {
|
|
para_id: ParaId,
|
|
head_data: HeadData,
|
|
pov_hash: Hash,
|
|
relay_parent: Hash,
|
|
erasure_root: Hash,
|
|
}
|
|
|
|
impl TestCandidateBuilder {
|
|
pub fn build(self) -> CommittedCandidateReceiptV2 {
|
|
CommittedCandidateReceipt {
|
|
descriptor: CandidateDescriptor {
|
|
para_id: self.para_id,
|
|
pov_hash: self.pov_hash,
|
|
relay_parent: self.relay_parent,
|
|
erasure_root: self.erasure_root,
|
|
collator: dummy_collator(),
|
|
persisted_validation_data_hash: dummy_hash(),
|
|
signature: dummy_collator_signature(),
|
|
para_head: dummy_hash(),
|
|
validation_code_hash: dummy_validation_code().hash(),
|
|
},
|
|
commitments: CandidateCommitments { head_data: self.head_data, ..Default::default() },
|
|
}
|
|
.into()
|
|
}
|
|
}
|
|
|
|
// Get chunk for index 0
|
|
pub fn get_valid_chunk_data(
|
|
pov: PoV,
|
|
n_validators: usize,
|
|
chunk_index: ChunkIndex,
|
|
) -> (Hash, ErasureChunk) {
|
|
let persisted = PersistedValidationData {
|
|
parent_head: HeadData(vec![7, 8, 9]),
|
|
relay_parent_number: Default::default(),
|
|
max_pov_size: 1024,
|
|
relay_parent_storage_root: Default::default(),
|
|
};
|
|
let available_data = AvailableData { validation_data: persisted, pov: Arc::new(pov) };
|
|
let chunks = obtain_chunks(n_validators, &available_data).unwrap();
|
|
let branches = branches(chunks.as_ref());
|
|
let root = branches.root();
|
|
let chunk = branches
|
|
.enumerate()
|
|
.map(|(index, (proof, chunk))| ErasureChunk {
|
|
chunk: chunk.to_vec(),
|
|
index: ChunkIndex(index as _),
|
|
proof: Proof::try_from(proof).unwrap(),
|
|
})
|
|
.nth(chunk_index.0 as usize)
|
|
.expect("There really should be enough chunks.");
|
|
(root, chunk)
|
|
}
|