All checks were successful
continuous-integration/drone/push Build is passing
Signed-off-by: kjuulh <contact@kjuulh.io>
41 lines
1020 B
Rust
41 lines
1020 B
Rust
use async_trait::async_trait;
|
|
use rand::Rng;
|
|
use tokio_util::sync::CancellationToken;
|
|
use tracing::Level;
|
|
|
|
struct WaitServer {}
|
|
#[async_trait]
|
|
impl notmad::Component for WaitServer {
|
|
fn name(&self) -> Option<String> {
|
|
Some("WaitServer".into())
|
|
}
|
|
|
|
async fn run(&self, cancellation: CancellationToken) -> Result<(), notmad::MadError> {
|
|
let millis_wait = rand::thread_rng().gen_range(500..3000);
|
|
|
|
tracing::debug!("waiting: {}ms", millis_wait);
|
|
|
|
// Simulates a server running for some time. Is normally supposed to be futures blocking indefinitely
|
|
tokio::time::sleep(std::time::Duration::from_millis(millis_wait)).await;
|
|
|
|
Ok(())
|
|
}
|
|
}
|
|
|
|
#[tokio::main]
|
|
async fn main() -> anyhow::Result<()> {
|
|
tracing_subscriber::fmt()
|
|
.with_max_level(Level::TRACE)
|
|
.init();
|
|
|
|
notmad::Mad::builder()
|
|
.add(WaitServer {})
|
|
.add(WaitServer {})
|
|
.add(WaitServer {})
|
|
.add(WaitServer {})
|
|
.run()
|
|
.await?;
|
|
|
|
Ok(())
|
|
}
|