Add special tag to exclude runtime storage items from benchmarking (#12205)
* initial setup * add WhitelistedStorageKeys trait * add (A, B) tuple implementation for whitelisted_storage_keys() * fix formatting * implement WhitelistedStorageKeys for all tuple combinations * impl_for_tuples up to 128 for WhitelistedStorageKeys * refactor to #[benchmarking(cached)] * tweak error message and mark BlockNumber as cached * add benchmarking(cached) to the other default types * add docs for benchmarking(cached) * properly parse storage type declaration * make storage_alias structs public so we can use them in this macro * use BTreeMap since TrackedStorageKey missing Ord outside of std * make WhitelistedStorageKeys accessible * basic detection of benchmarking(cached)* proper parsing of #[benchmarking(cached)] from pallet parse macro * store presence of #[benchmarking(cached)] macro on StorageDef * will be used for later expansion * compiling blank impl for WhitelistedStorageKeys * move impl to expand_pallet_struct * use frame_support::sp_std::vec::Vec properly * successfully compiling with storage info loaded into a variable * plausible implementation for whitelisted_storage_keys() * depends on the assumption that storage_info.encode() can be loaded into TrackedStorageKey::new(..) * use Pallet::whitelisted_storage_keys() instead of hard-coded list * AllPallets::whitelisted_storage_keys() properly working * collect storage names * whitelisted_storage_keys() impl working * clean up * fix compiler error * just one compiler error * fix doc compiler error * use better import path * fix comment * whoops * whoops again * fix macro import issue * cargo fmt * mark example as ignore * use keyword tokens instead of string parsing * fix keyword-based parsing of benchmarking(cached) * preliminary spec for check_whitelist() * add additional test for benchmarking whitelist * add TODO note * remove irrelevant line from example * use filter_map instead of filter and map * simplify syntax Co-authored-by: Keith Yeung <kungfukeith11@gmail.com> * clean up * fix test * fix tests * use keyword parsing instead of string parsing * use collect() instead of a for loop Co-authored-by:
Kian Paimani <5588131+kianenigma@users.noreply.github.com> * fix compiler error * clean up benchmarking(cached) marking code * use cloned() * refactor to not use panic! and remove need for pub types in storage_alias * remove unneeded use Co-authored-by:
Bastian Köcher <info@kchr.de> * remove unneeded visibility changes * don't manually hard code hash for treasury account as hex * proper Ord, PartialOrd, and Hash impls for TrackedStorageKey * now based just on key, and available in no-std * use BTreeSet instead of BTreeMap * fix comments * cargo fmt * switch to pallet::whitelist and re-do it basti's way :D * make PartialOrd for TrackedStorageKey consistent with Ord * more correct implementation of hash-related traits for TrackedStorageKey * fix integration test * update TODO * remove unused keyword * remove more unused keywords * use into_iter() Co-authored-by:
Keith Yeung <kungfukeith11@gmail.com> * Update frame/support/procedural/src/pallet/parse/mod.rs Co-authored-by:
Bastian Köcher <info@kchr.de> * add docs for whitelisted * fix comment Co-authored-by:
Keith Yeung <kungfukeith11@gmail.com> Co-authored-by:
Kian Paimani <5588131+kianenigma@users.noreply.github.com> Co-authored-by:
Bastian Köcher <info@kchr.de>
Showing
- substrate/bin/node-template/runtime/src/lib.rs 39 additions, 12 deletionssubstrate/bin/node-template/runtime/src/lib.rs
- substrate/bin/node/runtime/src/lib.rs 44 additions, 16 deletionssubstrate/bin/node/runtime/src/lib.rs
- substrate/frame/balances/src/lib.rs 1 addition, 0 deletionssubstrate/frame/balances/src/lib.rs
- substrate/frame/support/procedural/src/pallet/expand/pallet_struct.rs 19 additions, 0 deletions...ame/support/procedural/src/pallet/expand/pallet_struct.rs
- substrate/frame/support/procedural/src/pallet/parse/storage.rs 18 additions, 3 deletions...rate/frame/support/procedural/src/pallet/parse/storage.rs
- substrate/frame/support/procedural/src/storage/mod.rs 1 addition, 0 deletionssubstrate/frame/support/procedural/src/storage/mod.rs
- substrate/frame/support/src/lib.rs 15 additions, 0 deletionssubstrate/frame/support/src/lib.rs
- substrate/frame/support/src/traits.rs 1 addition, 0 deletionssubstrate/frame/support/src/traits.rs
- substrate/frame/support/src/traits/storage.rs 28 additions, 0 deletionssubstrate/frame/support/src/traits/storage.rs
- substrate/frame/support/test/tests/pallet_ui/storage_invalid_attribute.stderr 1 addition, 1 deletion...ort/test/tests/pallet_ui/storage_invalid_attribute.stderr
- substrate/frame/system/src/lib.rs 5 additions, 0 deletionssubstrate/frame/system/src/lib.rs
- substrate/primitives/storage/src/lib.rs 3 additions, 2 deletionssubstrate/primitives/storage/src/lib.rs
Please register or sign in to comment