1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
use crate::error::{ErrorDetail, ErrorDetails};
pub const NOT_VALID_EMAIL: &str = "NOT_VALID_EMAIL";
#[inline]
pub fn validate_email<S: Into<String>>(error_details: &mut ErrorDetails, field_name: S, val: &str) {
if !validator::validate_email(val) {
error_details.add_detail(field_name.into(), ErrorDetail::new(NOT_VALID_EMAIL, vec![]))
}
}
#[cfg(test)]
mod tests {
use super::*;
use crate::error::ErrorDetails;
#[test]
fn should_validate_and_return_no_errors() {
let mut error_details = ErrorDetails::default();
validate_email(&mut error_details, "email", "ufoscout@gmail.com");
assert!(error_details.details().is_empty())
}
#[test]
fn should_validate_and_return_errors() {
let mut error_details = ErrorDetails::default();
validate_email(&mut error_details, "email", "ufoscout_gmail.com");
assert_eq!(1, error_details.details().len());
assert_eq!(
ErrorDetail::new(NOT_VALID_EMAIL, vec![]),
error_details.details()["email"][0]
)
}
}