mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-30 18:53:39 +00:00
79d563c819
Part of #76268
135 lines
3.7 KiB
Rust
135 lines
3.7 KiB
Rust
use core::cmp::{
|
|
self,
|
|
Ordering::{self, *},
|
|
};
|
|
|
|
#[test]
|
|
fn test_int_totalord() {
|
|
assert_eq!(5.cmp(&10), Less);
|
|
assert_eq!(10.cmp(&5), Greater);
|
|
assert_eq!(5.cmp(&5), Equal);
|
|
assert_eq!((-5).cmp(&12), Less);
|
|
assert_eq!(12.cmp(&-5), Greater);
|
|
}
|
|
|
|
#[test]
|
|
fn test_bool_totalord() {
|
|
assert_eq!(true.cmp(&false), Greater);
|
|
assert_eq!(false.cmp(&true), Less);
|
|
assert_eq!(true.cmp(&true), Equal);
|
|
assert_eq!(false.cmp(&false), Equal);
|
|
}
|
|
|
|
#[test]
|
|
fn test_mut_int_totalord() {
|
|
assert_eq!((&mut 5).cmp(&&mut 10), Less);
|
|
assert_eq!((&mut 10).cmp(&&mut 5), Greater);
|
|
assert_eq!((&mut 5).cmp(&&mut 5), Equal);
|
|
assert_eq!((&mut -5).cmp(&&mut 12), Less);
|
|
assert_eq!((&mut 12).cmp(&&mut -5), Greater);
|
|
}
|
|
|
|
#[test]
|
|
fn test_ord_max_min() {
|
|
assert_eq!(1.max(2), 2);
|
|
assert_eq!(2.max(1), 2);
|
|
assert_eq!(1.min(2), 1);
|
|
assert_eq!(2.min(1), 1);
|
|
assert_eq!(1.max(1), 1);
|
|
assert_eq!(1.min(1), 1);
|
|
}
|
|
|
|
#[test]
|
|
fn test_ord_min_max_by() {
|
|
let f = |x: &i32, y: &i32| x.abs().cmp(&y.abs());
|
|
assert_eq!(cmp::min_by(1, -1, f), 1);
|
|
assert_eq!(cmp::min_by(1, -2, f), 1);
|
|
assert_eq!(cmp::min_by(2, -1, f), -1);
|
|
assert_eq!(cmp::max_by(1, -1, f), -1);
|
|
assert_eq!(cmp::max_by(1, -2, f), -2);
|
|
assert_eq!(cmp::max_by(2, -1, f), 2);
|
|
}
|
|
|
|
#[test]
|
|
fn test_ord_min_max_by_key() {
|
|
let f = |x: &i32| x.abs();
|
|
assert_eq!(cmp::min_by_key(1, -1, f), 1);
|
|
assert_eq!(cmp::min_by_key(1, -2, f), 1);
|
|
assert_eq!(cmp::min_by_key(2, -1, f), -1);
|
|
assert_eq!(cmp::max_by_key(1, -1, f), -1);
|
|
assert_eq!(cmp::max_by_key(1, -2, f), -2);
|
|
assert_eq!(cmp::max_by_key(2, -1, f), 2);
|
|
}
|
|
|
|
#[test]
|
|
fn test_ordering_reverse() {
|
|
assert_eq!(Less.reverse(), Greater);
|
|
assert_eq!(Equal.reverse(), Equal);
|
|
assert_eq!(Greater.reverse(), Less);
|
|
}
|
|
|
|
#[test]
|
|
fn test_ordering_order() {
|
|
assert!(Less < Equal);
|
|
assert_eq!(Greater.cmp(&Less), Greater);
|
|
}
|
|
|
|
#[test]
|
|
fn test_ordering_then() {
|
|
assert_eq!(Equal.then(Less), Less);
|
|
assert_eq!(Equal.then(Equal), Equal);
|
|
assert_eq!(Equal.then(Greater), Greater);
|
|
assert_eq!(Less.then(Less), Less);
|
|
assert_eq!(Less.then(Equal), Less);
|
|
assert_eq!(Less.then(Greater), Less);
|
|
assert_eq!(Greater.then(Less), Greater);
|
|
assert_eq!(Greater.then(Equal), Greater);
|
|
assert_eq!(Greater.then(Greater), Greater);
|
|
}
|
|
|
|
#[test]
|
|
fn test_ordering_then_with() {
|
|
assert_eq!(Equal.then_with(|| Less), Less);
|
|
assert_eq!(Equal.then_with(|| Equal), Equal);
|
|
assert_eq!(Equal.then_with(|| Greater), Greater);
|
|
assert_eq!(Less.then_with(|| Less), Less);
|
|
assert_eq!(Less.then_with(|| Equal), Less);
|
|
assert_eq!(Less.then_with(|| Greater), Less);
|
|
assert_eq!(Greater.then_with(|| Less), Greater);
|
|
assert_eq!(Greater.then_with(|| Equal), Greater);
|
|
assert_eq!(Greater.then_with(|| Greater), Greater);
|
|
}
|
|
|
|
#[test]
|
|
fn test_user_defined_eq() {
|
|
// Our type.
|
|
struct SketchyNum {
|
|
num: isize,
|
|
}
|
|
|
|
// Our implementation of `PartialEq` to support `==` and `!=`.
|
|
impl PartialEq for SketchyNum {
|
|
// Our custom eq allows numbers which are near each other to be equal! :D
|
|
fn eq(&self, other: &SketchyNum) -> bool {
|
|
(self.num - other.num).abs() < 5
|
|
}
|
|
}
|
|
|
|
// Now these binary operators will work when applied!
|
|
assert!(SketchyNum { num: 37 } == SketchyNum { num: 34 });
|
|
assert!(SketchyNum { num: 25 } != SketchyNum { num: 57 });
|
|
}
|
|
|
|
#[test]
|
|
fn ordering_const() {
|
|
// test that the methods of `Ordering` are usable in a const context
|
|
|
|
const ORDERING: Ordering = Greater;
|
|
|
|
const REVERSE: Ordering = ORDERING.reverse();
|
|
assert_eq!(REVERSE, Less);
|
|
|
|
const THEN: Ordering = Equal.then(ORDERING);
|
|
assert_eq!(THEN, Greater);
|
|
}
|