Introduce set_and_test_mut! to cleanup simple_nested_test.rs

PiperOrigin-RevId: 586723934
pull/14912/head
Hong Shin 1 year ago committed by Copybara-Service
parent 94ebf577e3
commit 745aa6edbd
  1. 51
      rust/test/shared/simple_nested_test.rs

@ -33,6 +33,22 @@ fn test_nested_views() {
#[test] #[test]
fn test_nested_muts() { fn test_nested_muts() {
// Covers the setting of a mut and the following assertion
// confirming the new value. Replacement example:
// old:
// inner_msg.double_mut().set(543.21);
// assert_that!(inner_msg.double_mut().get(), eq(543.21));
// new:
// set_and_test_mut!(inner_msg => double_mut, 543.21);
macro_rules! set_and_test_mut {
( $a:expr => $($target_mut:ident, $val:literal;)* ) => {
$(
$a.$target_mut().set($val);
assert_that!($a.$target_mut().get(), eq($val));
)*
};
}
let mut outer_msg = Outer::new(); let mut outer_msg = Outer::new();
let inner_msg: InnerMut<'_> = outer_msg.inner_mut(); let inner_msg: InnerMut<'_> = outer_msg.inner_mut();
assert_that!( assert_that!(
@ -54,29 +70,20 @@ fn test_nested_muts() {
}) })
); );
inner_msg.double_mut().set(543.21); set_and_test_mut!(inner_msg =>
assert_that!(inner_msg.double_mut().get(), eq(543.21)); double_mut, 543.21;
inner_msg.float_mut().set(1.23); float_mut, 1.23;
assert_that!(inner_msg.float_mut().get(), eq(1.23)); int32_mut, 12;
inner_msg.int32_mut().set(12); int64_mut, 42;
assert_that!(inner_msg.int32_mut().get(), eq(12)); uint32_mut, 13;
inner_msg.int64_mut().set(42); uint64_mut, 5000;
assert_that!(inner_msg.int64_mut().get(), eq(42)); sint32_mut, -2;
inner_msg.uint32_mut().set(13); sint64_mut, 322;
assert_that!(inner_msg.uint32_mut().get(), eq(13)); fixed32_mut, 77;
inner_msg.uint64_mut().set(5000); fixed64_mut, 999;
assert_that!(inner_msg.uint64_mut().get(), eq(5000)); bool_mut, true;
inner_msg.sint32_mut().set(-2);
assert_that!(inner_msg.sint32_mut().get(), eq(-2));
inner_msg.sint64_mut().set(322);
assert_that!(inner_msg.sint64_mut().get(), eq(322));
inner_msg.fixed32_mut().set(77);
assert_that!(inner_msg.fixed32_mut().get(), eq(77));
inner_msg.fixed64_mut().set(999);
assert_that!(inner_msg.fixed64_mut().get(), eq(999));
inner_msg.bool_mut().set(true);
assert_that!(inner_msg.bool_mut().get(), eq(true));
);
// TODO: add mutation tests for strings and bytes // TODO: add mutation tests for strings and bytes
} }

Loading…
Cancel
Save