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
use debugit::DebugIt;

/// A `Validator` is an object that knows how to validate method parameters.
///
/// To use these, you typically pass them to the `.with()` method for use with
/// the `Params` Constraint.
pub trait Validator<I> {
    /// This object has been called with the given parameters. Return `true`
    /// if they are acceptable, and `false` if they are not.
    fn validate(&mut self, param: &I) -> bool;

    // Method to create a string representing the pass condition of this Validator.
    fn print(&self) -> String;
}

/// `Validator` is automatically implemented for types that implement `PartialEq`.
impl<I: PartialEq> Validator<I> for I {
    fn validate(&mut self, param: &I) -> bool {
        &*param == self
    }

     fn print(&self) -> String {
         format!("{:?}", DebugIt(self)).to_owned()
     }
}

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

    #[test]
    fn test_partialeq_validate() {
        let v = 555;
        assert!(555.validate(&v));
        assert!(!666.validate(&v));
    }
}