mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-30 18:57:24 +00:00
74d6e660c6
* Add documentation to signed transactions and actually make them work. * Fix naming and bounds. * Forgotten import. * Remove warning. * Make accounts optional, fix logic. * Split the method to avoid confusing type error message. * Move executor tests to integration. * Add submit transactions tests. * Make `submit_transaction` tests compile * Remove a file that was accidently committed * Add can_sign helper function. * Fix compilation. * Add a key to keystore. * Fix the tests. * Remove env_logger. * Fix sending multiple transactions. * Remove commented code. * Bring back criterion. * Remove stray debug log. * Apply suggestions from code review Co-Authored-By: Bastian Köcher <bkchr@users.noreply.github.com> * Make sure to initialize block correctly. * Initialize block for offchain workers. * Add test for transaction validity. * Fix tests. * Review suggestions. * Remove redundant comment. * Make sure to use correct block number of authoring. * Change the runtime API. * Support both versions. * Bump spec version, fix RPC test. Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com> Co-authored-by: Gavin Wood <github@gavwood.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com>
133 lines
3.9 KiB
Rust
133 lines
3.9 KiB
Rust
// Copyright 2019-2020 Parity Technologies (UK) Ltd.
|
|
// This file is part of Substrate.
|
|
|
|
// Substrate 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.
|
|
|
|
// Substrate 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 Substrate. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Consensus extension module tests for BABE consensus.
|
|
|
|
use super::*;
|
|
use mock::{new_test_ext, Babe, Test};
|
|
use sp_runtime::{traits::OnFinalize, testing::{Digest, DigestItem}};
|
|
use pallet_session::ShouldEndSession;
|
|
|
|
const EMPTY_RANDOMNESS: [u8; 32] = [
|
|
74, 25, 49, 128, 53, 97, 244, 49,
|
|
222, 202, 176, 2, 231, 66, 95, 10,
|
|
133, 49, 213, 228, 86, 161, 164, 127,
|
|
217, 153, 138, 37, 48, 192, 248, 0,
|
|
];
|
|
|
|
fn make_pre_digest(
|
|
authority_index: sp_consensus_babe::AuthorityIndex,
|
|
slot_number: sp_consensus_babe::SlotNumber,
|
|
vrf_output: [u8; sp_consensus_babe::VRF_OUTPUT_LENGTH],
|
|
vrf_proof: [u8; sp_consensus_babe::VRF_PROOF_LENGTH],
|
|
) -> Digest {
|
|
let digest_data = sp_consensus_babe::RawBabePreDigest::Primary {
|
|
authority_index,
|
|
slot_number,
|
|
vrf_output,
|
|
vrf_proof,
|
|
};
|
|
let log = DigestItem::PreRuntime(sp_consensus_babe::BABE_ENGINE_ID, digest_data.encode());
|
|
Digest { logs: vec![log] }
|
|
}
|
|
|
|
#[test]
|
|
fn empty_randomness_is_correct() {
|
|
let s = compute_randomness([0; RANDOMNESS_LENGTH], 0, std::iter::empty(), None);
|
|
assert_eq!(s, EMPTY_RANDOMNESS);
|
|
}
|
|
|
|
#[test]
|
|
fn initial_values() {
|
|
new_test_ext(vec![0, 1, 2, 3]).execute_with(|| {
|
|
assert_eq!(Babe::authorities().len(), 4)
|
|
})
|
|
}
|
|
|
|
#[test]
|
|
fn check_module() {
|
|
new_test_ext(vec![0, 1, 2, 3]).execute_with(|| {
|
|
assert!(!Babe::should_end_session(0), "Genesis does not change sessions");
|
|
assert!(!Babe::should_end_session(200000),
|
|
"BABE does not include the block number in epoch calculations");
|
|
})
|
|
}
|
|
|
|
type System = frame_system::Module<Test>;
|
|
|
|
#[test]
|
|
fn first_block_epoch_zero_start() {
|
|
new_test_ext(vec![0, 1, 2, 3]).execute_with(|| {
|
|
let genesis_slot = 100;
|
|
let first_vrf = [1; 32];
|
|
let pre_digest = make_pre_digest(
|
|
0,
|
|
genesis_slot,
|
|
first_vrf,
|
|
[0xff; 64],
|
|
);
|
|
|
|
assert_eq!(Babe::genesis_slot(), 0);
|
|
System::initialize(
|
|
&1,
|
|
&Default::default(),
|
|
&Default::default(),
|
|
&pre_digest,
|
|
Default::default(),
|
|
);
|
|
|
|
// see implementation of the function for details why: we issue an
|
|
// epoch-change digest but don't do it via the normal session mechanism.
|
|
assert!(!Babe::should_end_session(1));
|
|
assert_eq!(Babe::genesis_slot(), genesis_slot);
|
|
assert_eq!(Babe::current_slot(), genesis_slot);
|
|
assert_eq!(Babe::epoch_index(), 0);
|
|
|
|
Babe::on_finalize(1);
|
|
let header = System::finalize();
|
|
|
|
assert_eq!(SegmentIndex::get(), 0);
|
|
assert_eq!(UnderConstruction::get(0), vec![first_vrf]);
|
|
assert_eq!(Babe::randomness(), [0; 32]);
|
|
assert_eq!(NextRandomness::get(), [0; 32]);
|
|
|
|
assert_eq!(header.digest.logs.len(), 2);
|
|
assert_eq!(pre_digest.logs.len(), 1);
|
|
assert_eq!(header.digest.logs[0], pre_digest.logs[0]);
|
|
|
|
let authorities = Babe::authorities();
|
|
let consensus_log = sp_consensus_babe::ConsensusLog::NextEpochData(
|
|
sp_consensus_babe::NextEpochDescriptor {
|
|
authorities,
|
|
randomness: Babe::randomness(),
|
|
}
|
|
);
|
|
let consensus_digest = DigestItem::Consensus(BABE_ENGINE_ID, consensus_log.encode());
|
|
|
|
// first epoch descriptor has same info as last.
|
|
assert_eq!(header.digest.logs[1], consensus_digest.clone())
|
|
})
|
|
}
|
|
|
|
#[test]
|
|
fn authority_index() {
|
|
new_test_ext(vec![0, 1, 2, 3]).execute_with(|| {
|
|
assert_eq!(
|
|
Babe::find_author((&[(BABE_ENGINE_ID, &[][..])]).into_iter().cloned()), None,
|
|
"Trivially invalid authorities are ignored")
|
|
})
|
|
}
|