2019-03-02 12:40:15 -06:00
|
|
|
//! Support code for rustc's built in unit-test and micro-benchmarking
|
|
|
|
//! framework.
|
|
|
|
//!
|
|
|
|
//! Almost all user code will only be interested in `Bencher` and
|
|
|
|
//! `black_box`. All other interactions (such as writing tests and
|
|
|
|
//! benchmarks themselves) should be done via the `#[test]` and
|
|
|
|
//! `#[bench]` attributes.
|
|
|
|
//!
|
|
|
|
//! See the [Testing Chapter](../book/ch11-00-testing.html) of the book for more details.
|
|
|
|
|
|
|
|
#![crate_name = "test"]
|
|
|
|
#![unstable(feature = "test", issue = "27812")]
|
|
|
|
#![doc(html_root_url = "https://doc.rust-lang.org/nightly/",
|
|
|
|
test(attr(deny(warnings))))]
|
2019-03-04 11:04:08 -06:00
|
|
|
#![feature(asm)]
|
2019-03-03 10:39:57 -06:00
|
|
|
#![feature(staged_api)]
|
2019-03-03 08:50:52 -06:00
|
|
|
#![feature(test)]
|
2019-03-02 12:40:15 -06:00
|
|
|
|
|
|
|
extern crate libtest;
|
2019-03-04 11:06:07 -06:00
|
|
|
pub use libtest::{
|
|
|
|
assert_test_result, filter_tests, parse_opts, run_test, test_main, test_main_static,
|
|
|
|
Bencher, DynTestFn, DynTestName, Metric, MetricMap, Options, RunIgnored, ShouldPanic,
|
|
|
|
StaticBenchFn, StaticTestFn, StaticTestName, TestDesc, TestDescAndFn, TestName, TestOpts,
|
|
|
|
TestResult, TrFailed, TrFailedMsg, TrIgnored, TrOk,
|
|
|
|
};
|
2019-03-04 11:04:08 -06:00
|
|
|
|
|
|
|
/// A function that is opaque to the optimizer, to allow benchmarks to
|
|
|
|
/// pretend to use outputs to assist in avoiding dead-code
|
|
|
|
/// elimination.
|
|
|
|
///
|
|
|
|
/// This function is a no-op, and does not even read from `dummy`.
|
|
|
|
#[cfg(not(any(target_arch = "asmjs", target_arch = "wasm32")))]
|
|
|
|
pub fn black_box<T>(dummy: T) -> T {
|
|
|
|
// we need to "use" the argument in some way LLVM can't
|
|
|
|
// introspect.
|
|
|
|
unsafe { asm!("" : : "r"(&dummy)) }
|
|
|
|
dummy
|
|
|
|
}
|
|
|
|
#[cfg(any(target_arch = "asmjs", target_arch = "wasm32"))]
|
|
|
|
#[inline(never)]
|
|
|
|
pub fn black_box<T>(dummy: T) -> T {
|
|
|
|
dummy
|
|
|
|
}
|