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
37
38
39
40
41
42
43
44
45
46
47
use crate::error::{ErrorDetail, ErrorDetails};
use validator::Contains;

pub const MUST_CONTAIN: &str = "MUST_CONTAIN";

/// Validates whether the value contains the needle
/// The value needs to implement the Contains trait, which is implement on String, str and Hashmap<String>
/// by default.
#[inline]
pub fn validate_contains<S: Into<String>, T: Contains>(
    error_details: &mut ErrorDetails,
    field_name: S,
    val: T,
    needle: &str,
) {
    if !validator::validate_contains(val, needle) {
        error_details.add_detail(
            field_name.into(),
            ErrorDetail::new(MUST_CONTAIN, vec![needle.to_string()]),
        )
    }
}

#[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_contains(&mut error_details, "name", "ufoscout", "ufo");
        assert!(error_details.details().is_empty())
    }

    #[test]
    fn should_validate_and_return_errors() {
        let mut error_details = ErrorDetails::default();
        validate_contains(&mut error_details, "name", "ufoscout", "alien");
        assert_eq!(1, error_details.details().len());
        assert_eq!(
            ErrorDetail::new(MUST_CONTAIN, vec!["alien".to_string()]),
            error_details.details()["name"][0]
        )
    }
}