use std::{fs, io::Read as _};
use cucumber::{World as _, given, then, when, writer};
use futures::FutureExt as _;
use regex::RegexBuilder;
use tempfile::NamedTempFile;
use tracing_subscriber::{
Layer as _,
filter::LevelFilter,
fmt::format::{DefaultFields, Format},
layer::SubscriberExt as _,
};
#[given(regex = r"(\d+) secs?")]
#[when(regex = r"(\d+) secs?")]
#[then(regex = r"(\d+) secs?")]
fn step(world: &mut World) {
world.0 += 1;
assert!(world.0 < 4, "Too much!");
tracing::info!("step");
}
#[tokio::test]
async fn output() {
let mut file = NamedTempFile::new().unwrap();
drop(
World::cucumber()
.before(|_, _, _, _| {
async { tracing::info!("before") }.boxed_local()
})
.after(|_, _, _, _, _| {
async { tracing::info!("after") }.boxed_local()
})
.with_writer(writer::JUnit::new(file.reopen().unwrap(), 1))
.fail_on_skipped()
.with_default_cli()
.configure_and_init_tracing(
DefaultFields::new(),
Format::default().with_ansi(false).without_time(),
|layer| {
tracing_subscriber::registry()
.with(LevelFilter::INFO.and_then(layer))
},
)
.run("tests/features/wait")
.await,
);
let mut buffer = String::new();
file.read_to_string(&mut buffer).unwrap();
let non_deterministic = RegexBuilder::new(
"time(stamp)?=\"[^\"]+\"\
|: [^\\.\\s]*\\.(feature|rs)(:\\d+:\\d+)?\
|^\\s+\
|\\s?\\n",
)
.multi_line(true)
.build()
.unwrap();
assert_eq!(
non_deterministic.replace_all(&buffer, ""),
non_deterministic.replace_all(
&fs::read_to_string("tests/junit/correct.xml").unwrap(),
"",
),
);
}
#[derive(Clone, Copy, Debug, Default, cucumber::World)]
struct World(usize);