#![warn(missing_docs)]
#![allow(clippy::new_ret_no_self)]
#[macro_use]
extern crate trackable;
pub use crate::error::{Error, ErrorKind};
pub use crate::tracer::Tracer;
pub mod carrier;
pub mod convert;
pub mod log;
pub mod sampler;
pub mod span;
pub mod tag;
mod error;
mod tracer;
pub type Result<T> = std::result::Result<T, Error>;
#[cfg(test)]
mod tests {
use super::*;
use crate::sampler::AllSampler;
use crate::tag::{StdTag, Tag};
use std::thread;
use std::time::Duration;
#[test]
fn it_works() {
let (span_tx, span_rx) = crossbeam_channel::bounded(10);
let tracer = Tracer::with_sender(AllSampler, span_tx);
{
let span = tracer.span("it_works").start_with_state(());
let mut child = span.child("child", |options| options.start_with_state(()));
child.set_tags(|| StdTag::peer_addr("127.0.0.1:80".parse().unwrap()));
}
let span = span_rx.try_recv().unwrap();
assert_eq!(span.operation_name(), "child");
let span = span_rx.try_recv().unwrap();
assert_eq!(span.operation_name(), "it_works");
}
#[test]
fn example_code_works() {
let (span_tx, span_rx) = crossbeam_channel::bounded(10);
let tracer = Tracer::with_sender(AllSampler, span_tx);
{
let parent_span = tracer.span("parent").start_with_state(());
thread::sleep(Duration::from_millis(10));
{
let mut child_span = tracer
.span("child_span")
.child_of(&parent_span)
.tag(Tag::new("key", "value"))
.start_with_state(());
child_span.log(|log| {
log.error().message("a log message");
});
} }
let mut count = 0;
while let Ok(span) = span_rx.try_recv() {
println!("# SPAN: {:?}", span);
count += 1;
}
assert_eq!(count, 2);
}
#[test]
fn nonblocking_on_full_queue() {
let (span_tx, span_rx) = crossbeam_channel::bounded(2);
let tracer = Tracer::with_sender(AllSampler, span_tx);
{
let span = tracer.span("first").start_with_state(());
let mut child = span.child("second", |options| options.start_with_state(()));
child.set_tags(|| StdTag::peer_addr("127.0.0.1:80".parse().unwrap()));
let _ = tracer.span("third").start_with_state(());
}
assert!(span_rx.is_full());
assert_eq!(span_rx.len(), 2);
let span = span_rx.try_recv().unwrap();
assert_eq!(span.operation_name(), "third");
let span = span_rx.try_recv().unwrap();
assert_eq!(span.operation_name(), "second");
assert!(span_rx.is_empty());
}
}