#![allow(
clippy::todo,
clippy::unimplemented,
clippy::panic,
clippy::unwrap_used,
clippy::expect_used,
clippy::missing_errors_doc,
clippy::missing_panics_doc,
clippy::doc_markdown,
clippy::needless_pass_by_value,
clippy::too_many_arguments,
clippy::unused_async,
clippy::diverging_sub_expression,
clippy::no_effect_underscore_binding,
clippy::let_unit_value,
clippy::used_underscore_binding,
clippy::let_underscore_untyped,
clippy::struct_field_names,
clippy::manual_let_else,
clippy::map_unwrap_or,
clippy::redundant_pub_crate,
dead_code,
unreachable_code,
unused_assignments,
unused_mut,
unused_imports,
unused_variables
)]
use arcp::error::ARCPError;
use arcp::transport::MemoryTransport;
use arcp::{ARCPClient, Envelope};
use serde_json::json;
type Client = ARCPClient<MemoryTransport>;
const CHATTY_COUNT: u32 = 2_000;
async fn submit_chatty(_client: &Client) -> Result<String, ARCPError> {
todo!()
}
async fn ack(_client: &Client, _last_seq: u64) -> Result<(), ARCPError> {
todo!()
}
async fn drain(_client: &Client, _job_id: &str) -> Result<(u32, bool), ARCPError> {
let mut metrics: u32 = 0;
let mut back_pressure = false;
Ok((metrics, back_pressure))
}
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let client: Client = todo!();
let job_id = submit_chatty(&client).await?;
println!("accepted: job_id={job_id}");
let (metrics, bp) = drain(&client, &job_id).await?;
println!("metrics observed={metrics} back_pressure={bp}");
if !bp {
return Err("expected a backpressure event but none arrived".into());
}
println!("back-pressure observed and acknowledged — done");
Ok(())
}