use crate::core::SourceLocation;
#[derive(Debug)]
pub enum TestResult {
Success,
Failure(Failure),
}
impl TestResult {
pub fn new_success() -> Self {
TestResult::Success
}
pub fn new_failure(message: String, location: Option<SourceLocation>) -> Self {
TestResult::Failure(Failure {
should_panic: true,
message: message,
location: location,
})
}
pub fn assert_eq_message(self, message: &str) {
if let TestResult::Failure(mut failure) = self {
failure.should_panic = false;
assert_eq!(failure.message, message);
} else {
panic!("expected to be TestResult::Failure, got <{:?}>", self);
}
}
}
#[derive(Debug)]
pub struct Failure {
should_panic: bool,
message: String,
location: Option<SourceLocation>,
}
impl Failure {
#[cfg(feature = "nightly")]
fn panic(&self) {
use rust_core::panicking;
if let Some(location) = self.location {
let file_line = &(location.file, location.line, location.column);
panicking::panic_fmt(format_args!("{}", self.message), file_line);
} else {
panic!("assertion failed: `{}`", self.message);
}
}
#[cfg(not(feature = "nightly"))]
fn panic(&self) {
if let Some(location) = self.location {
panic!("assertion failed: `{}`, {}", self.message, location);
} else {
panic!("assertion failed: `{}`", self.message);
}
}
}
impl Drop for Failure {
fn drop(&mut self) {
if self.should_panic {
self.panic();
}
}
}
#[cfg(test)]
mod tests {
use super::TestResult;
#[test]
#[should_panic]
fn it_panics() {
TestResult::new_failure("panics on drop".into(), None);
}
}