2 releases
Uses old Rust 2015
0.1.1 | Aug 17, 2018 |
---|---|
0.1.0 | Mar 25, 2017 |
#213 in Profiling
Used in 2 crates
18KB
189 lines
queuecheck
A thread-safe queue testing and benchmarking library.
Supported on the stable, beta, and nightly Rust channels.
Released under the Apache License 2.0.
Examples
Testing
The below tests the unbounded MPMC queue from the standard library by producing 100,000 items using two producer threads which are then consumed by one consumer thread.
use std::sync::mpsc::{self, Receiver, Sender};
let (producer, consumer) = mpsc::channel();
queuecheck_test!(
// enqueue/dequeue operation pairs
100_000,
// producer threads
vec![producer.clone(), producer],
// consumer threads
vec![consumer],
// produce operation
|p: &Sender<String>, i: String| p.send(i).unwrap(),
// consume operation
|c: &Receiver<String>| c.try_recv().ok()
);
Benchmarking
Latency
The below benchmarks the latency of the unbounded MPMC queue from the standard library by producing 100,000 items using two producer threads which are then consumed by one consumer thread.
use std::sync::mpsc::{self, Receiver, Sender};
let (producer, consumer) = mpsc::channel();
let latency = queuecheck_bench_latency!(
// warmup and measurement enqueue/dequeue operation pairs
(1_000, 100_000),
// producer threads
vec![producer.clone(), producer],
// consumer threads
vec![consumer],
// produce operation
|p: &Sender<i32>, i: i32| p.send(i).unwrap(),
// consume operation
|c: &Receiver<i32>| c.try_recv().ok()
);
latency.report("mpmc", &[50.0, 70.0, 90.0, 95.0, 99.09]);
Throughput
The below benchmarks the throughput of the unbounded MPMC queue from the standard library by producing 100,000 items using two producer threads which are then consumed by one consumer thread.
use std::sync::mpsc::{self, Receiver, Sender};
let (producer, consumer) = mpsc::channel();
let ops = queuecheck_bench_throughput!(
// warmup and measurement enqueue/dequeue operation pairs
(1_000, 100_000),
// producer threads
vec![producer.clone(), producer],
// consumer threads
vec![consumer],
// produce operation
|p: &Sender<i32>, i: i32| p.send(i).unwrap(),
// consume operation
|c: &Receiver<i32>| c.try_recv().ok()
);
println!("{:.3} operation/second", ops);