2019-04-01 14:08:19 -05:00
|
|
|
use core::ops::DerefMut;
|
2019-12-22 16:42:04 -06:00
|
|
|
use core::option::*;
|
2017-06-07 22:52:13 -05:00
|
|
|
|
2019-12-22 16:42:04 -06:00
|
|
|
fn op1() -> Result<isize, &'static str> {
|
|
|
|
Ok(666)
|
|
|
|
}
|
|
|
|
fn op2() -> Result<isize, &'static str> {
|
|
|
|
Err("sadface")
|
|
|
|
}
|
2014-06-28 15:57:36 -05:00
|
|
|
|
|
|
|
#[test]
|
2015-04-28 23:22:58 -05:00
|
|
|
fn test_and() {
|
2015-01-25 15:05:03 -06:00
|
|
|
assert_eq!(op1().and(Ok(667)).unwrap(), 667);
|
2019-12-22 16:42:04 -06:00
|
|
|
assert_eq!(op1().and(Err::<i32, &'static str>("bad")).unwrap_err(), "bad");
|
2014-06-28 15:57:36 -05:00
|
|
|
|
2015-01-25 15:05:03 -06:00
|
|
|
assert_eq!(op2().and(Ok(667)).unwrap_err(), "sadface");
|
2019-12-22 16:42:04 -06:00
|
|
|
assert_eq!(op2().and(Err::<i32, &'static str>("bad")).unwrap_err(), "sadface");
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2015-04-28 23:22:58 -05:00
|
|
|
fn test_and_then() {
|
2015-03-25 19:06:52 -05:00
|
|
|
assert_eq!(op1().and_then(|i| Ok::<isize, &'static str>(i + 1)).unwrap(), 667);
|
2019-12-22 16:42:04 -06:00
|
|
|
assert_eq!(op1().and_then(|_| Err::<isize, &'static str>("bad")).unwrap_err(), "bad");
|
2014-06-28 15:57:36 -05:00
|
|
|
|
2019-12-22 16:42:04 -06:00
|
|
|
assert_eq!(op2().and_then(|i| Ok::<isize, &'static str>(i + 1)).unwrap_err(), "sadface");
|
|
|
|
assert_eq!(op2().and_then(|_| Err::<isize, &'static str>("bad")).unwrap_err(), "sadface");
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2015-04-28 23:22:58 -05:00
|
|
|
fn test_or() {
|
2015-02-25 12:37:22 -06:00
|
|
|
assert_eq!(op1().or(Ok::<_, &'static str>(667)).unwrap(), 666);
|
2014-06-28 15:57:36 -05:00
|
|
|
assert_eq!(op1().or(Err("bad")).unwrap(), 666);
|
|
|
|
|
2015-02-25 12:37:22 -06:00
|
|
|
assert_eq!(op2().or(Ok::<_, &'static str>(667)).unwrap(), 667);
|
2014-06-28 15:57:36 -05:00
|
|
|
assert_eq!(op2().or(Err("bad")).unwrap_err(), "bad");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2015-04-28 23:22:58 -05:00
|
|
|
fn test_or_else() {
|
2015-03-25 19:06:52 -05:00
|
|
|
assert_eq!(op1().or_else(|_| Ok::<isize, &'static str>(667)).unwrap(), 666);
|
|
|
|
assert_eq!(op1().or_else(|e| Err::<isize, &'static str>(e)).unwrap(), 666);
|
2014-06-28 15:57:36 -05:00
|
|
|
|
2015-03-25 19:06:52 -05:00
|
|
|
assert_eq!(op2().or_else(|_| Ok::<isize, &'static str>(667)).unwrap(), 667);
|
2019-12-22 16:42:04 -06:00
|
|
|
assert_eq!(op2().or_else(|e| Err::<isize, &'static str>(e)).unwrap_err(), "sadface");
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2015-04-28 23:22:58 -05:00
|
|
|
fn test_impl_map() {
|
2015-03-25 19:06:52 -05:00
|
|
|
assert!(Ok::<isize, isize>(1).map(|x| x + 1) == Ok(2));
|
|
|
|
assert!(Err::<isize, isize>(1).map(|x| x + 1) == Err(1));
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2015-04-28 23:22:58 -05:00
|
|
|
fn test_impl_map_err() {
|
2015-03-25 19:06:52 -05:00
|
|
|
assert!(Ok::<isize, isize>(1).map_err(|x| x + 1) == Ok(1));
|
|
|
|
assert!(Err::<isize, isize>(1).map_err(|x| x + 1) == Err(2));
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_collect() {
|
2015-03-25 19:06:52 -05:00
|
|
|
let v: Result<Vec<isize>, ()> = (0..0).map(|_| Ok::<isize, ()>(0)).collect();
|
2014-06-28 15:57:36 -05:00
|
|
|
assert!(v == Ok(vec![]));
|
|
|
|
|
2015-03-25 19:06:52 -05:00
|
|
|
let v: Result<Vec<isize>, ()> = (0..3).map(|x| Ok::<isize, ()>(x)).collect();
|
2014-06-28 15:57:36 -05:00
|
|
|
assert!(v == Ok(vec![0, 1, 2]));
|
|
|
|
|
2019-12-22 16:42:04 -06:00
|
|
|
let v: Result<Vec<isize>, isize> = (0..3).map(|x| if x > 1 { Err(x) } else { Ok(x) }).collect();
|
2014-06-28 15:57:36 -05:00
|
|
|
assert!(v == Err(2));
|
|
|
|
|
|
|
|
// test that it does not take more elements than it needs
|
2018-07-13 00:25:22 -05:00
|
|
|
let mut functions: [Box<dyn Fn() -> Result<(), isize>>; 3] =
|
2015-01-25 15:05:03 -06:00
|
|
|
[box || Ok(()), box || Err(1), box || panic!()];
|
2014-06-28 15:57:36 -05:00
|
|
|
|
2015-03-25 19:06:52 -05:00
|
|
|
let v: Result<Vec<()>, isize> = functions.iter_mut().map(|f| (*f)()).collect();
|
2014-06-28 15:57:36 -05:00
|
|
|
assert!(v == Err(1));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2015-04-28 23:22:58 -05:00
|
|
|
fn test_fmt_default() {
|
2015-03-25 19:06:52 -05:00
|
|
|
let ok: Result<isize, &'static str> = Ok(100);
|
|
|
|
let err: Result<isize, &'static str> = Err("Err");
|
2014-06-28 15:57:36 -05:00
|
|
|
|
2014-12-20 02:09:35 -06:00
|
|
|
let s = format!("{:?}", ok);
|
2015-01-20 17:45:07 -06:00
|
|
|
assert_eq!(s, "Ok(100)");
|
2014-12-20 02:09:35 -06:00
|
|
|
let s = format!("{:?}", err);
|
|
|
|
assert_eq!(s, "Err(\"Err\")");
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2015-04-28 23:22:58 -05:00
|
|
|
fn test_unwrap_or() {
|
2015-03-25 19:06:52 -05:00
|
|
|
let ok: Result<isize, &'static str> = Ok(100);
|
|
|
|
let ok_err: Result<isize, &'static str> = Err("Err");
|
2014-06-28 15:57:36 -05:00
|
|
|
|
|
|
|
assert_eq!(ok.unwrap_or(50), 100);
|
|
|
|
assert_eq!(ok_err.unwrap_or(50), 50);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2015-04-28 23:22:58 -05:00
|
|
|
fn test_unwrap_or_else() {
|
2015-03-25 19:06:52 -05:00
|
|
|
fn handler(msg: &'static str) -> isize {
|
2019-12-22 16:42:04 -06:00
|
|
|
if msg == "I got this." { 50 } else { panic!("BadBad") }
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
|
|
|
|
2015-03-25 19:06:52 -05:00
|
|
|
let ok: Result<isize, &'static str> = Ok(100);
|
|
|
|
let ok_err: Result<isize, &'static str> = Err("I got this.");
|
2014-06-28 15:57:36 -05:00
|
|
|
|
|
|
|
assert_eq!(ok.unwrap_or_else(handler), 100);
|
|
|
|
assert_eq!(ok_err.unwrap_or_else(handler), 50);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2015-01-31 17:08:25 -06:00
|
|
|
#[should_panic]
|
2014-10-09 14:17:22 -05:00
|
|
|
pub fn test_unwrap_or_else_panic() {
|
2015-03-25 19:06:52 -05:00
|
|
|
fn handler(msg: &'static str) -> isize {
|
2019-12-22 16:42:04 -06:00
|
|
|
if msg == "I got this." { 50 } else { panic!("BadBad") }
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
|
|
|
|
2015-03-25 19:06:52 -05:00
|
|
|
let bad_err: Result<isize, &'static str> = Err("Unrecoverable mess.");
|
2019-12-22 16:42:04 -06:00
|
|
|
let _: isize = bad_err.unwrap_or_else(handler);
|
2014-06-28 15:57:36 -05:00
|
|
|
}
|
2015-06-13 09:34:58 -05:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
pub fn test_expect_ok() {
|
|
|
|
let ok: Result<isize, &'static str> = Ok(100);
|
|
|
|
assert_eq!(ok.expect("Unexpected error"), 100);
|
|
|
|
}
|
|
|
|
#[test]
|
2019-12-22 16:42:04 -06:00
|
|
|
#[should_panic(expected = "Got expected error: \"All good\"")]
|
2015-06-13 09:34:58 -05:00
|
|
|
pub fn test_expect_err() {
|
|
|
|
let err: Result<isize, &'static str> = Err("All good");
|
|
|
|
err.expect("Got expected error");
|
|
|
|
}
|
2015-08-27 01:37:40 -05:00
|
|
|
|
2017-01-10 21:17:47 -06:00
|
|
|
#[test]
|
|
|
|
pub fn test_expect_err_err() {
|
|
|
|
let ok: Result<&'static str, isize> = Err(100);
|
|
|
|
assert_eq!(ok.expect_err("Unexpected ok"), 100);
|
|
|
|
}
|
|
|
|
#[test]
|
2019-12-22 16:42:04 -06:00
|
|
|
#[should_panic(expected = "Got expected ok: \"All good\"")]
|
2017-01-10 21:17:47 -06:00
|
|
|
pub fn test_expect_err_ok() {
|
|
|
|
let err: Result<&'static str, isize> = Ok("All good");
|
|
|
|
err.expect_err("Got expected ok");
|
|
|
|
}
|
|
|
|
|
2015-08-27 01:37:40 -05:00
|
|
|
#[test]
|
|
|
|
pub fn test_iter() {
|
|
|
|
let ok: Result<isize, &'static str> = Ok(100);
|
|
|
|
let mut it = ok.iter();
|
|
|
|
assert_eq!(it.size_hint(), (1, Some(1)));
|
|
|
|
assert_eq!(it.next(), Some(&100));
|
|
|
|
assert_eq!(it.size_hint(), (0, Some(0)));
|
|
|
|
assert!(it.next().is_none());
|
|
|
|
assert_eq!((&ok).into_iter().next(), Some(&100));
|
|
|
|
|
|
|
|
let err: Result<isize, &'static str> = Err("error");
|
|
|
|
assert_eq!(err.iter().next(), None);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
pub fn test_iter_mut() {
|
|
|
|
let mut ok: Result<isize, &'static str> = Ok(100);
|
|
|
|
for loc in ok.iter_mut() {
|
|
|
|
*loc = 200;
|
|
|
|
}
|
|
|
|
assert_eq!(ok, Ok(200));
|
|
|
|
for loc in &mut ok {
|
|
|
|
*loc = 300;
|
|
|
|
}
|
|
|
|
assert_eq!(ok, Ok(300));
|
|
|
|
|
|
|
|
let mut err: Result<isize, &'static str> = Err("error");
|
|
|
|
for loc in err.iter_mut() {
|
|
|
|
*loc = 200;
|
|
|
|
}
|
|
|
|
assert_eq!(err, Err("error"));
|
|
|
|
}
|
2016-10-20 00:08:49 -05:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
pub fn test_unwrap_or_default() {
|
|
|
|
assert_eq!(op1().unwrap_or_default(), 666);
|
|
|
|
assert_eq!(op2().unwrap_or_default(), 0);
|
|
|
|
}
|
2017-06-07 22:52:13 -05:00
|
|
|
|
2019-11-02 15:12:51 -05:00
|
|
|
#[test]
|
2019-11-04 06:05:15 -06:00
|
|
|
pub fn test_into_ok() {
|
2019-11-02 15:12:51 -05:00
|
|
|
fn infallible_op() -> Result<isize, !> {
|
|
|
|
Ok(666)
|
|
|
|
}
|
|
|
|
|
2019-11-04 06:05:15 -06:00
|
|
|
assert_eq!(infallible_op().into_ok(), 666);
|
2019-11-02 15:12:51 -05:00
|
|
|
|
|
|
|
enum MyNeverToken {}
|
|
|
|
impl From<MyNeverToken> for ! {
|
|
|
|
fn from(never: MyNeverToken) -> ! {
|
|
|
|
match never {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn infallible_op2() -> Result<isize, MyNeverToken> {
|
|
|
|
Ok(667)
|
|
|
|
}
|
|
|
|
|
2019-11-04 06:05:15 -06:00
|
|
|
assert_eq!(infallible_op2().into_ok(), 667);
|
2019-11-02 15:12:51 -05:00
|
|
|
}
|
|
|
|
|
2017-06-07 22:52:13 -05:00
|
|
|
#[test]
|
|
|
|
fn test_try() {
|
|
|
|
fn try_result_some() -> Option<u8> {
|
|
|
|
let val = Ok(1)?;
|
|
|
|
Some(val)
|
|
|
|
}
|
|
|
|
assert_eq!(try_result_some(), Some(1));
|
|
|
|
|
|
|
|
fn try_result_none() -> Option<u8> {
|
2017-06-18 13:07:09 -05:00
|
|
|
let val = Err(NoneError)?;
|
2017-06-07 22:52:13 -05:00
|
|
|
Some(val)
|
|
|
|
}
|
|
|
|
assert_eq!(try_result_none(), None);
|
|
|
|
|
|
|
|
fn try_result_ok() -> Result<u8, u8> {
|
2018-05-20 13:52:08 -05:00
|
|
|
let result: Result<u8, u8> = Ok(1);
|
|
|
|
let val = result?;
|
2017-06-07 22:52:13 -05:00
|
|
|
Ok(val)
|
|
|
|
}
|
|
|
|
assert_eq!(try_result_ok(), Ok(1));
|
|
|
|
|
|
|
|
fn try_result_err() -> Result<u8, u8> {
|
2018-05-20 13:52:08 -05:00
|
|
|
let result: Result<u8, u8> = Err(1);
|
|
|
|
let val = result?;
|
2017-06-07 22:52:13 -05:00
|
|
|
Ok(val)
|
|
|
|
}
|
|
|
|
assert_eq!(try_result_err(), Err(1));
|
|
|
|
}
|
2018-04-26 18:29:22 -05:00
|
|
|
|
|
|
|
#[test]
|
2019-04-01 14:08:19 -05:00
|
|
|
fn test_result_as_deref() {
|
2020-01-07 00:57:08 -06:00
|
|
|
// &Result<T: Deref, E>::Ok(T).as_deref() ->
|
2018-04-30 14:51:43 -05:00
|
|
|
// Result<&T::Deref::Target, &E>::Ok(&*T)
|
|
|
|
let ref_ok = &Result::Ok::<&i32, u8>(&42);
|
|
|
|
let expected_result = Result::Ok::<&i32, &u8>(&42);
|
2019-04-01 14:08:19 -05:00
|
|
|
assert_eq!(ref_ok.as_deref(), expected_result);
|
2018-04-30 14:51:43 -05:00
|
|
|
|
2020-01-07 00:57:08 -06:00
|
|
|
let ref_ok = &Result::Ok::<String, u32>(String::from("a result"));
|
2018-04-30 14:51:43 -05:00
|
|
|
let expected_result = Result::Ok::<&str, &u32>("a result");
|
2019-04-01 14:08:19 -05:00
|
|
|
assert_eq!(ref_ok.as_deref(), expected_result);
|
2018-04-30 14:51:43 -05:00
|
|
|
|
2020-01-07 00:57:08 -06:00
|
|
|
let ref_ok = &Result::Ok::<Vec<i32>, u32>(vec![1, 2, 3, 4, 5]);
|
2019-04-01 14:08:19 -05:00
|
|
|
let expected_result = Result::Ok::<&[i32], &u32>([1, 2, 3, 4, 5].as_slice());
|
|
|
|
assert_eq!(ref_ok.as_deref(), expected_result);
|
2018-04-30 14:51:43 -05:00
|
|
|
|
2020-07-30 21:44:29 -05:00
|
|
|
// &Result<T: Deref, E>::Err(T).as_deref() ->
|
|
|
|
// Result<&T::Deref::Target, &E>::Err(&*E)
|
|
|
|
let val = 41;
|
|
|
|
let ref_err = &Result::Err::<&u8, i32>(val);
|
|
|
|
let expected_result = Result::Err::<&u8, &i32>(&val);
|
2019-04-01 14:08:19 -05:00
|
|
|
assert_eq!(ref_err.as_deref(), expected_result);
|
2018-04-30 14:51:43 -05:00
|
|
|
|
2020-01-07 00:57:08 -06:00
|
|
|
let s = String::from("an error");
|
|
|
|
let ref_err = &Result::Err::<&u32, String>(s.clone());
|
|
|
|
let expected_result = Result::Err::<&u32, &String>(&s);
|
2019-04-01 14:08:19 -05:00
|
|
|
assert_eq!(ref_err.as_deref(), expected_result);
|
2018-04-30 14:51:43 -05:00
|
|
|
|
2020-01-07 00:57:08 -06:00
|
|
|
let v = vec![5, 4, 3, 2, 1];
|
|
|
|
let ref_err = &Result::Err::<&u32, Vec<i32>>(v.clone());
|
|
|
|
let expected_result = Result::Err::<&u32, &Vec<i32>>(&v);
|
2019-04-01 14:08:19 -05:00
|
|
|
assert_eq!(ref_err.as_deref(), expected_result);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_result_as_deref_mut() {
|
2020-07-30 21:44:29 -05:00
|
|
|
// &mut Result<T: DerefMut, E>::Ok(T).as_deref_mut() ->
|
|
|
|
// Result<&mut T::DerefMut::Target, &mut E>::Ok(&mut *T)
|
2019-04-01 14:08:19 -05:00
|
|
|
let mut val = 42;
|
|
|
|
let mut expected_val = 42;
|
|
|
|
let mut_ok = &mut Result::Ok::<&mut i32, u8>(&mut val);
|
|
|
|
let expected_result = Result::Ok::<&mut i32, &mut u8>(&mut expected_val);
|
|
|
|
assert_eq!(mut_ok.as_deref_mut(), expected_result);
|
|
|
|
|
|
|
|
let mut expected_string = String::from("a result");
|
2020-01-07 00:57:08 -06:00
|
|
|
let mut_ok = &mut Result::Ok::<String, u32>(expected_string.clone());
|
2019-04-01 14:08:19 -05:00
|
|
|
let expected_result = Result::Ok::<&mut str, &mut u32>(expected_string.deref_mut());
|
|
|
|
assert_eq!(mut_ok.as_deref_mut(), expected_result);
|
|
|
|
|
|
|
|
let mut expected_vec = vec![1, 2, 3, 4, 5];
|
2020-01-07 00:57:08 -06:00
|
|
|
let mut_ok = &mut Result::Ok::<Vec<i32>, u32>(expected_vec.clone());
|
2019-04-01 14:08:19 -05:00
|
|
|
let expected_result = Result::Ok::<&mut [i32], &mut u32>(expected_vec.as_mut_slice());
|
|
|
|
assert_eq!(mut_ok.as_deref_mut(), expected_result);
|
|
|
|
|
2020-07-30 21:44:29 -05:00
|
|
|
// &mut Result<T: DerefMut, E>::Err(T).as_deref_mut() ->
|
|
|
|
// Result<&mut T, &mut E>::Err(&mut *E)
|
2019-04-01 14:08:19 -05:00
|
|
|
let mut val = 41;
|
2020-01-07 00:57:08 -06:00
|
|
|
let mut_err = &mut Result::Err::<&mut u8, i32>(val);
|
|
|
|
let expected_result = Result::Err::<&mut u8, &mut i32>(&mut val);
|
2019-04-01 14:08:19 -05:00
|
|
|
assert_eq!(mut_err.as_deref_mut(), expected_result);
|
|
|
|
|
|
|
|
let mut expected_string = String::from("an error");
|
|
|
|
let mut_err = &mut Result::Err::<&mut u32, String>(expected_string.clone());
|
2020-01-07 00:57:08 -06:00
|
|
|
let expected_result = Result::Err::<&mut u32, &mut String>(&mut expected_string);
|
2019-04-01 14:08:19 -05:00
|
|
|
assert_eq!(mut_err.as_deref_mut(), expected_result);
|
|
|
|
|
|
|
|
let mut expected_vec = vec![5, 4, 3, 2, 1];
|
|
|
|
let mut_err = &mut Result::Err::<&mut u32, Vec<i32>>(expected_vec.clone());
|
2020-01-07 00:57:08 -06:00
|
|
|
let expected_result = Result::Err::<&mut u32, &mut Vec<i32>>(&mut expected_vec);
|
2019-04-01 14:08:19 -05:00
|
|
|
assert_eq!(mut_err.as_deref_mut(), expected_result);
|
2018-04-26 18:29:22 -05:00
|
|
|
}
|
2020-09-03 17:24:34 -05:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn result_const() {
|
|
|
|
// test that the methods of `Result` are usable in a const context
|
|
|
|
|
|
|
|
const RESULT: Result<usize, bool> = Ok(32);
|
|
|
|
|
|
|
|
const REF: Result<&usize, &bool> = RESULT.as_ref();
|
|
|
|
assert_eq!(REF, Ok(&32));
|
|
|
|
|
|
|
|
const IS_OK: bool = RESULT.is_ok();
|
|
|
|
assert!(IS_OK);
|
|
|
|
|
|
|
|
const IS_ERR: bool = RESULT.is_err();
|
|
|
|
assert!(!IS_ERR)
|
|
|
|
}
|