2024-11-28 10:43:56 -05:00
|
|
|
use crate::data::{DBError, id::IDError};
|
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 {
|
2024-11-28 10:43:56 -05:00
|
|
|
DBErr(DBError),
|
|
|
|
IDErr(IDError),
|
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
|
|
|
}
|
|
|
|
|
2024-11-28 10:43:56 -05:00
|
|
|
impl From<DBError> for ErrorType {
|
|
|
|
fn from(value: DBError) -> Self {
|
|
|
|
ErrorType::DBErr(value)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<IDError> for ErrorType {
|
|
|
|
fn from(value: IDError) -> Self {
|
|
|
|
ErrorType::IDErr(value)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
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-28 10:43:56 -05:00
|
|
|
ErrorType::DBErr(data) => write!(f, "database: {}", data),
|
|
|
|
ErrorType::IDErr(data) => write!(f, "id: {}", 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
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-11-28 10:43:56 -05:00
|
|
|
#[cfg(test)]
|
|
|
|
mod errortypes {
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn database_error() {
|
|
|
|
let err = DBError::DuplicateTable("something".to_string());
|
|
|
|
let result = ErrorType::from(err.clone());
|
|
|
|
assert_eq!(result.to_string(), format!("database: {}", err));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn id_error() {
|
|
|
|
let err = IDError::InvalidUuid("bad".to_string());
|
|
|
|
let result = ErrorType::from(err.clone());
|
|
|
|
assert_eq!(result.to_string(), format!("id: {}", err));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
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())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-11-28 10:43:56 -05:00
|
|
|
impl From<IDError> for MTTError {
|
|
|
|
fn from(value: IDError) -> Self {
|
|
|
|
Self {
|
|
|
|
err: value.into(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-11-15 13:37:11 -05:00
|
|
|
#[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-28 10:43:56 -05:00
|
|
|
fn from_id_error() {
|
|
|
|
let error = IDError::InvalidUuid(rand_str());
|
|
|
|
let err = MTTError::from(error.clone());
|
|
|
|
assert_eq!(err.to_string(), ErrorType::IDErr(error).to_string());
|
2024-11-25 09:12:31 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#[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));
|
|
|
|
}
|
|
|
|
}
|