diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-30 18:31:36 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-30 18:31:36 +0000 |
commit | e02c5b5930c2c9ba3e5423fe12e2ef0155017297 (patch) | |
tree | fd60ebbbb5299e16e5fca8c773ddb74f764760db /vendor/derive_builder/tests/setter_visibility.rs | |
parent | Adding debian version 1.73.0+dfsg1-1. (diff) | |
download | rustc-e02c5b5930c2c9ba3e5423fe12e2ef0155017297.tar.xz rustc-e02c5b5930c2c9ba3e5423fe12e2ef0155017297.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/setter_visibility.rs')
-rw-r--r-- | vendor/derive_builder/tests/setter_visibility.rs | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/vendor/derive_builder/tests/setter_visibility.rs b/vendor/derive_builder/tests/setter_visibility.rs new file mode 100644 index 000000000..999509348 --- /dev/null +++ b/vendor/derive_builder/tests/setter_visibility.rs @@ -0,0 +1,63 @@ +#[macro_use] +extern crate pretty_assertions; +#[macro_use] +extern crate derive_builder; + +pub mod foo { + #[derive(Debug, PartialEq, Default, Builder, Clone)] + #[builder(private, setter(into))] + pub struct Lorem { + pub private: String, + #[builder(public)] + pub public: String, + } + + #[derive(Debug, PartialEq, Default, Builder, Clone)] + #[builder(public, setter(into))] + pub struct Ipsum { + #[builder(private)] + pub private: String, + pub public: String, + } + + #[test] + fn setters_same_module() { + let x = LoremBuilder::default() + .public("Hello") + .private("world!") + .build() + .unwrap(); + + assert_eq!( + x, + Lorem { + public: "Hello".into(), + private: "world!".into(), + } + ); + + let y = IpsumBuilder::default() + .public("Hello") + .private("world!") + .build() + .unwrap(); + + assert_eq!( + y, + Ipsum { + public: "Hello".into(), + private: "world!".into(), + } + ); + } +} + +#[test] +fn public_setters_foreign_module() { + let error = foo::IpsumBuilder::default() + .public("Hello") + .build() + .unwrap_err(); + + assert_eq!(&error.to_string(), "`private` must be initialized"); +} |