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

Allow adding a prefix to the informant #6174

Merged
merged 41 commits into from
Jun 9, 2020
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
6c3a2c0
Initial commit
cecton May 28, 2020
9c2e726
Add a Service Configuration's field + adapt informant + provide means…
cecton May 28, 2020
c966d4b
CLEANUP
cecton May 28, 2020
a3c306e
fix tests
cecton May 28, 2020
d3c1d52
fixed bad path to object
cecton May 28, 2020
cd86c58
Change OutputFormat enum to struct
cecton May 29, 2020
6c0029b
Add informant_prefix to builder and service
cecton Jun 2, 2020
ed89283
Revert "Change OutputFormat enum to struct"
cecton Jun 2, 2020
ad18c29
Revert "fix tests"
cecton Jun 2, 2020
ff258dc
Revert "Add a Service Configuration's field + adapt informant + provi…
cecton Jun 2, 2020
f5cf997
Implementation using the ServiceBuilder
cecton Jun 2, 2020
1b02761
reduce line length
cecton Jun 2, 2020
b88ed95
Merge commit f85fabd753c40041edcaac487f6f1ce259e8d11b (no conflict)
cecton Jun 2, 2020
b81f8ff
fix line width again
cecton Jun 2, 2020
a04e788
WIP
cecton Jun 2, 2020
cb8e402
WIP
cecton Jun 2, 2020
5dceb40
WIP
cecton Jun 2, 2020
bf7e144
use struct instead of enum
cecton Jun 2, 2020
d8daabb
WIP
cecton Jun 2, 2020
4133e3c
Update client/service/src/lib.rs
cecton Jun 3, 2020
23d775e
improve doc
cecton Jun 3, 2020
f006ccf
Update client/service/src/builder.rs
cecton Jun 3, 2020
b5dd8d8
Update client/service/src/builder.rs
cecton Jun 3, 2020
e32866a
change code
cecton Jun 3, 2020
1b38e33
Update client/informant/src/lib.rs
cecton Jun 3, 2020
5523518
enable_color
cecton Jun 3, 2020
36c4148
reorg log
cecton Jun 3, 2020
9728c25
remove macro
cecton Jun 3, 2020
036a1ea
Removed builder for informant prefix
cecton Jun 3, 2020
f494058
fix doc
cecton Jun 3, 2020
6ba7627
Update client/informant/src/lib.rs
cecton Jun 8, 2020
c1ec56a
Update client/informant/src/lib.rs
cecton Jun 8, 2020
d334904
Update client/informant/src/lib.rs
cecton Jun 8, 2020
f73afa4
Update client/informant/src/lib.rs
cecton Jun 8, 2020
89a9c2b
Update client/service/src/builder.rs
cecton Jun 8, 2020
a82f2cb
Update client/service/src/builder.rs
cecton Jun 8, 2020
f75b06a
Update client/service/src/builder.rs
cecton Jun 8, 2020
f1bcacb
Merge commit cc5b3a63fe5adb5100436ff43d5260a2ea18d893 (no conflict)
cecton Jun 9, 2020
38a4f27
Merge commit e287915eb37928491adbf4666e764ea0be5ac21a (conflicts)
cecton Jun 9, 2020
bb7c7c2
Merge commit feb334d87773331c23ef6560a55f43fcb5ef62a8 (no conflict)
cecton Jun 9, 2020
89b5df8
Merge branch 'cecton-informant-prefix' of github.com:paritytech/subst…
cecton Jun 9, 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
6 changes: 6 additions & 0 deletions client/cli/src/commands/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -402,6 +402,12 @@ macro_rules! substrate_cli_subcommands {
$($enum::$variant(cmd) => cmd.log_filters()),*
}
}

fn informant_prefix<C: $crate::SubstrateCli>(&self) -> $crate::Result<String> {
match self {
$($enum::$variant(cmd) => cmd.informant_prefix::<C>()),*
}
}
}
}
}
Expand Down
6 changes: 6 additions & 0 deletions client/cli/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -393,6 +393,11 @@ pub trait CliConfiguration: Sized {
Ok(true)
}

/// A prefix for the informant's logs
fn informant_prefix<C: SubstrateCli>(&self) -> Result<String> {
Ok(C::informant_prefix().to_string())
}

/// Create a Configuration object from the current object
fn create_configuration<C: SubstrateCli>(
&self,
Expand Down Expand Up @@ -464,6 +469,7 @@ pub trait CliConfiguration: Sized {
max_runtime_instances,
announce_block: self.announce_block()?,
role,
informant_prefix: self.informant_prefix::<C>()?,
})
}

Expand Down
5 changes: 5 additions & 0 deletions client/cli/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,11 @@ pub trait SubstrateCli: Sized {
/// Chain spec factory
fn load_spec(&self, id: &str) -> std::result::Result<Box<dyn ChainSpec>, String>;

/// A prefix for the informant's logs
fn informant_prefix() -> &'static str {
""
}

/// Helper function used to parse the command line arguments. This is the equivalent of
/// `structopt`'s `from_iter()` except that it takes a `VersionInfo` argument to provide the name of
/// the application, author, "about" and version. It will also set `AppSettings::GlobalVersion`.
Expand Down
6 changes: 5 additions & 1 deletion client/cli/src/runner.rs
Original file line number Diff line number Diff line change
Expand Up @@ -209,9 +209,13 @@ impl<C: SubstrateCli> Runner<C> {
F: FnOnce(Configuration) -> std::result::Result<T, sc_service::error::Error>,
T: AbstractService + Unpin,
{
let prefix = self.config.informant_prefix.clone();
let service = service_builder(self.config)?;

let informant_future = sc_informant::build(&service, sc_informant::OutputFormat::Coloured);
let informant_future = sc_informant::build(&service, sc_informant::OutputFormat {
colors: true,
prefix,
});
let _informant_handle = self.tokio_runtime.spawn(informant_future);

// we eagerly drop the service so that the internal exit future is fired,
Expand Down
22 changes: 13 additions & 9 deletions client/informant/src/display.rs
Original file line number Diff line number Diff line change
Expand Up @@ -67,16 +67,18 @@ impl<B: BlockT> InformantDisplay<B> {
self.last_update = Instant::now();
self.last_number = Some(best_number);

let (status, target) = match (net_status.sync_state, net_status.best_seen_block) {
(SyncState::Idle, _) => ("💤 Idle".into(), "".into()),
(SyncState::Downloading, None) => (format!("⚙️ Preparing{}", speed), "".into()),
(SyncState::Downloading, Some(n)) => (format!("⚙️ Syncing{}", speed), format!(", target=#{}", n)),
let (level, status, target) = match (net_status.sync_state, net_status.best_seen_block) {
(SyncState::Idle, _) => ("💤", "Idle".into(), "".into()),
(SyncState::Downloading, None) => ("⚙️ ", format!("Preparing{}", speed), "".into()),
(SyncState::Downloading, Some(n)) => ("⚙️ ", format!("Syncing{}", speed), format!(", target=#{}", n)),
};

if self.format == OutputFormat::Coloured {
if self.format.colors {
info!(
target: "substrate",
"{}{} ({} peers), best: #{} ({}), finalized #{} ({}), {} {}",
"{} {}{}{} ({} peers), best: #{} ({}), finalized #{} ({}), {} {}",
level,
self.format.prefix,
Colour::White.bold().paint(&status),
target,
Colour::White.bold().paint(format!("{}", num_connected_peers)),
Expand All @@ -86,11 +88,13 @@ impl<B: BlockT> InformantDisplay<B> {
info.chain.finalized_hash,
Colour::Green.paint(format!("⬇ {}", TransferRateFormat(net_status.average_download_per_sec))),
Colour::Red.paint(format!("⬆ {}", TransferRateFormat(net_status.average_upload_per_sec))),
);
)
} else {
info!(
target: "substrate",
"{}{} ({} peers), best: #{} ({}), finalized #{} ({}), ⬇ {} ⬆ {}",
"{} {}{}{} ({} peers), best: #{} ({}), finalized #{} ({}), ⬇ {} ⬆ {}",
level,
self.format.prefix,
status,
target,
num_connected_peers,
Expand All @@ -100,7 +104,7 @@ impl<B: BlockT> InformantDisplay<B> {
info.chain.finalized_hash,
TransferRateFormat(net_status.average_download_per_sec),
TransferRateFormat(net_status.average_upload_per_sec),
);
)
}
}
}
Expand Down
25 changes: 19 additions & 6 deletions client/informant/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -29,18 +29,18 @@ use std::time::Duration;
mod display;

/// The format to print telemetry output in.
#[derive(PartialEq)]
pub enum OutputFormat {
Coloured,
Plain,
#[derive(Clone)]
pub struct OutputFormat {
pub prefix: String,
pub colors: bool,
}

/// Creates an informant in the form of a `Future` that must be polled regularly.
cecton marked this conversation as resolved.
Show resolved Hide resolved
pub fn build(service: &impl AbstractService, format: OutputFormat) -> impl futures::Future<Output = ()> {
let client = service.client();
let pool = service.transaction_pool();

let mut display = display::InformantDisplay::new(format);
let mut display = display::InformantDisplay::new(format.clone());

let display_notifications = service
.network_status(Duration::from_millis(5000))
Expand Down Expand Up @@ -97,7 +97,20 @@ pub fn build(service: &impl AbstractService, format: OutputFormat) -> impl futur
last_best = Some((n.header.number().clone(), n.hash.clone()));
}

info!(target: "substrate", "✨ Imported #{} ({})", Colour::White.bold().paint(format!("{}", n.header.number())), n.hash);
if format.colors {
info!(
target: "substrate",
"✨ {}Imported #{} ({})",
format.prefix, Colour::White.bold().paint(n.header.number().to_string()), n.hash,
)
} else {
info!(
target: "substrate",
"✨ {}Imported #{} ({})",
format.prefix, n.header.number(), n.hash,
)
}

future::ready(())
});

Expand Down
2 changes: 2 additions & 0 deletions client/service/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,8 @@ pub struct Configuration {
pub max_runtime_instances: usize,
/// Announce block automatically after they have been imported
pub announce_block: bool,
/// A prefix for the informant's logs
pub informant_prefix: String,
}

/// Type for tasks spawned by the executor.
Expand Down
1 change: 1 addition & 0 deletions client/service/test/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -210,6 +210,7 @@ fn node_config<G: RuntimeGenesis + 'static, E: ChainSpecExtension + Clone + 'sta
tracing_receiver: Default::default(),
max_runtime_instances: 8,
announce_block: true,
informant_prefix: Default::default(),
}
}

Expand Down
6 changes: 5 additions & 1 deletion utils/browser/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,7 @@ where
wasm_method: Default::default(),
max_runtime_instances: 8,
announce_block: true,
informant_prefix: Default::default(),
};

Ok(config)
Expand All @@ -118,7 +119,10 @@ struct RpcMessage {
pub fn start_client(mut service: impl AbstractService) -> Client {
// Spawn informant
wasm_bindgen_futures::spawn_local(
sc_informant::build(&service, sc_informant::OutputFormat::Plain).map(drop)
sc_informant::build(
&service,
sc_informant::OutputFormat { colors: false, prefix: Default::default() },
).map(drop)
);

// We dispatch a background task responsible for processing the service.
Expand Down