test/formatters/
mod.rs

1use std::io;
2use std::io::prelude::Write;
3
4use crate::console::{ConsoleTestDiscoveryState, ConsoleTestState};
5use crate::test_result::TestResult;
6use crate::time;
7use crate::types::{TestDesc, TestName};
8
9mod json;
10mod junit;
11mod pretty;
12mod terse;
13
14pub(crate) use self::json::JsonFormatter;
15pub(crate) use self::junit::JunitFormatter;
16pub(crate) use self::pretty::PrettyFormatter;
17pub(crate) use self::terse::TerseFormatter;
18
19pub(crate) trait OutputFormatter {
20    fn write_discovery_start(&mut self) -> io::Result<()>;
21    fn write_test_discovered(&mut self, desc: &TestDesc, test_type: &str) -> io::Result<()>;
22    fn write_discovery_finish(&mut self, state: &ConsoleTestDiscoveryState) -> io::Result<()>;
23
24    fn write_run_start(&mut self, test_count: usize, shuffle_seed: Option<u64>) -> io::Result<()>;
25    fn write_test_start(&mut self, desc: &TestDesc) -> io::Result<()>;
26    fn write_timeout(&mut self, desc: &TestDesc) -> io::Result<()>;
27    fn write_result(
28        &mut self,
29        desc: &TestDesc,
30        result: &TestResult,
31        exec_time: Option<&time::TestExecTime>,
32        stdout: &[u8],
33        state: &ConsoleTestState,
34    ) -> io::Result<()>;
35    fn write_run_finish(&mut self, state: &ConsoleTestState) -> io::Result<bool>;
36}
37
38pub(crate) fn write_stderr_delimiter(test_output: &mut Vec<u8>, test_name: &TestName) {
39    match test_output.last() {
40        Some(b'\n') => (),
41        Some(_) => test_output.push(b'\n'),
42        None => (),
43    }
44    writeln!(test_output, "---- {test_name} stderr ----").unwrap();
45}