2024-11-15 13:37:11 -05:00
|
|
|
use std::{error::Error, fmt};
|
|
|
|
|
|
|
|
#[derive(Debug)]
|
2024-11-25 09:12:31 -05:00
|
|
|
pub enum ErrorType {
|
|
|
|
FieldIDInvalid(String),
|
2024-11-15 13:37:11 -05:00
|
|
|
TableAddFieldDuplicate(String),
|
2024-11-25 09:12:31 -05:00
|
|
|
TableRecordInvalidFieldName(String),
|
2024-11-15 13:37:11 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
impl fmt::Display for ErrorType {
|
|
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|
|
|
match self {
|
2024-11-25 09:12:31 -05:00
|
|
|
ErrorType::FieldIDInvalid(data) => write!(f, "'{}' is not a valid uuid", data),
|
2024-11-15 13:37:11 -05:00
|
|
|
ErrorType::TableAddFieldDuplicate(data) => write!(f, "field '{}' already exists", data),
|
2024-11-25 09:12:31 -05:00
|
|
|
ErrorType::TableRecordInvalidFieldName(data) => {
|
|
|
|
write!(f, "invalid field name '{}'", data)
|
|
|
|
}
|
2024-11-15 13:37:11 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug)]
|
2024-11-25 09:12:31 -05:00
|
|
|
pub struct MTTError {
|
2024-11-15 13:37:11 -05:00
|
|
|
err: ErrorType,
|
|
|
|
}
|
|
|
|
|
2024-11-25 09:12:31 -05:00
|
|
|
impl From<ErrorType> for MTTError {
|
|
|
|
fn from(value: ErrorType) -> Self {
|
|
|
|
MTTError::new(value)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-11-15 13:37:11 -05:00
|
|
|
impl MTTError {
|
2024-11-25 09:12:31 -05:00
|
|
|
pub fn new(err: ErrorType) -> Self {
|
|
|
|
Self { err: err }
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn get_code(&self) -> &ErrorType {
|
|
|
|
&self.err
|
2024-11-15 13:37:11 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Error for MTTError {}
|
|
|
|
|
|
|
|
impl fmt::Display for MTTError {
|
|
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|
|
|
write!(f, "{}", self.err.to_string())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod errors {
|
|
|
|
use super::*;
|
2024-11-25 09:12:31 -05:00
|
|
|
use rand::{distributions::Alphanumeric, Rng};
|
|
|
|
|
|
|
|
fn rand_str() -> String {
|
|
|
|
rand::thread_rng()
|
|
|
|
.sample_iter(&Alphanumeric)
|
|
|
|
.take(5)
|
|
|
|
.map(char::from)
|
|
|
|
.collect()
|
|
|
|
}
|
2024-11-15 13:37:11 -05:00
|
|
|
|
|
|
|
#[test]
|
2024-11-25 09:12:31 -05:00
|
|
|
fn from_invalid_id() {
|
|
|
|
let data = rand_str();
|
|
|
|
let etype = ErrorType::FieldIDInvalid(data.clone());
|
|
|
|
let result = MTTError::from(etype);
|
|
|
|
match result.get_code() {
|
|
|
|
ErrorType::FieldIDInvalid(txt) => assert_eq!(txt, &data),
|
|
|
|
_ => unreachable!("should have been ErrorType::FieldIDInvalid"),
|
|
|
|
}
|
|
|
|
assert_eq!(
|
|
|
|
result.to_string(),
|
|
|
|
format!("'{}' is not a valid uuid", data)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn from_duplicate_table_name() {
|
|
|
|
let data = rand_str();
|
|
|
|
let etype = ErrorType::TableAddFieldDuplicate(data.clone());
|
|
|
|
let result = MTTError::from(etype);
|
|
|
|
match result.get_code() {
|
|
|
|
ErrorType::TableAddFieldDuplicate(txt) => assert_eq!(txt, &data),
|
|
|
|
_ => unreachable!("should have been ErrorType::FieldIDInvalid"),
|
|
|
|
}
|
|
|
|
assert_eq!(
|
|
|
|
result.to_string(),
|
|
|
|
format!("field '{}' already exists", data)
|
|
|
|
);
|
2024-11-15 13:37:11 -05:00
|
|
|
}
|
|
|
|
|
2024-11-25 09:12:31 -05:00
|
|
|
#[test]
|
|
|
|
fn error_type_strings() {
|
|
|
|
let data = rand_str();
|
|
|
|
let etype = ErrorType::TableRecordInvalidFieldName(data.clone());
|
|
|
|
assert_eq!(etype.to_string(), format!("invalid field name '{}'", data));
|
|
|
|
}
|
|
|
|
}
|