Skip to content

Commit

Permalink
editoast: setup tracing with opentelemetry for TestApp
Browse files Browse the repository at this point in the history
Signed-off-by: home <[email protected]>
  • Loading branch information
home committed Dec 18, 2024
1 parent 5af6621 commit c5b5f96
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 20 deletions.
18 changes: 18 additions & 0 deletions editoast/Cargo.lock

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

3 changes: 2 additions & 1 deletion editoast/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ axum-extra = { version = "0.9.6", default-features = false, features = [
"typed-header",
] }
axum-test = { version = "16.4.1", default-features = false }
axum-tracing-opentelemetry = { version = "0.24.1", default-features = false }
axum-tracing-opentelemetry = { version = "0.24.1", default-features = false, features = ["tracing_level_info"] }
chrono.workspace = true
clap = { version = "4.5.23", features = ["derive", "env"] }
colored = "2.2.0"
Expand Down Expand Up @@ -147,6 +147,7 @@ opentelemetry-otlp = { version = "0.27.0", default-features = false, features =
] }
opentelemetry-semantic-conventions.workspace = true
opentelemetry_sdk = { version = "0.27.1", features = ["rt-tokio", "trace"] }
opentelemetry-stdout = { version = "0.27.0" }
ordered-float = { version = "4.5.0", features = ["serde"] }
osm_to_railjson = { path = "./osm_to_railjson" }
paste.workspace = true
Expand Down
37 changes: 29 additions & 8 deletions editoast/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ use client::Commands;
use editoast_models::DbConnectionPoolV2;
use models::RollingStockModel;
use opentelemetry::trace::TracerProvider as _;
use opentelemetry_sdk::export::trace::SpanExporter;
use opentelemetry_sdk::propagation::TraceContextPropagator;
use opentelemetry_sdk::resource::EnvResourceDetector;
use opentelemetry_sdk::resource::SdkProvidedResourceDetector;
Expand Down Expand Up @@ -66,12 +67,17 @@ pub use valkey_utils::ValkeyConnection;
/// - we *expect* a webserver to output logging information, so since it's an expected
/// output (and not extra information), it should be on stdout
#[derive(Debug, PartialEq)]
enum EditoastMode {
pub enum EditoastMode {
Webservice,
Cli,
}

fn init_tracing(mode: EditoastMode, telemetry_config: &client::TelemetryConfig) {
pub fn init_tracing<T: SpanExporter + 'static>(
mode: EditoastMode,
telemetry_config: &client::TelemetryConfig,
exporter: T,
for_test: bool,
) -> Option<tracing::subscriber::DefaultGuard> {
let env_filter_layer = tracing_subscriber::EnvFilter::builder()
// Set the default log level to 'info'
.with_default_directive(tracing_subscriber::filter::LevelFilter::INFO.into())
Expand All @@ -89,11 +95,6 @@ fn init_tracing(mode: EditoastMode, telemetry_config: &client::TelemetryConfig)
let telemetry_layer = match telemetry_config.telemetry_kind {
client::TelemetryKind::None => None,
client::TelemetryKind::Opentelemetry => {
let exporter = opentelemetry_otlp::SpanExporter::builder()
.with_tonic()
.with_endpoint(telemetry_config.telemetry_endpoint.as_str())
.build()
.expect("failed to build a span exporter");
let resource = Resource::new(vec![KeyValue::new(
opentelemetry_semantic_conventions::resource::SERVICE_NAME,
telemetry_config.service_name.clone(),
Expand All @@ -116,11 +117,21 @@ fn init_tracing(mode: EditoastMode, telemetry_config: &client::TelemetryConfig)
Some(layer)
}
};

if for_test {
let subscriber = tracing_subscriber::registry()
.with(telemetry_layer)
.with(env_filter_layer)
.with(fmt_layer);
return Some(tracing::subscriber::set_default(subscriber));
}

tracing_subscriber::registry()
.with(telemetry_layer)
.with(env_filter_layer)
.with(fmt_layer)
.init();
None
}

impl EditoastMode {
Expand Down Expand Up @@ -151,7 +162,17 @@ async fn main() {

async fn run() -> Result<(), Box<dyn Error + Send + Sync>> {
let client = Client::parse();
init_tracing(EditoastMode::from_client(&client), &client.telemetry_config);
let exporter = opentelemetry_otlp::SpanExporter::builder()
.with_tonic()
.with_endpoint(client.telemetry_config.telemetry_endpoint.as_str())
.build()
.expect("failed to build a span exporter");
let _ = init_tracing(
EditoastMode::from_client(&client),
&client.telemetry_config,
exporter,
false,
);

let pg_config = client.postgres_config;
let db_pool =
Expand Down
21 changes: 10 additions & 11 deletions editoast/src/views/test_app.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,14 @@ use tower_http::trace::TraceLayer;
use url::Url;

use crate::{
client::{TelemetryConfig, TelemetryKind},
core::{mocking::MockingClient, CoreClient},
generated_data::speed_limit_tags_config::SpeedLimitTagIds,
infra_cache::InfraCache,
init_tracing,
map::MapLayers,
valkey_utils::ValkeyConfig,
AppState, ValkeyClient,
AppState, EditoastMode, ValkeyClient,
};
use axum_test::TestRequest;
use axum_test::TestServer;
Expand Down Expand Up @@ -106,16 +108,13 @@ impl TestAppBuilder {
};

// Setup tracing
let sub = tracing_subscriber::fmt()
.pretty()
.with_env_filter(
tracing_subscriber::EnvFilter::builder()
.with_default_directive(tracing_subscriber::filter::LevelFilter::DEBUG.into())
.from_env_lossy(),
)
.with_span_events(tracing_subscriber::fmt::format::FmtSpan::CLOSE)
.finish();
let tracing_guard = tracing::subscriber::set_default(sub);
let exporter = opentelemetry_stdout::SpanExporter::default();
let telemety_config = TelemetryConfig {
telemetry_kind: TelemetryKind::Opentelemetry,
..Default::default()
};
let tracing_guard =
init_tracing(EditoastMode::Webservice, &telemety_config, exporter, true).unwrap();

// Config valkey
let valkey = ValkeyClient::new(config.valkey_config.clone())
Expand Down

0 comments on commit c5b5f96

Please sign in to comment.