LCOV - differential code coverage report
Current view: top level - compute_tools/src - logger.rs (source / functions) Coverage Total Hit CBC
Current: cd44433dd675caa99df17a61b18949c8387e2242.info Lines: 100.0 % 25 25 25
Current Date: 2024-01-09 02:06:09 Functions: 100.0 % 3 3 3
Baseline: 66c52a629a0f4a503e193045e0df4c77139e344b.info
Baseline Date: 2024-01-08 15:34:46

           TLA  Line data    Source code
       1                 : use tracing_opentelemetry::OpenTelemetryLayer;
       2                 : use tracing_subscriber::layer::SubscriberExt;
       3                 : use tracing_subscriber::prelude::*;
       4                 : 
       5                 : /// Initialize logging to stderr, and OpenTelemetry tracing and exporter.
       6                 : ///
       7                 : /// Logging is configured using either `default_log_level` or
       8                 : /// `RUST_LOG` environment variable as default log level.
       9                 : ///
      10                 : /// OpenTelemetry is configured with OTLP/HTTP exporter. It picks up
      11                 : /// configuration from environment variables. For example, to change the destination,
      12                 : /// set `OTEL_EXPORTER_OTLP_ENDPOINT=http://jaeger:4318`. See
      13                 : /// `tracing-utils` package description.
      14                 : ///
      15 CBC         544 : pub fn init_tracing_and_logging(default_log_level: &str) -> anyhow::Result<()> {
      16             544 :     // Initialize Logging
      17             544 :     let env_filter = tracing_subscriber::EnvFilter::try_from_default_env()
      18             544 :         .unwrap_or_else(|_| tracing_subscriber::EnvFilter::new(default_log_level));
      19             544 : 
      20             544 :     let fmt_layer = tracing_subscriber::fmt::layer()
      21             544 :         .with_ansi(false)
      22             544 :         .with_target(false)
      23             544 :         .with_writer(std::io::stderr);
      24             544 : 
      25             544 :     // Initialize OpenTelemetry
      26             544 :     let otlp_layer =
      27             544 :         tracing_utils::init_tracing_without_runtime("compute_ctl").map(OpenTelemetryLayer::new);
      28             544 : 
      29             544 :     // Put it all together
      30             544 :     tracing_subscriber::registry()
      31             544 :         .with(env_filter)
      32             544 :         .with(otlp_layer)
      33             544 :         .with(fmt_layer)
      34             544 :         .init();
      35             544 :     tracing::info!("logging and tracing started");
      36                 : 
      37             544 :     utils::logging::replace_panic_hook_with_tracing_panic_hook().forget();
      38             544 : 
      39             544 :     Ok(())
      40             544 : }
        

Generated by: LCOV version 2.1-beta