mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-31 01:41:03 +00:00
6f53b974b2
Compressed ECDSA keys requires to have 0x02 or 0x03 as their first byte in order to allow public key recovery. Nevertheless the test was working because of the `unwrap_or_default()` at the end of the conversion routine (i.e. the invalid keys were converted to an empty vector).
148 lines
3.7 KiB
Rust
148 lines
3.7 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) 2021-2022 Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
use std::vec;
|
|
|
|
use beefy_primitives::{
|
|
mmr::{BeefyNextAuthoritySet, MmrLeafVersion},
|
|
ValidatorSet,
|
|
};
|
|
use codec::{Decode, Encode};
|
|
use hex_literal::hex;
|
|
|
|
use sp_core::H256;
|
|
use sp_io::TestExternalities;
|
|
use sp_runtime::{traits::Keccak256, DigestItem};
|
|
|
|
use frame_support::traits::OnInitialize;
|
|
|
|
use crate::mock::*;
|
|
|
|
fn init_block(block: u64) {
|
|
System::set_block_number(block);
|
|
Session::on_initialize(block);
|
|
Mmr::on_initialize(block);
|
|
Beefy::on_initialize(block);
|
|
BeefyMmr::on_initialize(block);
|
|
}
|
|
|
|
pub fn beefy_log(log: ConsensusLog<BeefyId>) -> DigestItem {
|
|
DigestItem::Consensus(BEEFY_ENGINE_ID, log.encode())
|
|
}
|
|
|
|
fn offchain_key(pos: usize) -> Vec<u8> {
|
|
(<Test as pallet_mmr::Config>::INDEXING_PREFIX, pos as u64).encode()
|
|
}
|
|
|
|
fn read_mmr_leaf(ext: &mut TestExternalities, index: usize) -> MmrLeaf {
|
|
type Node = pallet_mmr_primitives::DataOrHash<Keccak256, MmrLeaf>;
|
|
ext.persist_offchain_overlay();
|
|
let offchain_db = ext.offchain_db();
|
|
offchain_db
|
|
.get(&offchain_key(index))
|
|
.map(|d| Node::decode(&mut &*d).unwrap())
|
|
.map(|n| match n {
|
|
Node::Data(d) => d,
|
|
_ => panic!("Unexpected MMR node."),
|
|
})
|
|
.unwrap()
|
|
}
|
|
|
|
#[test]
|
|
fn should_contain_mmr_digest() {
|
|
let mut ext = new_test_ext(vec![1, 2, 3, 4]);
|
|
ext.execute_with(|| {
|
|
init_block(1);
|
|
|
|
assert_eq!(
|
|
System::digest().logs,
|
|
vec![beefy_log(ConsensusLog::MmrRoot(
|
|
hex!("969d516e5279540ef38e4a710fb0645cab4c3b01e528be7285b85ec9c5fb55c8").into()
|
|
))]
|
|
);
|
|
|
|
// unique every time
|
|
init_block(2);
|
|
|
|
assert_eq!(
|
|
System::digest().logs,
|
|
vec![
|
|
beefy_log(ConsensusLog::MmrRoot(
|
|
hex!("969d516e5279540ef38e4a710fb0645cab4c3b01e528be7285b85ec9c5fb55c8").into()
|
|
)),
|
|
beefy_log(ConsensusLog::AuthoritiesChange(
|
|
ValidatorSet::new(vec![mock_beefy_id(3), mock_beefy_id(4),], 1,).unwrap()
|
|
)),
|
|
beefy_log(ConsensusLog::MmrRoot(
|
|
hex!("8c42b7b040d262f7f2e26abeb61ab0c3c448f60c7f2f19e6ca0035d9bb3ae7e2").into()
|
|
)),
|
|
]
|
|
);
|
|
});
|
|
}
|
|
|
|
#[test]
|
|
fn should_contain_valid_leaf_data() {
|
|
let mut ext = new_test_ext(vec![1, 2, 3, 4]);
|
|
ext.execute_with(|| {
|
|
init_block(1);
|
|
});
|
|
|
|
let mmr_leaf = read_mmr_leaf(&mut ext, 0);
|
|
assert_eq!(
|
|
mmr_leaf,
|
|
MmrLeaf {
|
|
version: MmrLeafVersion::new(1, 5),
|
|
parent_number_and_hash: (0_u64, H256::repeat_byte(0x45)),
|
|
beefy_next_authority_set: BeefyNextAuthoritySet {
|
|
id: 1,
|
|
len: 2,
|
|
root: hex!("176e73f1bf656478b728e28dd1a7733c98621b8acf830bff585949763dca7a96")
|
|
.into(),
|
|
},
|
|
parachain_heads: hex!(
|
|
"ed893c8f8cc87195a5d4d2805b011506322036bcace79642aa3e94ab431e442e"
|
|
)
|
|
.into(),
|
|
}
|
|
);
|
|
|
|
// build second block on top
|
|
ext.execute_with(|| {
|
|
init_block(2);
|
|
});
|
|
|
|
let mmr_leaf = read_mmr_leaf(&mut ext, 1);
|
|
assert_eq!(
|
|
mmr_leaf,
|
|
MmrLeaf {
|
|
version: MmrLeafVersion::new(1, 5),
|
|
parent_number_and_hash: (1_u64, H256::repeat_byte(0x45)),
|
|
beefy_next_authority_set: BeefyNextAuthoritySet {
|
|
id: 2,
|
|
len: 2,
|
|
root: hex!("9c6b2c1b0d0b25a008e6c882cc7b415f309965c72ad2b944ac0931048ca31cd5")
|
|
.into(),
|
|
},
|
|
parachain_heads: hex!(
|
|
"ed893c8f8cc87195a5d4d2805b011506322036bcace79642aa3e94ab431e442e"
|
|
)
|
|
.into(),
|
|
}
|
|
);
|
|
}
|