chainerror/tests/test_iter.rs

97 lines
2.7 KiB
Rust
Raw Normal View History

2020-08-28 16:45:24 +02:00
use chainerror::prelude::v1::*;
2019-01-25 13:53:30 +01:00
use std::error::Error;
use std::io;
2020-06-03 14:41:42 +02:00
#[cfg(not(feature = "display-cause"))]
2019-01-25 13:53:30 +01:00
#[test]
2020-03-03 14:37:11 +01:00
fn test_iter() -> Result<(), Box<dyn Error + Send + Sync>> {
2020-06-03 14:41:42 +02:00
use std::fmt::Write;
2020-08-28 16:45:24 +02:00
let err: Result<(), _> = Err(io::Error::from(io::ErrorKind::NotFound));
2020-09-01 21:03:01 +02:00
let err = err.context("1");
let err = err.context("2");
let err = err.context("3");
let err = err.context("4");
let err = err.context("5");
let err = err.context("6");
2020-08-28 16:45:24 +02:00
let err = err.err().unwrap();
2019-01-25 13:53:30 +01:00
let mut res = String::new();
for e in err.iter() {
write!(res, "{}", e.to_string())?;
}
assert_eq!(res, "654321entity not found");
let io_error: Option<&io::Error> = err
.iter()
.filter_map(Error::downcast_ref::<io::Error>)
.next();
assert_eq!(io_error.unwrap().kind(), io::ErrorKind::NotFound);
Ok(())
}
2020-06-03 14:41:42 +02:00
#[cfg(feature = "display-cause")]
#[test]
fn test_iter() -> Result<(), Box<dyn Error + Send + Sync>> {
2020-08-28 16:45:24 +02:00
let err: Result<(), _> = Err(io::Error::from(io::ErrorKind::NotFound));
2020-09-01 21:03:01 +02:00
let err = err.context("1");
let err = err.context("2");
let err = err.context("3");
let err = err.context("4");
let err = err.context("5");
let err = err.context("6");
2020-08-28 16:45:24 +02:00
let err = err.err().unwrap();
2020-06-03 14:41:42 +02:00
let res = err.to_string();
assert_eq!(res, "6\nCaused by:\n5\nCaused by:\n4\nCaused by:\n3\nCaused by:\n2\nCaused by:\n1\nCaused by:\nentity not found");
let io_error: Option<&io::Error> = err
.iter()
.filter_map(Error::downcast_ref::<io::Error>)
.next();
assert_eq!(io_error.unwrap().kind(), io::ErrorKind::NotFound);
Ok(())
}
2019-01-25 13:53:30 +01:00
#[test]
2020-03-03 14:37:11 +01:00
fn test_find_cause() -> Result<(), Box<dyn Error + Send + Sync>> {
2020-08-28 16:45:24 +02:00
let err: Result<(), _> = Err(io::Error::from(io::ErrorKind::NotFound));
2020-09-01 21:03:01 +02:00
let err = err.context("1");
let err = err.context("2");
let err = err.context("3");
let err = err.context("4");
let err = err.context("5");
let err = err.context("6");
2020-08-28 16:45:24 +02:00
let err = err.err().unwrap();
2019-01-25 13:53:30 +01:00
let io_error: Option<&io::Error> = err.find_cause::<io::Error>();
assert_eq!(io_error.unwrap().kind(), io::ErrorKind::NotFound);
Ok(())
}
#[test]
2020-03-03 14:37:11 +01:00
fn test_root_cause() -> Result<(), Box<dyn Error + Send + Sync>> {
2020-08-28 16:45:24 +02:00
let err: Result<(), _> = Err(io::Error::from(io::ErrorKind::NotFound));
2020-09-01 21:03:01 +02:00
let err = err.context("1");
let err = err.context("2");
let err = err.context("3");
let err = err.context("4");
let err = err.context("5");
let err = err.context("6");
2020-08-28 16:45:24 +02:00
let err = err.err().unwrap();
2019-01-25 13:53:30 +01:00
let err: Option<&(dyn std::error::Error + 'static)> = err.root_cause();
let io_error: Option<&io::Error> = err.and_then(Error::downcast_ref::<io::Error>);
assert_eq!(io_error.unwrap().kind(), io::ErrorKind::NotFound);
Ok(())
}