2024-12-01 23:00:07 -05:00
|
|
|
use crate::data::{id::IDError, DBError, table::TBLError};
|
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-12-01 23:00:07 -05:00
|
|
|
TBLErr(TBLError),
|
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-12-01 23:00:07 -05:00
|
|
|
impl From<TBLError> for ErrorType {
|
|
|
|
fn from(value: TBLError) -> Self {
|
|
|
|
ErrorType::TBLErr(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-12-01 23:00:07 -05:00
|
|
|
ErrorType::TBLErr(data) => write!(f, "table: {}", 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-12-01 23:00:07 -05:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn table_error() {
|
|
|
|
let err = TBLError::InvalidField("bad".to_string());
|
|
|
|
let result = ErrorType::from(err.clone());
|
|
|
|
assert_eq!(result.to_string(), format!("table: {}", err));
|
|
|
|
}
|
2024-11-28 10:43:56 -05:00
|
|
|
}
|
|
|
|
|
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-12-01 23:00:07 -05:00
|
|
|
impl From<DBError> for MTTError {
|
|
|
|
fn from(value: DBError) -> Self {
|
|
|
|
Self { err: value.into() }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-11-28 10:43:56 -05:00
|
|
|
impl From<IDError> for MTTError {
|
|
|
|
fn from(value: IDError) -> Self {
|
2024-12-01 23:00:07 -05:00
|
|
|
Self { err: value.into() }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<TBLError> for MTTError {
|
|
|
|
fn from(value: TBLError) -> Self {
|
|
|
|
Self { err: value.into() }
|
2024-11-28 10:43:56 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-12-01 23:00:07 -05:00
|
|
|
|
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]
|
2024-12-01 23:00:07 -05:00
|
|
|
fn from_database_error() {
|
|
|
|
let error = DBError::DuplicateTable(rand_str());
|
|
|
|
let err = MTTError::from(error.clone());
|
|
|
|
assert_eq!(err.to_string(), ErrorType::DBErr(error).to_string());
|
2024-11-15 13:37:11 -05:00
|
|
|
}
|
|
|
|
|
2024-11-25 09:12:31 -05:00
|
|
|
#[test]
|
2024-12-01 23:00:07 -05:00
|
|
|
fn from_table_error() {
|
|
|
|
let error = TBLError::InvalidField(rand_str());
|
|
|
|
let err = MTTError::from(error.clone());
|
|
|
|
assert_eq!(err.to_string(), ErrorType::TBLErr(error).to_string());
|
2024-11-25 09:12:31 -05:00
|
|
|
}
|
|
|
|
}
|