event-listener/tests/notify.rs
John Nunley eb54e95aca m: Fix new nightly Clippy warnings
- Suppress warning from the cfg(loom) directive by having it emit
  "rustc-check-cfg" in build.rs
- Remove usage of legacy "std::usize" module.
- Ignore "clippy::multiple_bound_locations". We use multiple bounds as a
  workaround for an issue in pin-project-lite where only one bound can be
  assigned per location. The phrasing of pin-project-lite's README implies that
  this issue is WONTFIX. To quote:

> This library does not tackle as expansive of a range of use cases as
> pin-project does. If your use case is not already covered, please use
> pin-project.

Signed-off-by: John Nunley <dev@notgull.net>
2024-05-19 11:18:16 -07:00

192 lines
4.3 KiB
Rust

use std::future::Future;
use std::pin::Pin;
use std::sync::{Arc, Mutex};
use std::task::Context;
use event_listener::{Event, EventListener};
use waker_fn::waker_fn;
#[cfg(target_family = "wasm")]
use wasm_bindgen_test::wasm_bindgen_test as test;
fn is_notified(listener: &mut EventListener) -> bool {
let waker = waker_fn(|| ());
Pin::new(listener)
.poll(&mut Context::from_waker(&waker))
.is_ready()
}
#[test]
fn notify() {
let event = Event::new();
let mut l1 = event.listen();
let mut l2 = event.listen();
let mut l3 = event.listen();
assert!(!is_notified(&mut l1));
assert!(!is_notified(&mut l2));
assert!(!is_notified(&mut l3));
assert_eq!(event.notify(2), 2);
assert_eq!(event.notify(1), 0);
assert!(is_notified(&mut l1));
assert!(is_notified(&mut l2));
assert!(!is_notified(&mut l3));
}
#[test]
fn notify_additional() {
let event = Event::new();
let mut l1 = event.listen();
let mut l2 = event.listen();
let mut l3 = event.listen();
assert_eq!(event.notify_additional(1), 1);
assert_eq!(event.notify(1), 0);
assert_eq!(event.notify_additional(1), 1);
assert!(is_notified(&mut l1));
assert!(is_notified(&mut l2));
assert!(!is_notified(&mut l3));
}
#[test]
fn notify_one() {
let event = Event::new();
let mut l1 = event.listen();
let mut l2 = event.listen();
assert!(!is_notified(&mut l1));
assert!(!is_notified(&mut l2));
assert_eq!(event.notify(1), 1);
assert!(is_notified(&mut l1));
assert!(!is_notified(&mut l2));
assert_eq!(event.notify(1), 1);
assert!(is_notified(&mut l2));
}
#[test]
fn notify_all() {
let event = Event::new();
let mut l1 = event.listen();
let mut l2 = event.listen();
assert!(!is_notified(&mut l1));
assert!(!is_notified(&mut l2));
assert_eq!(event.notify(usize::MAX), 2);
assert!(is_notified(&mut l1));
assert!(is_notified(&mut l2));
}
#[test]
fn drop_notified() {
let event = Event::new();
let l1 = event.listen();
let mut l2 = event.listen();
let mut l3 = event.listen();
assert_eq!(event.notify(1), 1);
drop(l1);
assert!(is_notified(&mut l2));
assert!(!is_notified(&mut l3));
}
#[test]
fn drop_notified2() {
let event = Event::new();
let l1 = event.listen();
let mut l2 = event.listen();
let mut l3 = event.listen();
assert_eq!(event.notify(2), 2);
drop(l1);
assert!(is_notified(&mut l2));
assert!(!is_notified(&mut l3));
}
#[test]
fn drop_notified_additional() {
let event = Event::new();
let l1 = event.listen();
let mut l2 = event.listen();
let mut l3 = event.listen();
let mut l4 = event.listen();
assert_eq!(event.notify_additional(1), 1);
assert_eq!(event.notify(2), 1);
drop(l1);
assert!(is_notified(&mut l2));
assert!(is_notified(&mut l3));
assert!(!is_notified(&mut l4));
}
#[test]
fn drop_non_notified() {
let event = Event::new();
let mut l1 = event.listen();
let mut l2 = event.listen();
let l3 = event.listen();
assert_eq!(event.notify(1), 1);
drop(l3);
assert!(is_notified(&mut l1));
assert!(!is_notified(&mut l2));
}
#[test]
fn notify_all_fair() {
let event = Event::new();
let v = Arc::new(Mutex::new(vec![]));
let mut l1 = event.listen();
let mut l2 = event.listen();
let mut l3 = event.listen();
let waker1 = {
let v = v.clone();
waker_fn(move || v.lock().unwrap().push(1))
};
let waker2 = {
let v = v.clone();
waker_fn(move || v.lock().unwrap().push(2))
};
let waker3 = {
let v = v.clone();
waker_fn(move || v.lock().unwrap().push(3))
};
assert!(Pin::new(&mut l1)
.poll(&mut Context::from_waker(&waker1))
.is_pending());
assert!(Pin::new(&mut l2)
.poll(&mut Context::from_waker(&waker2))
.is_pending());
assert!(Pin::new(&mut l3)
.poll(&mut Context::from_waker(&waker3))
.is_pending());
assert_eq!(event.notify(usize::MAX), 3);
assert_eq!(&*v.lock().unwrap(), &[1, 2, 3]);
assert!(Pin::new(&mut l1)
.poll(&mut Context::from_waker(&waker1))
.is_ready());
assert!(Pin::new(&mut l2)
.poll(&mut Context::from_waker(&waker2))
.is_ready());
assert!(Pin::new(&mut l3)
.poll(&mut Context::from_waker(&waker3))
.is_ready());
}