-
Notifications
You must be signed in to change notification settings - Fork 2.6k
Fix issues with Operational
transactions validity and prioritization.
#6435
Conversation
@@ -1483,9 +1497,11 @@ impl<T: Trait + Send + Sync> CheckWeight<T> where | |||
fn get_priority(info: &DispatchInfoOf<T::Call>) -> TransactionPriority { | |||
match info.class { | |||
DispatchClass::Normal => info.weight.into(), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just tagging the related issue to this funny line: #5672
Probably not a problem that needs to be solved now
DispatchClass::Operational => { | ||
let maximum_weight = T::MaximumBlockWeight::get(); | ||
let operational_limit = Self::get_dispatch_limit_ratio(DispatchClass::Operational) * maximum_weight; | ||
let extrinsic_weight = info.weight.saturating_add(T::ExtrinsicBaseWeight::get()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This calculation is missing BaseBlockWeight
if we want to be entirely accurate.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What happens if a transaction satisfies this but can actually never be included because check_block_weight always fails ? Is that an issue like the transaction will stay forever in the queue ?
Because in the moment I guess it also doesn't include the minimum cost of OnInitialize.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is that an issue like the transaction will stay forever in the queue ?
Yes, if it's immortal.
Because in the moment I guess it also doesn't include the minimum cost of OnInitialize.
Good point. With Normal
dispatchables, we have a separate parameter that allows to control the max size when runtime is created. I guess it might make sense to lift it up for Operational
as well and define as like 90%
of max block weight or sth.
* master: Ensure the listen addresses are consistent with the transport (#6436) client/network/service: Add primary dimension to connection metrics (#6472) `pallet-scheduler`: Check that `when` is not in the past (#6480) bound some missing bound for elevated trait (#6487) Fix the browser node and ensure it doesn't colour the informant output (#6457) Fix `sp-api` handling of multiple arguments (#6484) impl Debug for sc_service::Configuration (#6400) Remove lingering runtime upgrades (#6476) Optimize offchain worker api by re-using http-client (#6454) Implement nested storage transactions (#6269) Avoid panic on dropping a `sc_network::service::out_events::Receiver`. (#6458) network: remove unused variable (#6460) [CI] Don't tag PRs on companion job cancels (#6470) update collective events docs to be consistent with changes (#6463) `pallet-staking`: Expose missing consts (#6456) Fix issues with `Operational` transactions validity and prioritization. (#6435) pallet-atomic-swap: generialized swap action (#6421) node: spawn block authoring and grandpa voter as blocking tasks (#6446) change everything to transaction (#6440)
* Fix typo: eror -> error (paritytech#6293) * Fix typo: PRORITY -> PRIORITY (paritytech#6291) * Intent to release rc3 (paritytech#6290) * Fix transaction pool & network issues (paritytech#6288) * fix & tweaks * address review * line width * Use `sign_with` for signing grandpa's outgoing message (paritytech#6178) * Use sign_with and stop using `Pair` * PR feedback * Remove clone * Transfer ownership of public to sign_message * Use Option * Simplify code * Fix error message * Pass keystore as ref * Pass keystore properly * Fix tests * Revalidation tweak & logging for transaction pool (paritytech#6258) * updates and logging * fix length * Update client/transaction-pool/src/lib.rs * rename * Update client/transaction-pool/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update README.md * Allow adding a prefix to the informant (paritytech#6174) * Initial commit Forked at: 49b1561 Parent branch: origin/master * Add a Service Configuration's field + adapt informant + provide means to CLI * CLEANUP Forked at: 49b1561 Parent branch: origin/master * fix tests * fixed bad path to object * Change OutputFormat enum to struct * Add informant_prefix to builder and service * Revert "Change OutputFormat enum to struct" This reverts commit cd86c58. * Revert "fix tests" This reverts commit a3c306e. * Revert "Add a Service Configuration's field + adapt informant + provide means to CLI" This reverts commit 9c2e726. * Implementation using the ServiceBuilder * reduce line length * fix line width again * WIP Forked at: 49b1561 Parent branch: origin/master * WIP Forked at: 49b1561 Parent branch: origin/master * WIP Forked at: 49b1561 Parent branch: origin/master * use struct instead of enum * WIP Forked at: 49b1561 Parent branch: origin/master * Update client/service/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * improve doc * Update client/service/src/builder.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/service/src/builder.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * change code * Update client/informant/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * enable_color * reorg log * remove macro * Removed builder for informant prefix * fix doc * Update client/informant/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/informant/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/informant/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/informant/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/service/src/builder.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/service/src/builder.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/service/src/builder.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Transaction pool added missed comment (paritytech#6308) * Add a test for lots of nodes connecting at the same time (paritytech#6247) * Add a test for lots of nodes connecting at the same time * Do small change * Introduce frozen indices. (paritytech#6307) * Introduce frozen indices. * Fix. * Bump runtime * Benchmark for freeze * Fix * fix benchmarks * update freeze weights * remove copy pasta Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> * new crate sc-light (paritytech#6235) * sc-light * remove unused deps * fix line width * move more fns to sc_light * Fix ui tests for latest rust stable (paritytech#6310) * Expose light client. (paritytech#6313) * Fix nits in rpc error display. (paritytech#6302) * Improve rpc error display. * Apply review suggestion. * Apply review suggestion. * Update client/rpc-api/src/author/error.rs * Fix custom. Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * "OR gate" for EnsureOrigin (paritytech#6237) * 'OR gate' for EnsureOrigin. * Formatting. * More formatting. * Add docstring; Update 'Success' type. * Bump runtime impl_version. * Fix successful_origin. * Add either into std feature list. * Update docs. * New CI image (paritytech#6223) * fix (ci): hotfix Docker release * change (ci): moving to the tested CI image with a proper name * change (ci): rename substrate-ci-linux * Reduce the lots_of_incoming_peers_works test load (paritytech#6314) * change (ci): moving to the tested CI image with a proper name * change (ci): rename substrate-ci-linux * Reduce the lots_of_incoming_peers_works test load (paritytech#6314) Co-authored-by: Bastian Köcher <git@kchr.de> Co-authored-by: Pierre Krieger <pierre.krieger1708@gmail.com> * Add a feature to create automatically a random temporary directory for base path & remove `Clone` (paritytech#6221) * Initial commit Forked at: 342caad Parent branch: origin/master * Add a feature to create automatically a temporary directory for base path * doc fix and todos * use parking_lot instead * use refcell instead since we stay in the main thread * remove Clone derives * add test * solving dependency issue * clarifying doc * conflict argument with base-path * WIP Forked at: 342caad Parent branch: origin/master * revert dep deletion * fixing test and making base_path optional * hold basepath while the service is running * fixes * Update client/cli/src/params/shared_params.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/service/Cargo.toml Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/cli/src/commands/mod.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update client/service/src/config.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * WIP Forked at: 342caad Parent branch: origin/master * improve doc Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Add a [prefix]_process_start_time_seconds metric (paritytech#6315) * Make NumberOrHex a common primitive. (paritytech#6321) * Make NumberOrHex a common primitive. * Update primitives/rpc/src/number.rs Co-authored-by: Nikolay Volf <nikvolf@gmail.com> Co-authored-by: Nikolay Volf <nikvolf@gmail.com> * Avoid self-lookups in Authority Discovery (paritytech#6317) * Ensure authority discovery avoids self-lookups. Thereby additionally guard the `NetworkService` against adding the local peer to the PSM or registering a "known address" for the local peer. * Clarify comments. * See if returning errors is ok. * Fix quadratic iterations in transaction pool ready set (paritytech#6256) * refactor ready set size calc * Update client/transaction-pool/graph/src/ready.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * remove pub * update to new variat * rename Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Find the alive incoming entry on disconnect. (paritytech#6320) When a peer in `Incoming` state disconnects, the "alive" entry in the `incoming` list for that peer must be updated (set to `false`). Currently the entry that is updated may be an earlier entry for the same peer that is already no longer alive. This can happen if a peer repeatedly connects (incoming) and disconnects between invocations to `poll()` of the behaviour. * Impl Debug and Display for Ss58AddressFormat when compiled with std (paritytech#6327) * Initial commit Forked at: 606c56d Parent branch: origin/master * Impl Debug and Display for Ss58AddressFormat when compiled with std Fixes paritytech#6289 * Use write! instead of writeln! * transaction-pool: expose blocking api for tx submission (paritytech#6325) * transaction-pool: expose blocking api for tx submission * service: separate ServiceBuilder::build for full and light * service: add ServiceBuilder::build_common * transaction-pool: extend docs Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com> Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com> * Pruned and resubmitted metrics in transaction pool (paritytech#6322) * pruned and resubmitted metrics * update counter once * Enable wasmtime on node-template (paritytech#6336) * Enable wasmtime on node-template * Apply suggestions from code review syntax Co-authored-by: Nikolay Volf <nikvolf@gmail.com> Co-authored-by: Nikolay Volf <nikvolf@gmail.com> * Adds support for storage parameter types (paritytech#6296) * Adds support for storage parameter types This pr adds a new parameter types type, the storage parameter types. This parameter type supports loading the value from the storage or returning the given default value. * Use twox_128 * Update docs * Update frame/support/src/lib.rs Co-authored-by: Alexander Popiak <alexander.popiak@parity.io> Co-authored-by: Alexander Popiak <alexander.popiak@parity.io> * Basic documentation for Scheduler pallet (paritytech#6338) Closes paritytech#5912 * Fix check-line-width CI script (paritytech#6326) * Compare lines to the hash that the PR branched off from * Use git merge-base to determine common ancestor * Fixup * client: use appropriate ExecutionContext for initial sync / regular import (paritytech#6180) * client: use appropriate ExecutionContext for sync/import * client: remove dead code * client: ExecutionContext: distinguish between own and foreign imports * client: fix cli parameter doc * Revert "client: ExecutionContext: distinguish between own and foreign imports" This reverts commit 0fac115. * primitives: add docs for ExecutionContext * cli: execution strategy docs * cli: use different execution context for importing block on validator * cli: remove defaults from execution context flags * Fix transaction pool event sending (paritytech#6341) This pr fixes a bug with the transaction pool not sending certain events like finalized and also fixes the order of events. The problem with the finalized event was that we did not extracted pruned extrinsics if there were not ready transactions in the pool. However this is wrong, if we have a re-org, a tx is clearly not ready anymore and we still need to send a pruned event for it because it is in a new block included. This also lead to sending "ready" events and tx being re-validated. The listener also only send the "finalized" event if it has seen a block as being included, which did not happen before with the old code. The second fix of the pr is the order of events. If we prune and retract the same transaction in the same block, we first need to send the "retract" event and after that the "pruned" event, because finalization takes longer and this would lead to the UI showing "retract" while it actually is included. * Deprecate FunctionOf and remove its users (paritytech#6340) * Deprecate FunctionOf and remove users * Remove unused import * Add events for balance reserve and unreserve functions (paritytech#6330) * almost works * add clone to BalanceStatus * reserve event * fix staking tests * fix balances tests * Update frame/balances/src/tests.rs Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com> * restore tests and move event emission * move repatriate reserved event outside of mutate_account * clean up events in tests Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com> * Update contributing guide with new label policy (paritytech#6333) * mention C and M labels in contributing guide * update PR template with more specific instructions * update PR template with updated label rules and contributing guide link * update contibuting guide * adding a ss58 format for Stafi Network (paritytech#6347) * add extend_lock for StorageLock (paritytech#6323) * add extend_lock for StorageLock * changes * changes * Introduce in-origin filtering (paritytech#6318) * impl filter in origin * remove IsCallable usage. Breaking: utility::batch(root, calls) no longer bypass BasicCallFilter * rename BasicCallFilter -> BaseCallFilter * refactor code * Apply suggestions from code review Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com> * remove forgotten temporar comment * better add suggestion in another PR * refactor: use Clone instead of mem::replace * fix tests * fix tests * fix tests * fix benchmarks * Make root bypass filter in utility::batch * fix unused imports Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com> * pallet-evm add get(fn) to AccountStorages (paritytech#6279) * Add IPC support (paritytech#6348) This is useful for both security and performance reasons. IPC is faster than TCP, and it is subject to OS access controls. * expose constants of pallet_recovery trait (paritytech#6363) * Impl integrity test for runtime (paritytech#6356) * impl integrity test for runtime * Update frame/support/src/traits.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Update frame/support/procedural/src/construct_runtime/mod.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * use thread local * update doc * Apply suggestions from code review Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Gavin Wood <gavin@parity.io> * historical slashing w ocw w adhoc tree creation (paritytech#6220) * draft * steps * chore: fmt * step by step * more details * make test public * refactor: split into on and offchain * test stab * tabs my friend * offchain overlay: split key into prefix and true key Simplifies inspection and makes key actually unique. * test: share state * fix & test * docs improv * address review comments * cleanup test chore * refactor, abbrev link text * chore: linewidth * fix prefix key split fallout * minor fallout * minor changes * addresses review comments * rename historical.rs -> historical/mod.rs * avoid shared::* wildcard import * fix: add missing call to store_session_validator_set_to_offchain * fix/compile: missing shared:: prefix * fix/test: flow * fix/review: Apply suggestions from code review Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com> * fix/review: more review comment fixes * fix/review: make ValidatorSet private * fix/include: core -> sp_core * fix/review: fallout * fix/visbility: make them public API Ref paritytech#6358 * fix/review: review changes fallout - again Co-authored-by: Bernhard Schuster <bernhard@parity.io> Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com> * [CI] Auto-label new PRs according to draft status (paritytech#6361) * add auto-label github action * Add missing 'remove-labels' line * Split the service initialisation up into seperate functions (paritytech#6332) * Seperate out the complexity in ServiceBuilder::build_common into seperate functions * Fix line widths * Move some functions to their respective crates * [CI] Add label enforcement (paritytech#6365) * Add label enforcement * fix .gitlab-ci.yml * update check_labels.sh * vesting: Force Vested Transfer (paritytech#6368) * force-vested-transfer * Tweak weights * Update frame/vesting/src/lib.rs Co-authored-by: joe petrowski <25483142+joepetrowski@users.noreply.github.com> Co-authored-by: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * client/authority-discovery: Don't add own address to priority group (paritytech#6370) * client/authority-discovery: Don't add own address to priority group In the scenario of a validator publishing the address of its sentry node to the DHT, said sentry node should not add its own Multiaddr to the peerset "authority" priority group. Related to 70cfeff. * client/authority-discovery: Remove unused import PeerId * client/authority-discovery/tests: Add tcp protocol to multiaddresses * .gitlab-ci.yml: Run promtool on Prometheus alerting rules (paritytech#6344) * .gitlab-ci.yml: Run promtool on Prometheus alerting rules Add a CI stage to test the Prometheus alerting rules within `.maintain/monitoring`. * .gitlab-ci.yml: Switch Prometheus stage to paritytech/tools image * .gitlab-ci.yml: Follow http redirects in Prometheus stage * .gitlab-ci.yml: Fix Prometheus stage promtool folder name * Use /dns/ instead of /dns4/ (paritytech#6369) * add system_dryRun (paritytech#6300) * add system_dryRun * fix build error * delete unneeded code * return ApplyExtrinsicResult directly * line width * mark dry run unsafe * line width * fix test * add test * update comment * fix BlockAttributes encoding (paritytech#6281) * Allow Sudo to do anything (paritytech#6375) * All Sudo to do anything. * Rename old labels. * Stored call in multisig (paritytech#6319) * Stored call in multisig * Docs. * Benchmarks. * Fix * Update frame/multisig/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * patch benchmarks * Minor grumbles. * Update as_multi weight * Fixes and refactoring. * Split out threshold=1 and opaquify Call. * Compiles, tests pass, weights are broken * Update benchmarks, add working tests * Add benchmark to threshold 1, add event too * suppress warning for now * @xlc improvment nit * Update weight and tests * Test for weight check * Fix line width * one more line width error * Apply suggestions from code review Co-authored-by: Alexander Popiak <alexander.popiak@parity.io> * fix merge * more @apopiak feedback * Multisig handles no preimage * Optimize return weight after dispatch * Error on failed deposit. Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> Co-authored-by: Alexander Popiak <alexander.popiak@parity.io> * Fix the broken weight multiplier update function (paritytech#6334) * Initial draft, has some todos left * remove ununsed import * Apply suggestions from code review * Some refactors with migration * Fix more test and cleanup * Fix for companion * Apply suggestions from code review Co-authored-by: Alexander Popiak <alexander.popiak@parity.io> * Update bin/node/runtime/src/impls.rs * Fix weight * Add integrity test * length is not affected. Co-authored-by: Alexander Popiak <alexander.popiak@parity.io> * Restrict remove_proxies (paritytech#6383) * Remove penalty on duplicate Status message (paritytech#6377) * `decl_module!` print better error on duplicate reserved keyword (paritytech#6384) * `decl_module!` print better error on duplicate reserved keyword This prints a better error message on duplicated reserved keywords, instead of complaining because of missing `origin`. * Review feedback * FixedPointNumber: zero is not positive. (paritytech#6385) * Allow empty values in the storage (paritytech#6364) * Allow empty values in the storage * Bump trie-bench * Bump trie-bench * Pallet: Atomic Swap (paritytech#6349) * Init atomic swap pallet * Implement module swap operations * Add successful swap test * Bump node spec_version * Fix storage name * Add ProofLimit parameter to prevent proof size being too large * Add missing events * Basic weight support * Add basic docs * Mark swap on claim This handles the additional case if `repatriate_reserved` fails. * Add additional expire handler * Update frame/atomic-swap/src/lib.rs Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> * Add docs on ProofLimit * Fix test * Return Ok(()) even when the transfer fails Because we need to mark the swap as claimed no matter what. * Remove retry logic It's overkill. Swap is about something being executed, not necessarily successful. Although there should be logic (reserve and unreserve) to make it so that both parties *believes* that the execution is successful. * succeed -> succeeded * Add docs on duration -- revealer should use duration shorter than counterparty * Missing trait type Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> * Runtime interface to add support for tracing from wasm (paritytech#6381) * Add span recording to tracing implementation * Add tracing proxy * switch to rustc_hash::FxHashMap * Replace lazy_static and hashmap with thread_local and vec. * fix marking valid span as invalid while removing invalid spans * refactor, add wasm_tracing module in `support` * update registered spans * tidy up * typos * refactor * update flag name to signal lost trace - `is_valid_trace` * update flag name to signal lost trace - `is_valid_trace` * update docs * update docs * Use tracing Field recording to store the actual `name` and `target` from wasm traces. * fix debug log in subscriber + small refactor * add tests * handle misuse in case trying to exit span not held * Implement filter for wasm traces, simplify field recording for primitive types * remove superfluous warning * update docs * Update primitives/tracing/src/proxy.rs Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com> * Apply suggestions from code review Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * update docs, apply suggestions * move Proxy from thread_local to `Extension`, rename macro * fix test * unify native & wasm span macro calls * implement wasm tracing control facility in primitives and frame * add cli flag `--wasm-tracing` * fix * switch to `Option<u4>` (possible performance degradation), switch to static mut bool * performance improvement using u64 vs Option<u64> * performance improvement moving concat to client * update docs * Update client/cli/src/params/import_params.rs Co-authored-by: Cecile Tonglet <cecile@parity.io> * performance improvement * Revert "performance improvement" This reverts commit cff0aa2. * small refactor * formatting * bump impl_version * Update client/cli/src/config.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * update docs * small fixes, remove pub static * nit * add integration tests and refactor Subscriber * tests * revert formatting * try fix test that works locally but not in CI * try fix test that works locally but not in CI * debug test that works locally but not in CI * fix test that works locally but not in CI * remove pub visibility from bool in runtime * make TracingSpanGuard #[cfg(not(feature = "std"))], update docs, comments * make TracingProxy drop implementation conditional on !empty state * add docs for TraceHandler * remove blank line * update expect message * update tests * rename cli option to tracing_enable_wasm * rename cli option to tracing_enable_wasm * fix * ensure wasm-tracing features are wasm only * bump impl_version * bump impl_version * add `"pallet-scheduler/std"` to `[features]` `std` in node/runtime * refactor service to remove sp_tracing dependency * refactor: line width, trait bounds * improve LogTraceHandler output * fix test * improve tracing log output * Apply suggestions from code review * Apply suggestions from code review Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * swap wasm indication from trace name to a separate value * Update client/tracing/src/lib.rs * add docs * remove runtime features remove wasm_tracing option from CLI remove wasm_tracing flag from ProfilingSubscriber Co-authored-by: Matt Rutherford <mattrutherford@users.noreply.github.com> Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Cecile Tonglet <cecile@parity.io> * Block packet size limit * Revert "Block packet size limit" This reverts commit 9a5892e. * Update s3 artifact url (paritytech#6399) * Increase network buffer sizes even more (paritytech#6080) * Remove pallet-balances from non-dev-deps (paritytech#6407) * Babe VRF Signing in keystore (paritytech#6225) * Introduce trait * Implement VRFSigner in keystore * Use vrf_sign from keystore * Convert output to VRFInOut * Simplify conversion * vrf_sign secondary slot using keystore * Fix RPC call to claim_slot * Use Public instead of Pair * Check primary threshold in signer * Fix interface to return error * Move vrf_sign to BareCryptoStore * Fix authorship_works test * Fix BABE logic leaks * Acquire a read lock once * Also fix RPC acquiring the read lock once * Implement a generic way to construct VRF Transcript * Use make_transcript_data to call sr25519_vrf_sign * Make sure VRFTranscriptData is serializable * Cleanup * Move VRF to it's own module * Implement & test VRF signing in testing module * Remove leftover * Fix feature requirements * Revert removing vec macro * Drop keystore pointer to prevent deadlock * Nitpicks * Add test to make sure make_transcript works * Fix mismatch in VRF transcript * Add a test to verify transcripts match in babe * Return VRFOutput and VRFProof from keystore * Update `libp2p-ping`. (paritytech#6412) Bugfix release, see [CHANGELOG]. [CHANGELOG]: https://github.com/libp2p/rust-libp2p/blob/master/protocols/ping/CHANGELOG.md * Remove --legacy-network-protocol CLI flag (paritytech#6411) * Scale and increase validator count (paritytech#6417) * Expose constants from Proxy Pallet (paritytech#6420) * .maintain/monitoring: Add alerting rule tests (paritytech#6343) * .maintain/monitoring: Add alerting rule tests * .maintain/monitoring/alerting-rules/alerting-rules.yaml: Break lines * .gitlab-ci.yml: Add promtool rule testing step * [CI] Label PRs if polkadot companion build fails (paritytech#6410) * add polkadot-companion-labels.yml * fix polkadot companion job name * add opened event to polkadot-companion-labels.yml * Dont label on timeouts * increase timeouts * increase timeouts again... to be sure * Switch to s3krit/await-status-action Turns out Sibz/await-status-action looks at /ref/statuses, which lists ALL statuses (i.e., if you send a pending and a failure for the same context, it will see both and assume the job is still pending.). I forked and point at /ref/status, which shows a combined summary of each status (i.e., only ever shows the most recent status of a single context). * Print bad mandatory error (paritytech#6416) * Print bad mandatory error This prints the error that leads to bad mandatory. * Update frame/system/src/lib.rs Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> * Adds missing trait import Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> * Track last blocks in informant display (paritytech#6429) This implements tracking of the last seen blocks in informant display to prevent printing the import message twice. In Cumulus we first import blocks as part of the block building with `new_best == false` and set the best block after we know which one was included by the relay chain. This leads to printing the import messages two times. This pr solves the problem by track the latest seen blocks to not print the message twice. * Simple Docs for Atomic Swap Pallet (paritytech#6434) * Simple Docs for Atomic Swap Pallet * Fix copy-and-paste error * More descriptive error message when invalid slot duration is used (paritytech#6430) * Initial commit Forked at: d735e4d No parent branch. * Errors if slot_duration is zero * Errors if slot_duration is zero * Revert "Errors if slot_duration is zero" This reverts commit a9e9820. * Update client/consensus/slots/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Root origin use no filter by default. Scheduler and Democracy dispatch without asserting BaseCallFilter (paritytech#6408) * make system root origin build runtime origin with no filter * additional doc * llow decl-module to have a where clause with trailing comma (paritytech#6431) * .gitlab-ci.yml: Use promtool from paritytech/tools:latest image (paritytech#6425) * Update sync chain info on own block import (paritytech#6424) Before we only updated the chain info of sync when we have imported something using the import queue. However, if you import your own blocks, this is not done using the import queue and so sync is not updated. If we don't do this, it can lead to sync switching to "major sync" mode because sync is not informed about new blocks. This especially happens on Cumulus, where a collator is selected multiple times to include its block into the relay chain and thus, sync switches to major sync mode while the node is still building blocks. * client/authority-discovery: Compare PeerIds and not Multihashes (paritytech#6414) In order to tell whether an address is the local nodes address the authority discovery module previously compared the Multihash within the `p2p` Multiaddr protocol. rust-libp2p recently switched to a new PeerId representation (see [1]). Multihashes of the same PeerId in the new and the old format don't equal. Instead of comparing the Multihashes, this patch ensures the module compares the PeerIds [1] libp2p/rust-libp2p#555 * add network propagated metrics (paritytech#6438) * change (ci): add interruptible to kubernetes jobs (paritytech#6441) * Avoid multisig reentrancy (paritytech#6445) * Validate encoding of extrinsics passed to runtime (paritytech#6442) * Validate encoding of extrinsics passed to runtime * Bump codec version explicitly * Fix Babe secondary plain slots claiming (paritytech#6451) We need to check that the public key of an authority exists in our keystore before we can successfully claim a plain secondary slot. * sp-npos-elections should not depend on itself (paritytech#6444) This removes the `dev-dependency` onto `sp-npos-elections` from itself. A crate should not depend on itself directly, especially not to make any macros work. * Don't autolabel insubstantial PRs 'pleasereview' (paritytech#6447) * change everything to transaction (paritytech#6440) * node: spawn block authoring and grandpa voter as blocking tasks (paritytech#6446) * service: add spawner for essential tasks * node: spawn block authoring and grandpa voter as blocking tasks * Apply suggestions from code review Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * pallet-atomic-swap: generialized swap action (paritytech#6421) * pallet-atomic-swap: generialized swap action * Bump spec_version * Fix weight calculation * Remove unnecessary type aliases * Fix issues with `Operational` transactions validity and prioritization. (paritytech#6435) * Fix weight limit for operational transactions. * Include BlockExecutionWeight. * `pallet-staking`: Expose missing consts (paritytech#6456) * `pallet-staking`: Expose missing consts * Apply suggestions from code review Co-authored-by: Nikolay Volf <nikvolf@gmail.com> Co-authored-by: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update the source docs Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com> Co-authored-by: Nikolay Volf <nikvolf@gmail.com> Co-authored-by: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * update collective events docs to be consistent with changes (paritytech#6463) * [CI] Don't tag PRs on companion job cancels (paritytech#6470) * network: remove unused variable (paritytech#6460) * Avoid panic on dropping a `sc_network::service::out_events::Receiver`. (paritytech#6458) * Avoid panic on dropping a `Receiver`. * CI * Implement nested storage transactions (paritytech#6269) * Add transactional storage functionality to OverlayChanges A collection already has a natural None state. No need to wrap it with an option. * Add storage transactions runtime interface * Add frame support for transactions * Fix committed typo * Rename 'changes' variable to 'overlay' * Fix renaming change * Fixed strange line break * Rename clear to clear_where * Add comment regarding delete value on mutation * Add comment which changes are covered by a transaction * Do force the arg to with_transaction return a Result * Use rust doc comments on every documentable place * Fix wording of insert_diry doc * Improve doc on start_transaction * Rename value to overlayed in close_transaction * Inline negation * Improve wording of close_transaction comments * Get rid of an expect by using get_or_insert_with * Remove trailing whitespace * Rename should to expected in tests * Rolling back a transaction must mark the overlay as dirty * Protect client initiated storage tx from being droped by runtime * Review nits * Return Err when entering or exiting runtime fails * Documentation fixup * Remove close type * Move enter/exit runtime to excute_aux in the state-machine * Rename Discard -> Rollback * Move child changeset creation to constructor * Move child spawning into the closure * Apply suggestions from code review Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Fixup for code suggestion * Unify re-exports * Rename overlay_changes to mod.rs and move into subdir * Change proof wording * Adapt a new test from master to storage-tx * Suggestions from the latest round of review * Fix warning message Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Optimize offchain worker api by re-using http-client (paritytech#6454) * Fix typo in offchain's docs * Use Self keyword in AsyncApi::new() * Move httpclient to be part of OffchainWorkers to optimize block import * Fix compilation errors for tests * Add wrapper struct for HyperClient * Use lazy_static share SharedClient amongst OffchainWorkers. Remove the need to raise the fd limit * Revert "Use lazy_static share SharedClient amongst OffchainWorkers. Remove the need to raise the fd limit" This reverts commit 7af9749. * Add lazy_static for tests * Remove lingering runtime upgrades (paritytech#6476) * Remove lingering runtime upgrades * remove unused warnings * remove tests * impl Debug for sc_service::Configuration (paritytech#6400) * Initial commit Forked at: d735e4d No parent branch. * Make sc_service::Configuration derive Debug * Replace task_executor fn's input by proper TaskExecutor type (cleaner) * impl From<Fn> for TaskExecutor * Update client/cli/src/runner.rs * Add some doc, examples and tests * Replace Deref by fn spawn as suggested Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Fix `sp-api` handling of multiple arguments (paritytech#6484) With the switch to `decode_all_with_depth_limit` we silently broken support for functions with multiple arguments. The old generated code tried to decode each parameter separately, which does not play well with `decode_all`. This pr adds a test to ensure that this does not happen again and fixes the bug by decoding everything at once by wrapping it into tuples. * Fix the browser node and ensure it doesn't colour the informant output (paritytech#6457) * Fix browser informant * Fix documentation * Add an informant_output_format function to the cli config * Wrap informant output format in an option * Revert batch verifier * Remove wasm-timer from primitives io cargo lock * Drop informant_output_format function * derive debug for output format * bound some missing bound for elevated trait (paritytech#6487) * `pallet-scheduler`: Check that `when` is not in the past (paritytech#6480) * `pallet-scheduler`: Check that `when` is not in the past * Break some lines * client/network/service: Add primary dimension to connection metrics (paritytech#6472) * client/network/service: Add primary dimension to connection metrics Two nodes can be interconnected via one or more connections. The first of those connections is called the primary connection. This commit adds another dimension to the `sub_libp2p_connections_{closed,opened}_total` metrics to differentiate primary and non-primary connections being opened / closed. By intuition more than one connection between two nodes is rare. Tracking the fact whether a connection is primary or not will help prove or disprove this intuition. * .maintain/monitoring: Ensure to sum over all connections_closed variants * client/network/service: Rename is_primary to is_first * client/network/service: Split by metric name with two additional metrics * Revert ".maintain/monitoring: Ensure to sum over all connections_closed variants" This reverts commit 2d2f93e. * client/network/service: Remove labels from distinct metrics * Ensure the listen addresses are consistent with the transport (paritytech#6436) * Initial commit Forked at: 0c42ced No parent branch. * Ensure the listen addresses are consistent with the transport * Update client/network/src/error.rs * Update client/network/src/service.rs * Better implementation * Fix bad previous impl * add boot_nodes * reserved nodes * test boot nodes * reserved nodes tests * add public_addresses and make specific error type * Update client/network/src/error.rs Co-authored-by: Pierre Krieger <pierre.krieger1708@gmail.com> Co-authored-by: Pierre Krieger <pierre.krieger1708@gmail.com> * pallet-contracts: migrate to nested storage transaction mechanism (paritytech#6382) * Add a simple direct storage access module * WIP * Completely migrate to the transactional system. * Format * Fix wasm compilation * Get rid of account_db module * Make deposit event eager * Make restore_to eager * It almost compiles. * Make it compile. * Make the tests compile * Get rid of account_db * Drop the result. * Backport the book keeping. * Fix all remaining tests. * Make it compile for std * Remove a stale TODO marker * Remove another stale TODO * Add proof for `terminate` * Remove a stale comment. * Make restoration diverging. * Remove redudnant trait: `ComputeDispatchFee` * Update frame/contracts/src/exec.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> * Introduce proper errors into the storage module. * Adds comments for contract storage module. * Inline `ExecutionContext::terminate`. * Restore_to should not let sacrifice itself if the contract present on the stack. * Inline `transfer` function * Update doc - add "if succeeded" * Adapt to TransactionOutcome changes * Updates the docs for `ext_restore_to` * Add a proper assert. * Update frame/contracts/src/wasm/runtime.rs Co-authored-by: Alexander Theißen <alex.theissen@me.com> Co-authored-by: Alexander Theißen <alex.theissen@me.com> Co-authored-by: Alexander Theißen <alexander.theissen@parity.io> * Update lock Co-authored-by: Subsocial <62490051+subsocialdev@users.noreply.github.com> Co-authored-by: Benjamin Kampmann <ben@gnunicorn.org> Co-authored-by: Nikolay Volf <nikvolf@gmail.com> Co-authored-by: Rakan Alhneiti <rakan.alhneiti@gmail.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Gavin Wood <gavin@parity.io> Co-authored-by: Cecile Tonglet <cecile@parity.io> Co-authored-by: Pierre Krieger <pierre.krieger1708@gmail.com> Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> Co-authored-by: Seun Lanlege <seunlanlege@gmail.com> Co-authored-by: David Craven <david@craven.ch> Co-authored-by: Marcio Diaz <marcio.diaz@gmail.com> Co-authored-by: Shaopeng Wang <spxwang@gmail.com> Co-authored-by: Denis Pisarev <denis.pisarev@parity.io> Co-authored-by: Bastian Köcher <git@kchr.de> Co-authored-by: Sergei Shulepov <sergei@parity.io> Co-authored-by: Roman Borschel <romanb@users.noreply.github.com> Co-authored-by: André Silva <123550+andresilva@users.noreply.github.com> Co-authored-by: Tomasz Drwięga <tomusdrw@users.noreply.github.com> Co-authored-by: Alexander Popiak <alexander.popiak@parity.io> Co-authored-by: Dan Forbes <dan@danforbes.dev> Co-authored-by: Alexander Theißen <alex.theissen@me.com> Co-authored-by: joe petrowski <25483142+joepetrowski@users.noreply.github.com> Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com> Co-authored-by: Tore19 <289649077@qq.com> Co-authored-by: wangjj9219 <183318287@qq.com> Co-authored-by: Guillaume Thiolliere <gui.thiolliere@gmail.com> Co-authored-by: tgmichel <telmo@purestake.com> Co-authored-by: Demi Obenour <demi@parity.io> Co-authored-by: Bernhard Schuster <bernhard@ahoi.io> Co-authored-by: Bernhard Schuster <bernhard@parity.io> Co-authored-by: s3krit <pugh@s3kr.it> Co-authored-by: Ashley <ashley.ruglys@gmail.com> Co-authored-by: Max Inden <mail@max-inden.de> Co-authored-by: Xiliang Chen <xlchen1291@gmail.com> Co-authored-by: Svyatoslav Nikolsky <svyatonik@gmail.com> Co-authored-by: Arkadiy Paronyan <arkady.paronyan@gmail.com> Co-authored-by: Wei Tang <hi@that.world> Co-authored-by: mattrutherford <44339188+mattrutherford@users.noreply.github.com> Co-authored-by: Matt Rutherford <mattrutherford@users.noreply.github.com> Co-authored-by: ddorgan <david@parity.io> Co-authored-by: Toralf Wittner <tw@dtex.org> Co-authored-by: pscott <30843220+pscott@users.noreply.github.com> Co-authored-by: Alexander Theißen <alexander.theissen@parity.io>
Adds a check to make sure that
Operational
transactions weight does not exceed the limit for such transactions (sinceOperational
transactions are allowed to consumeNormal
transaction space, the limit is actuallyMaximumBlockWeight
).Changes the priority of
Operational
transactions tomax_value / 2
to make sure things that alter priority (liketip
) for instance can be used for replacement transactions.