Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

Implement tracing::Event handling & parent_id for spans and events #6672

Merged
28 commits merged into from
Aug 12, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
e43faeb
implement events handling, implement parent_id for spans & events
mattrutherford Jul 16, 2020
5d0d25a
add events to sp_io::storage
mattrutherford Jul 16, 2020
0b7f4f8
update test
mattrutherford Jul 16, 2020
f7981fc
add tests
mattrutherford Jul 16, 2020
f892b57
adjust limit
mattrutherford Jul 16, 2020
159ac53
Merge remote-tracking branch 'origin/master' into tracing-events
gnunicorn Jul 22, 2020
ffb8713
let tracing crate handle parent_ids
gnunicorn Jul 22, 2020
cc3e5e3
re-enable current-id tracking
gnunicorn Jul 22, 2020
89a9b73
Merge branch 'master' into tracing-events
mattrutherford Jul 22, 2020
38b412c
Merge branch 'tracing-events' of github.com:paritytech/substrate into…
mattrutherford Jul 22, 2020
1855a9a
add test for threads with CurrentSpan
mattrutherford Jul 22, 2020
2081e5d
fix log level
mattrutherford Jul 22, 2020
8da1d7a
remove redundant check for non wasm traces
mattrutherford Jul 22, 2020
64d9863
remove duplicate definition in test
mattrutherford Jul 22, 2020
4dfc683
Adding conditional events API
gnunicorn Jul 23, 2020
c4bac2d
prefer explicit parent_id over current,
mattrutherford Jul 23, 2020
c6d3b5c
Merge branch 'tracing-events' of github.com:paritytech/substrate into…
mattrutherford Jul 23, 2020
f4ee909
limit changes to client::tracing event implementation
mattrutherford Jul 23, 2020
0e14ca5
remove From impl due to fallback required on parent_id
mattrutherford Jul 23, 2020
0b7b16e
Merge branch 'master' into tracing-events
mattrutherford Jul 23, 2020
b8a105d
Merge branch 'master' into tracing-events
mattrutherford Aug 3, 2020
912b4d5
implement SPAN_LIMIT
mattrutherford Aug 3, 2020
7fa7f26
change version of tracing-core
mattrutherford Aug 3, 2020
b42464b
Merge branch 'master' into tracing-events
mattrutherford Aug 10, 2020
9e42b31
update dependancies
mattrutherford Aug 10, 2020
8f16d7b
revert limit
mattrutherford Aug 11, 2020
4717247
remove duplicate dependency
mattrutherford Aug 11, 2020
9dc17e3
Apply suggestions from code review
mattrutherford Aug 12, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
limit changes to client::tracing event implementation
  • Loading branch information
mattrutherford committed Jul 23, 2020
commit f4ee909b29386037bdaf424844877c7375011b73
1 change: 0 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 0 additions & 6 deletions client/tracing/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -664,9 +664,3 @@ mod tests {
assert!(event3.parent_id.is_none());
}
}

struct WasmSpan<'a>{
name: &'a str,
target: &'a str,
data: &'a
}
2 changes: 1 addition & 1 deletion client/transaction-pool/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ sc-transaction-graph = { version = "2.0.0-rc5", path = "./graph" }
sp-api = { version = "2.0.0-rc5", path = "../../primitives/api" }
sp-core = { version = "2.0.0-rc5", path = "../../primitives/core" }
sp-runtime = { version = "2.0.0-rc5", path = "../../primitives/runtime" }
sp-tracing = { version = "2.0.0-rc5", features = ["with-tracing"], path = "../../primitives/tracing" }
sp-tracing = { version = "2.0.0-rc5", path = "../../primitives/tracing" }
sp-transaction-pool = { version = "2.0.0-rc5", path = "../../primitives/transaction-pool" }
sp-blockchain = { version = "2.0.0-rc5", path = "../../primitives/blockchain" }
sp-utils = { version = "2.0.0-rc5", path = "../../primitives/utils" }
Expand Down
5 changes: 1 addition & 4 deletions frame/executive/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ pallet-transaction-payment = { version = "2.0.0-rc5", path = "../transaction-pay
sp-version = { version = "2.0.0-rc5", path = "../../primitives/version" }

[features]
default = ["std", "with-tracing"]
default = ["std"]
std = [
"codec/std",
"frame-support/std",
Expand All @@ -41,6 +41,3 @@ std = [
"sp-tracing/std",
"sp-std/std",
]
with-tracing = [
"sp-tracing/with-tracing"
]
25 changes: 6 additions & 19 deletions frame/executive/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -197,7 +197,7 @@ impl<
COnRuntimeUpgrade: OnRuntimeUpgrade,
> Executive<System, Block, Context, UnsignedValidator, AllModules, COnRuntimeUpgrade>
where
Block::Extrinsic: Checkable<Context> + tg vbhghhhhggc,
Block::Extrinsic: Checkable<Context> + Codec,
CheckedOf<Block::Extrinsic, Context>:
Applyable +
GetDispatchInfo,
Expand All @@ -207,7 +207,6 @@ where
{
/// Start the execution of a particular block.
pub fn initialize_block(header: &System::Header) {
sp_tracing::enter_span! { sp_tracing::Level::INFO, "initialize block" };
let digests = Self::extract_pre_digest(&header);
Self::initialize_block_impl(
header.number(),
Expand Down Expand Up @@ -271,7 +270,6 @@ where
}

fn initial_checks(block: &Block) {
sp_tracing::enter_span! { sp_tracing::Level::INFO, "initial checks" };
let header = block.header();

// Check that `parent_hash` is correct.
Expand Down Expand Up @@ -311,19 +309,12 @@ where

/// Execute given extrinsics and take care of post-extrinsics book-keeping.
fn execute_extrinsics_with_book_keeping(extrinsics: Vec<Block::Extrinsic>, block_number: NumberFor<Block>) {
{
sp_tracing::enter_span! { sp_tracing::Level::INFO, "executing extrinsics" };
extrinsics.into_iter().for_each(Self::apply_extrinsic_no_note);
}
extrinsics.into_iter().for_each(Self::apply_extrinsic_no_note);

{
sp_tracing::enter_span! { sp_tracing::Level::INFO, "finalizing" };
// post-extrinsics book-keeping
<frame_system::Module<System>>::note_finished_extrinsics();

<frame_system::Module<System> as OnFinalize<System::BlockNumber>>::on_finalize(block_number);
<AllModules as OnFinalize<System::BlockNumber>>::on_finalize(block_number);
}
// post-extrinsics book-keeping
<frame_system::Module<System>>::note_finished_extrinsics();
<frame_system::Module<System> as OnFinalize<System::BlockNumber>>::on_finalize(block_number);
<AllModules as OnFinalize<System::BlockNumber>>::on_finalize(block_number);
}

/// Finalize the block - it is up the caller to ensure that all header fields are valid
Expand Down Expand Up @@ -364,9 +355,6 @@ where
encoded_len: usize,
to_note: Option<Vec<u8>>,
) -> ApplyExtrinsicResult {
sp_tracing::enter_span! { sp_tracing::Level::INFO, "applying extrinsic"};
// FIXME: add support for Codec
// sp_tracing::event!(sp_tracing::Level::INFO, extrinsic = ?uxt);
// Verify that the signature is good.
let xt = uxt.check(&Default::default())?;

Expand All @@ -389,7 +377,6 @@ where
}

fn final_checks(header: &System::Header) {
sp_tracing::enter_span! { sp_tracing::Level::INFO, "final checks" };
// remove temporaries
let new_header = <frame_system::Module<System>>::finalize();

Expand Down
5 changes: 1 addition & 4 deletions frame/support/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ frame-system = { version = "2.0.0-rc5", path = "../system" }
parity-util-mem = { version = "0.7.0", features = ["primitive-types"] }

[features]
default = ["std", "with-tracing"]
default = ["std"]
std = [
"once_cell",
"bitmask/std",
Expand All @@ -52,9 +52,6 @@ std = [
"sp-inherents/std",
"sp-state-machine",
]
with-tracing = [
"sp-tracing/with-tracing"
]
nightly = []
strict = []
runtime-benchmarks = []
2 changes: 0 additions & 2 deletions primitives/io/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@ sp-tracing = { version = "2.0.0-rc5", default-features = false, path = "../traci
log = { version = "0.4.8", optional = true }
futures = { version = "0.3.1", features = ["thread-pool"], optional = true }
parking_lot = { version = "0.10.0", optional = true }
tracing = { version = "0.1.16", optional = true }

[features]
default = ["std"]
Expand All @@ -46,7 +45,6 @@ std = [
"log",
"futures",
"parking_lot",
"tracing"
]

# These two features are used for `no_std` builds for the environments which already provides
Expand Down
56 changes: 2 additions & 54 deletions primitives/io/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -100,25 +100,12 @@ pub trait Storage {

/// Set `key` to `value` in the storage.
fn set(&mut self, key: &[u8], value: &[u8]) {
#[cfg(feature = "std")]
tracing::event!(
tracing::Level::INFO,
?key,
?value,
"set"
);
self.set_storage(key.to_vec(), value.to_vec());
}

/// Clear the storage of the given `key` and its value.
fn clear(&mut self, key: &[u8]) {
#[cfg(feature = "std")]
tracing::event!(
tracing::Level::INFO,
?key,
"clear"
);
self.clear_storage(key);
self.clear_storage(key)
}

/// Check whether the given `key` exists in storage.
Expand All @@ -128,13 +115,7 @@ pub trait Storage {

/// Clear the storage of each key-value pair where the key starts with the given `prefix`.
fn clear_prefix(&mut self, prefix: &[u8]) {
#[cfg(feature = "std")]
tracing::event!(
tracing::Level::INFO,
?prefix,
"clear_prefix"
);
Externalities::clear_prefix(*self, prefix);
Externalities::clear_prefix(*self, prefix)
}

/// Append the encoded `value` to the storage item at `key`.
Expand All @@ -146,13 +127,6 @@ pub trait Storage {
/// If the storage item does not support [`EncodeAppend`](codec::EncodeAppend) or
/// something else fails at appending, the storage item will be set to `[value]`.
fn append(&mut self, key: &[u8], value: Vec<u8>) {
#[cfg(feature = "std")]
tracing::event!(
tracing::Level::INFO,
?key,
?value,
"append"
);
self.storage_append(key.to_vec(), value);
}

Expand All @@ -162,11 +136,6 @@ pub trait Storage {
///
/// Returns a `Vec<u8>` that holds the SCALE encoded hash.
fn root(&mut self) -> Vec<u8> {
#[cfg(feature = "std")]
tracing::event!(
tracing::Level::INFO,
"root"
);
self.storage_root()
}

Expand All @@ -178,12 +147,6 @@ pub trait Storage {
/// Returns `Some(Vec<u8>)` which holds the SCALE encoded hash or `None` when
/// changes trie is disabled.
fn changes_root(&mut self, parent_hash: &[u8]) -> Option<Vec<u8>> {
#[cfg(feature = "std")]
tracing::event!(
tracing::Level::INFO,
?parent_hash,
"changes_root"
);
self.storage_changes_root(parent_hash)
.expect("Invalid `parent_hash` given to `changes_root`.")
}
Expand All @@ -206,11 +169,6 @@ pub trait Storage {
/// in unbalanced transactions. For example, FRAME users should use high level storage
/// abstractions.
fn start_transaction(&mut self) {
#[cfg(feature = "std")]
tracing::event!(
tracing::Level::INFO,
"start_transaction"
);
self.storage_start_transaction();
}

Expand All @@ -222,11 +180,6 @@ pub trait Storage {
///
/// Will panic if there is no open transaction.
fn rollback_transaction(&mut self) {
#[cfg(feature = "std")]
tracing::event!(
tracing::Level::INFO,
"rollback_transaction"
);
self.storage_rollback_transaction()
.expect("No open transaction that can be rolled back.");
}
Expand All @@ -239,11 +192,6 @@ pub trait Storage {
///
/// Will panic if there is no open transaction.
fn commit_transaction(&mut self) {
#[cfg(feature = "std")]
tracing::event!(
tracing::Level::INFO,
"commit_transaction"
);
self.storage_commit_transaction()
.expect("No open transaction that can be committed.");
}
Expand Down
5 changes: 2 additions & 3 deletions primitives/tracing/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,10 @@ description = "Instrumentation primitives and macros for Substrate."
targets = ["x86_64-unknown-linux-gnu"]

[dependencies]
tracing = { version = "0.1.13", optional = true, default-features = false }
tracing = { version = "0.1.13", optional = true }
rental = { version = "0.5.5", optional = true }
log = { version = "0.4.8", optional = true }

[features]
default = [ "std" ]
with-tracing = [ "tracing" ]
std = [ "with-tracing", "tracing/std", "rental", "log" ]
std = [ "tracing", "rental", "log" ]
Loading