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 = "call_chain_recursive"; 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 = 10; let mut j = 0; for i in 0..24 { 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 => "call_chain_recursive::main", _ => "call_chain_recursive::chain", } ); if i == 0 { assert_eq!(arguments.len(), 0); } else { assert_eq!(arguments.len(), 1); assert_eq!(arguments[0].1, RValue::Prim(PValue::usize(cc))); if cc > 0 { cc -= 1; } } } Event::FunctionReturn { function_name, return_value, .. } => { assert_eq!( &function_name, match i { 23 => "call_chain_recursive::main", _ => "call_chain_recursive::chain", } ); if i == 23 { assert_eq!(return_value, RValue::Unit); } else { assert_eq!(return_value, RValue::Prim(PValue::usize(cc))); if j == 10 { assert_eq!(cc, 55); } j += 1; cc += j; } } } } Ok(()) }