aboutsummaryrefslogtreecommitdiffstats
path: root/validator_derive/tests/schema.rs
blob: 6b3ae4fc9a7df6f7a763173918a81abcfd02012f (plain)
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
93
94
95
96
97
98
99
#[macro_use]
extern crate validator_derive;
extern crate validator;

use validator::{Validate, ValidationError};


#[test]
fn can_validate_schema_fn_ok() {
    fn valid_schema_fn(_: &TestStruct) -> Result<(), ValidationError> {
    Ok(())
}

    #[derive(Debug, Validate)]
    #[validate(schema(function = "valid_schema_fn"))]
    struct TestStruct {
        val: String,
    }

    let s = TestStruct {
        val: "hello".to_string(),
    };

    assert!(s.validate().is_ok());
}

#[test]
fn can_fail_schema_fn_validation() {
    fn invalid_schema_fn(_: &TestStruct) -> Result<(), ValidationError> {
        Err(ValidationError::new("meh"))
    }

    #[derive(Debug, Validate)]
    #[validate(schema(function = "invalid_schema_fn"))]
    struct TestStruct {
        val: String,
    }

    let s = TestStruct {
        val: String::new(),
    };
    let res = s.validate();
    assert!(res.is_err());
    let errs = res.unwrap_err().inner();
    assert!(errs.contains_key("__all__"));
    assert_eq!(errs["__all__"].len(), 1);
    assert_eq!(errs["__all__"][0].code, "meh");
}

#[test]
fn can_specify_message_for_schema_fn() {
    fn invalid_schema_fn(_: &TestStruct) -> Result<(), ValidationError> {
        Err(ValidationError::new("meh"))
    }

    #[derive(Debug, Validate)]
    #[validate(schema(function = "invalid_schema_fn", message = "oops"))]
    struct TestStruct {
        val: String,
    }
    let s = TestStruct {
        val: String::new(),
    };
    let res = s.validate();
    assert!(res.is_err());
    let errs = res.unwrap_err().inner();
    assert!(errs.contains_key("__all__"));
    assert_eq!(errs["__all__"].len(), 1);
    assert_eq!(errs["__all__"][0].clone().message.unwrap(), "oops");
}

#[test]
fn can_choose_to_run_schema_validation_even_after_field_errors() {
    fn invalid_schema_fn(_: &TestStruct) -> Result<(), ValidationError> {
        Err(ValidationError::new("meh"))
    }
    #[derive(Debug, Validate)]
    #[validate(schema(function = "invalid_schema_fn", skip_on_field_errors = "false"))]
    struct TestStruct {
        val: String,
        #[validate(range(min = "1", max = "10"))]
        num: usize,
    }

    let s = TestStruct {
        val: "hello".to_string(),
        num: 0,
    };

    let res = s.validate();
    assert!(res.is_err());
    let errs = res.unwrap_err().inner();
    assert!(errs.contains_key("__all__"));
    assert_eq!(errs["__all__"].len(), 1);
    assert_eq!(errs["__all__"][0].clone().code, "meh");
    assert!(errs.contains_key("num"));
    assert_eq!(errs["num"].len(), 1);
    assert_eq!(errs["num"][0].clone().code, "range");
}