mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-22 17:21:07 +00:00
4c810609d6
The first step towards https://github.com/paritytech/polkadot-sdk/issues/3155 Brings all templates under the following structure ``` templates | parachain | | polkadot-launch | | runtime --> parachain-template-runtime | | pallets --> pallet-parachain-template | | node --> parachain-template-node | minimal | | runtime --> minimal-template-runtime | | pallets --> pallet-minimal-template | | node --> minimal-template-node | solochain | | runtime --> solochain-template-runtime | | pallets --> pallet-template (the naming is not consistent here) | | node --> solochain-template-node ``` The only note-worthy changes in this PR are: - More `Cargo.toml` fields are forwarded to use the one from the workspace. - parachain template now has weights and benchmarks - adds a shell pallet to the minimal template - remove a few unused deps A list of possible follow-ups: - [ ] Unify READMEs, create a parent README for all - [ ] remove references to `docs.substrate.io` in templates - [ ] make all templates use `#[derive_impl]` - [ ] update and unify all licenses - [ ] Remove polkadot launch, use https://github.com/paritytech/polkadot-sdk/blob/35349df993ea2e7c4769914ef5d199e787b23d4c/cumulus/zombienet/examples/small_network.toml instead.
64 lines
2.0 KiB
Rust
64 lines
2.0 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) 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.
|
|
|
|
pub mod constants {
|
|
use frame_support::{
|
|
parameter_types,
|
|
weights::{constants, RuntimeDbWeight},
|
|
};
|
|
|
|
parameter_types! {
|
|
/// `ParityDB` can be enabled with a feature flag, but is still experimental. These weights
|
|
/// are available for brave runtime engineers who may want to try this out as default.
|
|
pub const ParityDbWeight: RuntimeDbWeight = RuntimeDbWeight {
|
|
read: 8_000 * constants::WEIGHT_REF_TIME_PER_NANOS,
|
|
write: 50_000 * constants::WEIGHT_REF_TIME_PER_NANOS,
|
|
};
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod test_db_weights {
|
|
use super::constants::ParityDbWeight as W;
|
|
use frame_support::weights::constants;
|
|
|
|
/// Checks that all weights exist and have sane values.
|
|
// NOTE: If this test fails but you are sure that the generated values are fine,
|
|
// you can delete it.
|
|
#[test]
|
|
fn sane() {
|
|
// At least 1 µs.
|
|
assert!(
|
|
W::get().reads(1).ref_time() >= constants::WEIGHT_REF_TIME_PER_MICROS,
|
|
"Read weight should be at least 1 µs."
|
|
);
|
|
assert!(
|
|
W::get().writes(1).ref_time() >= constants::WEIGHT_REF_TIME_PER_MICROS,
|
|
"Write weight should be at least 1 µs."
|
|
);
|
|
// At most 1 ms.
|
|
assert!(
|
|
W::get().reads(1).ref_time() <= constants::WEIGHT_REF_TIME_PER_MILLIS,
|
|
"Read weight should be at most 1 ms."
|
|
);
|
|
assert!(
|
|
W::get().writes(1).ref_time() <= constants::WEIGHT_REF_TIME_PER_MILLIS,
|
|
"Write weight should be at most 1 ms."
|
|
);
|
|
}
|
|
}
|
|
}
|