arti_testing/
traces.rs
1use std::sync::{
4 atomic::{AtomicUsize, Ordering},
5 Arc,
6};
7use tracing::Subscriber;
8use tracing_subscriber::Layer;
9
10#[derive(Default)]
12pub(crate) struct TraceCount {
13 trace: AtomicUsize,
15 debug: AtomicUsize,
17 info: AtomicUsize,
19 warn: AtomicUsize,
21 error: AtomicUsize,
23}
24
25impl std::fmt::Display for TraceCount {
26 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
27 std::sync::atomic::fence(Ordering::SeqCst);
28 let trace = self.trace.load(Ordering::SeqCst);
29 let debug = self.debug.load(Ordering::SeqCst);
30 let info = self.info.load(Ordering::SeqCst);
31 let warn = self.warn.load(Ordering::SeqCst);
32 let error = self.error.load(Ordering::SeqCst);
33
34 write!(
35 f,
36 "Trace: {}, Debug: {}, Info: {}, Warn: {}, Error: {}",
37 trace, debug, info, warn, error
38 )
39 }
40}
41
42pub(crate) struct TraceCounter(pub(crate) Arc<TraceCount>);
44
45impl<S: Subscriber> Layer<S> for TraceCounter {
46 fn on_event(
47 &self,
48 event: &tracing::Event<'_>,
49 _ctx: tracing_subscriber::layer::Context<'_, S>,
50 ) {
51 use tracing::Level;
52 let var = match *event.metadata().level() {
53 Level::TRACE => &self.0.trace,
54 Level::DEBUG => &self.0.debug,
55 Level::INFO => &self.0.info,
56 Level::WARN => &self.0.warn,
57 Level::ERROR => &self.0.error,
58 };
59
60 var.fetch_add(1, Ordering::Relaxed);
61 }
62}