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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
#[macro_use]
extern crate validator_derive;
extern crate validator;
use validator::{Validate, ValidationErrors};
#[test]
fn can_validate_range_ok() {
#[derive(Debug, Validate)]
struct TestStruct {
#[validate(range(min = 5, max = 10))]
val: usize,
}
let s = TestStruct { val: 6 };
assert!(s.validate().is_ok());
}
#[test]
fn value_out_of_range_fails_validation() {
#[derive(Debug, Validate)]
struct TestStruct {
#[validate(range(min = 5, max = 10))]
val: usize,
}
let s = TestStruct { val: 11 };
let res = s.validate();
assert!(res.is_err());
let err = res.unwrap_err();
let errs = err.field_errors();
assert!(errs.contains_key("val"));
assert_eq!(errs["val"].len(), 1);
assert_eq!(errs["val"][0].code, "range");
}
#[test]
fn can_specify_code_for_range() {
#[derive(Debug, Validate)]
struct TestStruct {
#[validate(range(min = 5, max = 10, code = "oops"))]
val: usize,
}
let s = TestStruct { val: 11 };
let res = s.validate();
assert!(res.is_err());
let err = res.unwrap_err();
let errs = err.field_errors();
assert!(errs.contains_key("val"));
assert_eq!(errs["val"].len(), 1);
assert_eq!(errs["val"][0].code, "oops");
assert_eq!(errs["val"][0].params["value"], 11);
assert_eq!(errs["val"][0].params["min"], 5f64);
assert_eq!(errs["val"][0].params["max"], 10f64);
}
#[test]
fn can_specify_message_for_range() {
#[derive(Debug, Validate)]
struct TestStruct {
#[validate(range(min = 5, max = 10, message = "oops"))]
val: usize,
}
let s = TestStruct { val: 1 };
let res = s.validate();
assert!(res.is_err());
let err = res.unwrap_err();
let errs = err.field_errors();
assert!(errs.contains_key("val"));
assert_eq!(errs["val"].len(), 1);
assert_eq!(errs["val"][0].clone().message.unwrap(), "oops");
}
#[test]
fn can_pass_reference_as_validate() {
// This tests that the blanket Validate implementation on
// `&T where T:Validate` works properly
#[derive(Validate)]
struct TestStruct {
#[validate(range(min = 100))]
num_field: u32,
}
fn validate<T: Validate>(value: T) -> Result<(), ValidationErrors> {
value.validate()
}
let val = TestStruct { num_field: 10 };
validate(&val).unwrap_err();
}
|