2
0
Fork 1
mirror of https://github.com/async-rs/async-std.git synced 2025-02-28 15:19:41 +00:00

Updated example to be consistent; added timing measurements to throttle

This commit is contained in:
Wouter Geraedts 2019-11-12 15:38:02 +01:00
parent 6990c1403f
commit 4ab7b213de
2 changed files with 19 additions and 6 deletions

View file

@ -11,7 +11,7 @@ fn main() {
use std::time::Duration;
// emit value every 1 second
let s = stream::interval(Duration::from_nanos(1000000)).enumerate();
let s = stream::interval(Duration::from_secs(1)).enumerate();
// throttle for 2 seconds
let s = s.throttle(Duration::from_secs(2));

View file

@ -325,19 +325,32 @@ extension_trait! {
#
use async_std::prelude::*;
use async_std::stream;
use std::time::Duration;
use std::time::{Duration, Instant};
// emit value every 1 second
let s = stream::interval(Duration::from_millis(5)).enumerate().take(3);
// emit value every 5 milliseconds
let s = stream::interval(Duration::from_millis(5))
.enumerate()
.take(3);
// throttle for 2 seconds
// throttle for 10 milliseconds
let mut s = s.throttle(Duration::from_millis(10));
let start = Instant::now();
assert_eq!(s.next().await, Some((0, ())));
let duration_ms = start.elapsed().as_millis();
assert!(duration_ms >= 5 && duration_ms < 15);
assert_eq!(s.next().await, Some((1, ())));
let duration_ms = start.elapsed().as_millis();
assert!(duration_ms >= 15 && duration_ms < 25);
assert_eq!(s.next().await, Some((2, ())));
let duration_ms = start.elapsed().as_millis();
assert!(duration_ms >= 25 && duration_ms < 35);
assert_eq!(s.next().await, None);
// with a pause of 2 seconds between each print
let duration_ms = start.elapsed().as_millis();
assert!(duration_ms >= 35 && duration_ms < 45);
#
# }) }
```