gracefully handle lack of tokio runtime
This commit is contained in:
parent
7283ef881f
commit
386fa371d7
1 changed files with 4 additions and 1 deletions
|
@ -28,7 +28,10 @@ pub trait AsyncHook: Sync + Send + 'static + Sized {
|
|||
// so it should only be reached in case of total CPU overload.
|
||||
// However, a bounded channel is much more efficient so it's nice to use here
|
||||
let (tx, rx) = mpsc::channel(128);
|
||||
tokio::spawn(run(self, rx));
|
||||
// only spawn worker if we are inside runtime to avoid having to spawn a runtime for unrelated unit tests
|
||||
if tokio::runtime::Handle::try_current().is_ok() {
|
||||
tokio::spawn(run(self, rx));
|
||||
}
|
||||
tx
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue