mod util; use util::*; use anyhow::Result; use firedbg_rust_debugger::{Bytes, Debugger, Event, EventStream, PValue, RValue}; use pretty_assertions::assert_eq; use sea_streamer::{Buffer, Consumer, Message, Producer}; #[tokio::test] async fn main() -> Result<()> { let testcase = "factorial"; let (producer, consumer) = setup(testcase).await?; let debugger_params = debugger_params_from_file(testcase); Debugger::run(debugger_params, producer.clone()); producer.end().await?; let mut cc = 1; let mut j = 0; for i in 0..14 { let payload = consumer.next().await?.message().into_bytes(); let event = EventStream::read_from(Bytes::from(payload)); println!("#{i} {:?}", event); match event { Event::Breakpoint { .. } => unreachable!(), Event::FunctionCall { function_name, arguments, .. } => { assert_eq!( &function_name, match i { 0 => "factorial::main", _ => "factorial::factorial", } ); if i == 0 { assert_eq!(arguments.len(), 0); } else { assert_eq!(arguments.len(), 1); } } Event::FunctionReturn { function_name, return_value, .. } => { assert_eq!( &function_name, match i { 13 => "factorial::main", _ => "factorial::factorial", } ); if i == 13 { assert_eq!(return_value, RValue::Unit); } else { assert_eq!(return_value, RValue::Prim(PValue::i32(cc))); j += 1; cc *= j; } } } } Ok(()) }