1
0
mirror of https://github.com/fafhrd91/actix-web synced 2025-01-19 14:14:41 +01:00
actix-web/actix-http/examples/streaming-error.rs

42 lines
1.2 KiB
Rust
Raw Normal View History

2021-06-17 17:57:58 +01:00
//! Example showing response body (chunked) stream erroring.
//!
//! Test using `nc` or `curl`.
//! ```sh
//! $ curl -vN 127.0.0.1:8080
//! $ echo 'GET / HTTP/1.1\n\n' | nc 127.0.0.1 8080
//! ```
use std::{convert::Infallible, io, time::Duration};
use actix_http::{body::BodyStream, HttpService, Response};
use actix_server::Server;
use async_stream::stream;
use bytes::Bytes;
2022-03-10 03:12:29 +00:00
use tracing::info;
2021-06-17 17:57:58 +01:00
#[actix_rt::main]
async fn main() -> io::Result<()> {
env_logger::init_from_env(env_logger::Env::new().default_filter_or("info"));
Server::build()
.bind("streaming-error", ("127.0.0.1", 8080), || {
HttpService::build()
.finish(|req| async move {
2024-08-18 14:33:28 +01:00
info!("{req:?}");
2021-06-17 17:57:58 +01:00
let res = Response::ok();
Ok::<_, Infallible>(res.set_body(BodyStream::new(stream! {
yield Ok(Bytes::from("123"));
yield Ok(Bytes::from("456"));
2024-08-18 14:33:28 +01:00
actix_rt::time::sleep(Duration::from_secs(1)).await;
2021-06-17 17:57:58 +01:00
2024-08-18 14:33:28 +01:00
yield Err(io::Error::new(io::ErrorKind::Other, "abc"));
2021-06-17 17:57:58 +01:00
})))
})
.tcp()
})?
.run()
.await
}