mirror of
https://github.com/PostHog/posthog.git
synced 2024-11-22 08:40:03 +01:00
82 lines
2.8 KiB
Rust
82 lines
2.8 KiB
Rust
use std::sync::Arc;
|
|
|
|
use common_types::ClickHouseEvent;
|
|
use cymbal::{
|
|
config::Config,
|
|
frames::RawFrame,
|
|
symbol_store::{
|
|
caching::{Caching, SymbolSetCache},
|
|
sourcemap::SourcemapProvider,
|
|
Catalog,
|
|
},
|
|
types::{RawErrProps, Stacktrace},
|
|
};
|
|
use httpmock::MockServer;
|
|
use tokio::sync::Mutex;
|
|
|
|
const CHUNK_PATH: &str = "/static/chunk-PGUQKT6S.js";
|
|
const MINIFIED: &[u8] = include_bytes!("../tests/static/chunk-PGUQKT6S.js");
|
|
const MAP: &[u8] = include_bytes!("../tests/static/chunk-PGUQKT6S.js.map");
|
|
const EXAMPLE_EXCEPTION: &str = include_str!("../tests/static/raw_ch_exception_list.json");
|
|
|
|
#[tokio::test]
|
|
async fn end_to_end_resolver_test() {
|
|
let server = MockServer::start();
|
|
|
|
let source_mock = server.mock(|when, then| {
|
|
when.method("GET").path(CHUNK_PATH);
|
|
then.status(200).body(MINIFIED);
|
|
});
|
|
|
|
let map_mock = server.mock(|when, then| {
|
|
// Our minified example source uses a relative URL, formatted like this
|
|
when.method("GET").path(format!("{}.map", CHUNK_PATH));
|
|
then.status(200).body(MAP);
|
|
});
|
|
|
|
let exception: ClickHouseEvent = serde_json::from_str(EXAMPLE_EXCEPTION).unwrap();
|
|
let mut props: RawErrProps = serde_json::from_str(&exception.properties.unwrap()).unwrap();
|
|
let Stacktrace::Raw {
|
|
frames: mut test_stack,
|
|
} = props.exception_list.swap_remove(0).stack.unwrap()
|
|
else {
|
|
panic!("Expected a Raw stacktrace")
|
|
};
|
|
|
|
// We're going to pretend out stack consists exclusively of JS frames whose source
|
|
// we have locally
|
|
test_stack.retain(|s| {
|
|
let RawFrame::JavaScript(s) = s;
|
|
s.source_url.as_ref().unwrap().contains(CHUNK_PATH)
|
|
});
|
|
|
|
for frame in test_stack.iter_mut() {
|
|
let RawFrame::JavaScript(frame) = frame;
|
|
// Our test data contains our /actual/ source urls - we need to swap that to localhost
|
|
// When I first wrote this test, I forgot to do this, and it took me a while to figure out
|
|
// why the test was passing before I'd even set up the mockserver - which was pretty cool, tbh
|
|
frame.source_url = Some(server.url(CHUNK_PATH).to_string());
|
|
}
|
|
|
|
let mut config = Config::init_with_defaults().unwrap();
|
|
config.allow_internal_ips = true; // We're hitting localhost for the tests
|
|
|
|
let sourcemap = SourcemapProvider::new(&config);
|
|
let cache = Arc::new(Mutex::new(SymbolSetCache::new(
|
|
config.symbol_store_cache_max_bytes,
|
|
)));
|
|
|
|
let catalog = Catalog::new(Caching::new(sourcemap, cache));
|
|
|
|
let mut resolved_frames = Vec::new();
|
|
for frame in test_stack {
|
|
resolved_frames.push(frame.resolve(exception.team_id, &catalog).await.unwrap());
|
|
}
|
|
|
|
println!("{:?}", resolved_frames);
|
|
|
|
// The use of the caching layer is tested here - we should only have hit the server once
|
|
source_mock.assert_hits(1);
|
|
map_mock.assert_hits(1);
|
|
}
|