aboutsummaryrefslogtreecommitdiffstats
path: root/validator_derive
diff options
context:
space:
mode:
authorShadoySV2020-05-20 15:33:12 +0300
committerShadoySV2020-05-20 15:33:12 +0300
commit48a179d2ccfbda0e6f501337ac4bd18f953858be (patch)
tree512c58de8dcc5b70f18dbed024ab4adee61682b0 /validator_derive
parentdb4f4be938d381d4a83efbfbbcc1ac9b1a1df511 (diff)
downloadvalidator-48a179d2ccfbda0e6f501337ac4bd18f953858be.tar.bz2
required validation
Diffstat (limited to 'validator_derive')
-rw-r--r--validator_derive/src/lib.rs3
-rw-r--r--validator_derive/src/quoting.rs23
-rw-r--r--validator_derive/tests/required.rs31
3 files changed, 57 insertions, 0 deletions
diff --git a/validator_derive/src/lib.rs b/validator_derive/src/lib.rs
index 6f74202..6f91ae8 100644
--- a/validator_derive/src/lib.rs
+++ b/validator_derive/src/lib.rs
@@ -287,6 +287,9 @@ fn find_validators_for_field(
Validator::NonControlCharacter,
));
}
+ "required" => {
+ validators.push(FieldValidation::new(Validator::Required));
+ }
_ => panic!("Unexpected validator: {:?}", name.get_ident()),
}
}
diff --git a/validator_derive/src/quoting.rs b/validator_derive/src/quoting.rs
index dc466ac..4c81037 100644
--- a/validator_derive/src/quoting.rs
+++ b/validator_derive/src/quoting.rs
@@ -465,6 +465,9 @@ pub fn quote_field_validation(
Validator::NonControlCharacter => {
validations.push(quote_non_control_character_validation(&field_quoter, validation))
}
+ Validator::Required => {
+ validations.push(quote_required_validation(&field_quoter, validation))
+ }
}
}
@@ -501,3 +504,23 @@ pub fn quote_schema_validation(validation: Option<SchemaValidation>) -> proc_mac
quote!()
}
}
+
+pub fn quote_required_validation(
+ field_quoter: &FieldQuoter,
+ validation: &FieldValidation,
+) -> proc_macro2::TokenStream {
+ let field_name = &field_quoter.name;
+ let ident = &field_quoter.ident;
+ let validator_param = quote!(&self.#ident);
+
+ let quoted_error = quote_error(&validation);
+ let quoted = quote!(
+ if !::validator::validate_required(#validator_param) {
+ #quoted_error
+ err.add_param(::std::borrow::Cow::from("value"), &#validator_param);
+ errors.add(#field_name, err);
+ }
+ );
+
+ quoted
+}
diff --git a/validator_derive/tests/required.rs b/validator_derive/tests/required.rs
new file mode 100644
index 0000000..2f02b1b
--- /dev/null
+++ b/validator_derive/tests/required.rs
@@ -0,0 +1,31 @@
+#[macro_use]
+extern crate validator_derive;
+
+use serde::Serialize;
+use validator::Validate;
+
+#[derive(Debug, Serialize)]
+struct ObjectRef {
+ id: i32,
+ name: String,
+}
+
+#[derive(Debug, Validate)]
+struct TestStruct {
+ #[validate(required)]
+ val: Option<ObjectRef>,
+}
+
+#[test]
+fn can_validate_some() {
+ let s = TestStruct { val: Some(ObjectRef { id: 0, name: String::new() }) };
+
+ assert!(s.validate().is_ok());
+}
+
+#[test]
+fn none_fails_validate() {
+ let s = TestStruct { val: None };
+
+ assert!(s.validate().is_err());
+}