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
48
49
50
51
52
53
54
55
56
57
/// Validates that the given `value` is inside the defined range. The `max` and `min` parameters are
/// optional and will only be validated if they are not `None`
///
#[must_use]
pub fn validate_range<T>(value: T, min: Option<T>, max: Option<T>) -> bool
where
    T: PartialOrd + PartialEq,
{
    if let Some(max) = max {
        if value > max {
            return false;
        }
    }

    if let Some(min) = min {
        if value < min {
            return false;
        }
    }

    true
}

#[cfg(test)]
mod tests {
    use super::validate_range;

    #[test]
    fn test_validate_range_generic_ok() {
        // Unspecified generic type:
        assert_eq!(true, validate_range(10, Some(-10), Some(10)));
        assert_eq!(true, validate_range(0.0, Some(0.0), Some(10.0)));

        // Specified type:
        assert_eq!(true, validate_range(5u8, Some(0), Some(255)));
        assert_eq!(true, validate_range(4u16, Some(0), Some(16)));
        assert_eq!(true, validate_range(6u32, Some(0), Some(23)));
    }

    #[test]
    fn test_validate_range_generic_fail() {
        assert_eq!(false, validate_range(5, Some(17), Some(19)));
        assert_eq!(false, validate_range(-1.0, Some(0.0), Some(10.0)));
    }

    #[test]
    fn test_validate_range_generic_min_only() {
        assert_eq!(false, validate_range(5, Some(10), None));
        assert_eq!(true, validate_range(15, Some(10), None));
    }

    #[test]
    fn test_validate_range_generic_max_only() {
        assert_eq!(true, validate_range(5, None, Some(10)));
        assert_eq!(false, validate_range(15, None, Some(10)));
    }
}