validator 0.12.0

Common validation functions (email, url, length, ...) and trait - to be used with `validator_derive`
Documentation
/// 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)));
    }
}