summaryrefslogtreecommitdiffstats
path: root/vendor/derive_builder/tests/forward_serde_attrs.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 18:31:44 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 18:31:44 +0000
commitc23a457e72abe608715ac76f076f47dc42af07a5 (patch)
tree2772049aaf84b5c9d0ed12ec8d86812f7a7904b6 /vendor/derive_builder/tests/forward_serde_attrs.rs
parentReleasing progress-linux version 1.73.0+dfsg1-1~progress7.99u1. (diff)
downloadrustc-c23a457e72abe608715ac76f076f47dc42af07a5.tar.xz
rustc-c23a457e72abe608715ac76f076f47dc42af07a5.zip
Merging upstream version 1.74.1+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'vendor/derive_builder/tests/forward_serde_attrs.rs')
-rw-r--r--vendor/derive_builder/tests/forward_serde_attrs.rs29
1 files changed, 29 insertions, 0 deletions
diff --git a/vendor/derive_builder/tests/forward_serde_attrs.rs b/vendor/derive_builder/tests/forward_serde_attrs.rs
new file mode 100644
index 000000000..2ba7bcf80
--- /dev/null
+++ b/vendor/derive_builder/tests/forward_serde_attrs.rs
@@ -0,0 +1,29 @@
+#[macro_use]
+extern crate derive_builder;
+extern crate serde;
+extern crate serde_json;
+
+#[derive(Builder)]
+#[builder(setter(into), derive(serde::Serialize))]
+#[builder_struct_attr(serde(rename_all = "camelCase"))]
+#[allow(dead_code)]
+struct Example {
+ first_name: String,
+ middle_name: String,
+ #[builder_field_attr(serde(rename = "familyName"))]
+ last_name: String,
+}
+
+#[test]
+fn serialize_builder() {
+ assert_eq!(
+ serde_json::to_string(
+ &ExampleBuilder::default()
+ .first_name("Jane")
+ .middle_name("Alice")
+ .last_name("Doe"),
+ )
+ .unwrap(),
+ r#"{"firstName":"Jane","middleName":"Alice","familyName":"Doe"}"#
+ );
+}