use candid::Principal;
use super::{Pic, startup};
impl Pic {
pub fn dump_canister_debug(&self, canister_id: Principal, context: &str) {
eprintln!("{context}: debug for canister {canister_id}");
match self.canister_status(canister_id, None) {
Ok(status) => eprintln!("canister_status: {status:?}"),
Err(err) => {
let message = err.to_string();
if startup::is_dead_instance_transport_error(&message) {
eprintln!("canister_status unavailable: PocketIC instance no longer reachable");
return;
}
eprintln!("canister_status failed: {err:?}");
}
}
match self.fetch_canister_logs(canister_id, Principal::anonymous()) {
Ok(records) => {
if records.is_empty() {
eprintln!("canister logs: <empty>");
} else {
for record in records {
eprintln!("canister log: {record:?}");
}
}
}
Err(err) => {
let message = err.to_string();
if startup::is_dead_instance_transport_error(&message) {
eprintln!(
"fetch_canister_logs unavailable: PocketIC instance no longer reachable"
);
return;
}
eprintln!("fetch_canister_logs failed: {err:?}");
}
}
}
}