mirror of https://github.com/fafhrd91/actix-net
fix test
This commit is contained in:
parent
b6c477f26c
commit
88497fd9f3
|
@ -7,6 +7,7 @@ use std::{
|
||||||
};
|
};
|
||||||
|
|
||||||
use actix_rt::{self as rt, net::TcpStream, time::sleep, System};
|
use actix_rt::{self as rt, net::TcpStream, time::sleep, System};
|
||||||
|
use futures_core::future::BoxFuture;
|
||||||
use log::{error, info};
|
use log::{error, info};
|
||||||
use tokio::sync::mpsc::{unbounded_channel, UnboundedReceiver};
|
use tokio::sync::mpsc::{unbounded_channel, UnboundedReceiver};
|
||||||
use tokio::sync::oneshot;
|
use tokio::sync::oneshot;
|
||||||
|
@ -24,7 +25,6 @@ use crate::worker::{
|
||||||
WorkerHandleServer,
|
WorkerHandleServer,
|
||||||
};
|
};
|
||||||
use crate::{join_all, Token};
|
use crate::{join_all, Token};
|
||||||
use futures_core::future::LocalBoxFuture;
|
|
||||||
|
|
||||||
/// Server builder
|
/// Server builder
|
||||||
pub struct ServerBuilder {
|
pub struct ServerBuilder {
|
||||||
|
@ -39,7 +39,7 @@ pub struct ServerBuilder {
|
||||||
no_signals: bool,
|
no_signals: bool,
|
||||||
cmd: UnboundedReceiver<ServerCommand>,
|
cmd: UnboundedReceiver<ServerCommand>,
|
||||||
server: Server,
|
server: Server,
|
||||||
on_stop: Box<dyn Fn() -> LocalBoxFuture<'static, ()>>,
|
on_stop: Box<dyn Fn() -> BoxFuture<'static, ()>>,
|
||||||
notify: Vec<oneshot::Sender<()>>,
|
notify: Vec<oneshot::Sender<()>>,
|
||||||
worker_config: ServerWorkerConfig,
|
worker_config: ServerWorkerConfig,
|
||||||
}
|
}
|
||||||
|
@ -329,7 +329,7 @@ impl ServerBuilder {
|
||||||
pub fn on_stop<F, Fut>(mut self, func: F) -> Self
|
pub fn on_stop<F, Fut>(mut self, func: F) -> Self
|
||||||
where
|
where
|
||||||
F: Fn() -> Fut + 'static,
|
F: Fn() -> Fut + 'static,
|
||||||
Fut: Future<Output = ()> + 'static,
|
Fut: Future<Output = ()> + Send + 'static,
|
||||||
{
|
{
|
||||||
self.on_stop = Box::new(move || {
|
self.on_stop = Box::new(move || {
|
||||||
let fut = func();
|
let fut = func();
|
||||||
|
@ -338,8 +338,12 @@ impl ServerBuilder {
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
fn start_worker(&self, idx: usize, waker: WakerQueue) -> WorkerHandle {
|
fn start_worker(
|
||||||
let avail = WorkerAvailability::new(waker);
|
&self,
|
||||||
|
idx: usize,
|
||||||
|
waker: WakerQueue,
|
||||||
|
) -> (WorkerHandleAccept, WorkerHandleServer) {
|
||||||
|
let avail = WorkerAvailability::new(idx, waker);
|
||||||
let services = self.services.iter().map(|v| v.clone_factory()).collect();
|
let services = self.services.iter().map(|v| v.clone_factory()).collect();
|
||||||
|
|
||||||
ServerWorker::start(idx, services, avail, self.worker_config)
|
ServerWorker::start(idx, services, avail, self.worker_config)
|
||||||
|
@ -401,7 +405,7 @@ impl ServerBuilder {
|
||||||
|
|
||||||
// take the on_stop future.
|
// take the on_stop future.
|
||||||
let mut on_stop =
|
let mut on_stop =
|
||||||
Box::new(|| Box::pin(async {}) as LocalBoxFuture<'static, ()>) as _;
|
Box::new(|| Box::pin(async {}) as BoxFuture<'static, ()>) as _;
|
||||||
std::mem::swap(&mut self.on_stop, &mut on_stop);
|
std::mem::swap(&mut self.on_stop, &mut on_stop);
|
||||||
|
|
||||||
// stop workers
|
// stop workers
|
||||||
|
@ -412,8 +416,8 @@ impl ServerBuilder {
|
||||||
.collect();
|
.collect();
|
||||||
|
|
||||||
rt::spawn(async move {
|
rt::spawn(async move {
|
||||||
on_stop().await;
|
on_stop().await;
|
||||||
|
|
||||||
if graceful {
|
if graceful {
|
||||||
let _ = join_all(stop).await;
|
let _ = join_all(stop).await;
|
||||||
}
|
}
|
||||||
|
|
|
@ -577,3 +577,45 @@ async fn worker_restart() {
|
||||||
let _ = server.stop(false);
|
let _ = server.stop(false);
|
||||||
let _ = h.join().unwrap();
|
let _ = h.join().unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn on_stop() {
|
||||||
|
let bool = std::sync::Arc::new(AtomicBool::new(false));
|
||||||
|
|
||||||
|
let addr = unused_addr();
|
||||||
|
let (tx, rx) = mpsc::channel();
|
||||||
|
|
||||||
|
let bool_clone = bool.clone();
|
||||||
|
let h = thread::spawn(move || {
|
||||||
|
let sys = actix_rt::System::new();
|
||||||
|
let lst = net::TcpListener::bind(addr).unwrap();
|
||||||
|
sys.block_on(async {
|
||||||
|
let server = Server::build()
|
||||||
|
.disable_signals()
|
||||||
|
.on_stop(move || {
|
||||||
|
bool.store(true, Ordering::SeqCst);
|
||||||
|
async {}
|
||||||
|
})
|
||||||
|
.listen("test", lst, move || {
|
||||||
|
fn_service(|_| async { Ok::<_, ()>(()) })
|
||||||
|
})
|
||||||
|
.unwrap()
|
||||||
|
.run();
|
||||||
|
let _ = tx.send(server.clone());
|
||||||
|
|
||||||
|
server.await
|
||||||
|
})
|
||||||
|
});
|
||||||
|
let sys = rx.recv().unwrap();
|
||||||
|
|
||||||
|
thread::sleep(Duration::from_millis(500));
|
||||||
|
|
||||||
|
assert!(!bool_clone.load(Ordering::SeqCst));
|
||||||
|
|
||||||
|
assert!(net::TcpStream::connect(addr).is_ok());
|
||||||
|
|
||||||
|
let _ = sys.stop(true);
|
||||||
|
let _ = h.join();
|
||||||
|
|
||||||
|
assert!(bool_clone.load(Ordering::SeqCst));
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue