1
0
mirror of https://github.com/fafhrd91/actix-net synced 2025-06-26 15:07:43 +02:00

update actix-codec and actix-utils to tokio 1.0 (#237)

This commit is contained in:
fakeshadow
2020-12-28 11:16:37 +08:00
committed by GitHub
parent f48e3f4cb0
commit 2ee8f45f5d
9 changed files with 53 additions and 46 deletions

View File

@ -1,6 +1,7 @@
# Changes
## Unreleased - 2020-xx-xx
* Update `bytes` dependency to `1`.
* Use `pin-project-lite` to replace `pin-project`. [#229]
* Remove `condition`,`either`,`inflight`,`keepalive`,`oneshot`,`order`,`stream` and `time` mods. [#229]

View File

@ -17,8 +17,8 @@ path = "src/lib.rs"
[dependencies]
actix-codec = "0.3.0"
actix-rt = "1.1.1"
actix-service = "1.0.6"
actix-rt = "2.0.0-beta.1"
actix-service = "2.0.0-beta.1"
futures-core = { version = "0.3.7", default-features = false }
futures-sink = { version = "0.3.7", default-features = false }

View File

@ -9,7 +9,7 @@ use core::pin::Pin;
use core::task::{Context, Poll};
use core::{fmt, time};
use actix_rt::time::{delay_for, Delay};
use actix_rt::time::{sleep, Sleep};
use actix_service::{IntoService, Service, Transform};
use pin_project_lite::pin_project;
@ -85,8 +85,8 @@ where
{
type Response = S::Response;
type Error = TimeoutError<S::Error>;
type InitError = E;
type Transform = TimeoutService<S, Req>;
type InitError = E;
type Future = TimeoutFuture<Self::Transform, Self::InitError>;
fn new_transform(&self, service: S) -> Self::Future {
@ -157,7 +157,7 @@ where
fn call(&mut self, request: Req) -> Self::Future {
TimeoutServiceResponse {
fut: self.service.call(request),
sleep: delay_for(self.timeout),
sleep: sleep(self.timeout),
}
}
}
@ -171,7 +171,8 @@ pin_project! {
{
#[pin]
fut: S::Future,
sleep: Delay,
#[pin]
sleep: Sleep,
}
}
@ -193,20 +194,18 @@ where
}
// Now check the sleep
Pin::new(this.sleep)
.poll(cx)
.map(|_| Err(TimeoutError::Timeout))
this.sleep.poll(cx).map(|_| Err(TimeoutError::Timeout))
}
}
#[cfg(test)]
mod tests {
use std::task::Poll;
use std::time::Duration;
use core::task::Poll;
use core::time::Duration;
use super::*;
use actix_service::{apply, fn_factory, Service, ServiceFactory};
use futures_util::future::{ok, FutureExt, LocalBoxFuture};
use futures_core::future::LocalBoxFuture;
struct SleepService(Duration);
@ -218,9 +217,11 @@ mod tests {
actix_service::always_ready!();
fn call(&mut self, _: ()) -> Self::Future {
actix_rt::time::delay_for(self.0)
.then(|_| ok::<_, ()>(()))
.boxed_local()
let sleep = actix_rt::time::sleep(self.0);
Box::pin(async move {
sleep.await;
Ok(())
})
}
}
@ -249,7 +250,7 @@ mod tests {
let timeout = apply(
Timeout::new(resolution),
fn_factory(|| ok::<_, ()>(SleepService(wait_time))),
fn_factory(|| async { Ok::<_, ()>(SleepService(wait_time)) }),
);
let mut srv = timeout.new_service(&()).await.unwrap();