// Protocol Buffers - Google's data interchange format // Copyright 2023 Google LLC. All rights reserved. // // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file or at // https://developers.google.com/open-source/licenses/bsd //! Tests covering accessors for singular bool, int32, int64, and bytes fields. use googletest::prelude::*; use protobuf::proto; use unittest_rust_proto::{ test_all_types::{self, NestedMessage}, NestedTestAllTypes, TestAllTypes, }; use map_unittest_rust_proto::{TestMap, TestMapWithMessages}; struct TestValue { val: i64, } #[gtest] fn test_setting_literals() { let fixed64 = || 108; let test_ref = |x: &i64| *x; let test_ref_b = |x: &u32| *x; let one_oh_seven = [107_u32]; let value = TestValue { val: 106 }; let msg = proto!(TestAllTypes { optional_int32: 101, optional_int64: 102, optional_uint32: 103, optional_uint64: if true { 104 } else { 99 }, optional_sint32: -105, optional_sint64: (test_ref(&value.val)), optional_fixed32: { test_ref_b(&one_oh_seven[0]) }, optional_fixed64: fixed64(), //108 optional_sfixed32: 100 + 9, optional_sfixed64: { let x = 10; 100 + x }, optional_nested_message: NestedMessage { bb: 42 }, optional_float: 111.5, optional_double: 112000.5, optional_bool: true, optional_string: "foo", optional_bytes: b"bar", optional_nested_enum: test_all_types::NestedEnum::Baz, }); assert_that!(msg.optional_int32(), eq(101)); assert_that!(msg.optional_int64(), eq(102)); assert_that!(msg.optional_uint32(), eq(103)); assert_that!(msg.optional_uint64(), eq(104)); assert_that!(msg.optional_sint32(), eq(-105)); assert_that!(msg.optional_sint64(), eq(106)); assert_that!(msg.optional_fixed32(), eq(107)); assert_that!(msg.optional_fixed64(), eq(108)); assert_that!(msg.optional_sfixed32(), eq(109)); assert_that!(msg.optional_sfixed64(), eq(110)); assert_that!(msg.optional_float(), eq(111.5)); assert_that!(msg.optional_double(), eq(112000.5)); assert_that!(msg.optional_bool(), eq(true)); assert_that!(msg.optional_string(), eq("foo")); assert_that!(msg.optional_bytes(), eq(b"bar")); assert_that!(msg.optional_nested_enum(), eq(test_all_types::NestedEnum::Baz)); } #[gtest] fn single_nested_message() { let msg = proto!(TestAllTypes { optional_nested_message: NestedMessage { bb: 42 } }); assert_that!(msg.optional_nested_message().bb(), eq(42)); // field above it let msg = proto!(TestAllTypes { optional_int32: 1, optional_nested_message: NestedMessage { bb: 42 } }); assert_that!(msg.optional_nested_message().bb(), eq(42)); // field below it let msg = proto!(TestAllTypes { optional_nested_message: NestedMessage { bb: 42 }, optional_int32: 1 }); assert_that!(msg.optional_nested_message().bb(), eq(42)); // field above and below it let msg = proto!(TestAllTypes { optional_int32: 1, optional_nested_message: NestedMessage { bb: 42 }, optional_int64: 2 }); assert_that!(msg.optional_nested_message().bb(), eq(42)); // field above and below it let msg = proto!(TestAllTypes { optional_int32: 1, optional_nested_message: __ { bb: 42 }, optional_int64: 2 }); assert_that!(msg.optional_nested_message().bb(), eq(42)); // test empty initializer let msg = proto!(TestAllTypes {}); assert_that!(msg.has_optional_nested_message(), eq(false)); // empty nested message should be present // make sure that qualified path names work let msg = proto!(::unittest_rust_proto::TestAllTypes { optional_nested_message: unittest_rust_proto::test_all_types::NestedMessage {} }); assert_that!(msg.has_optional_nested_message(), eq(true)); let msg = proto!(::unittest_rust_proto::TestAllTypes { optional_nested_message: ::unittest_rust_proto::test_all_types::NestedMessage {} }); assert_that!(msg.has_optional_nested_message(), eq(true)); let msg = proto!(::unittest_rust_proto::TestAllTypes { optional_nested_message: __ {} }); assert_that!(msg.has_optional_nested_message(), eq(true)); } #[gtest] fn test_recursive_msg() { let msg = proto!(NestedTestAllTypes { child: NestedTestAllTypes { payload: TestAllTypes { optional_int32: 41 }, child: NestedTestAllTypes { child: NestedTestAllTypes { payload: TestAllTypes { optional_int32: 43 } }, payload: TestAllTypes { optional_int32: 42 } } } }); assert_that!(msg.child().payload().optional_int32(), eq(41)); assert_that!(msg.child().child().payload().optional_int32(), eq(42)); assert_that!(msg.child().child().child().payload().optional_int32(), eq(43)); } #[gtest] fn test_spread_msg() { let msg = proto!(TestAllTypes { optional_nested_message: NestedMessage { bb: 42 } }); let msg2 = proto!(TestAllTypes { ..msg.as_view() }); assert_that!(msg2.optional_nested_message().bb(), eq(42)); let msg3 = proto!(TestAllTypes { optional_int32: 1, ..msg.as_view() }); assert_that!(msg3.optional_nested_message().bb(), eq(42)); assert_that!(msg3.optional_int32(), eq(1)); } #[gtest] fn test_spread_nested_msg() { let msg = proto!(NestedTestAllTypes { child: NestedTestAllTypes { payload: TestAllTypes { optional_int32: 41 }, child: NestedTestAllTypes { child: NestedTestAllTypes { payload: TestAllTypes { optional_int32: 43 } }, payload: TestAllTypes { optional_int32: 42 } } } }); let msg2 = proto!(NestedTestAllTypes { child: NestedTestAllTypes { payload: TestAllTypes { optional_int32: 100 }, ..msg.child() } }); assert_that!(msg2.child().payload().optional_int32(), eq(100)); assert_that!(msg2.child().child().payload().optional_int32(), eq(42)); assert_that!(msg2.child().child().child().payload().optional_int32(), eq(43)); } #[gtest] fn test_repeated_i32() { let msg = proto!(TestAllTypes { repeated_int32: [1, 1 + 1, 3] }); assert_that!(msg.repeated_int32().len(), eq(3)); assert_that!(msg.repeated_int32().get(0).unwrap(), eq(1)); assert_that!(msg.repeated_int32().get(1).unwrap(), eq(2)); assert_that!(msg.repeated_int32().get(2).unwrap(), eq(3)); } #[gtest] fn test_repeated_msg() { let msg2 = proto!(NestedTestAllTypes { payload: TestAllTypes { optional_int32: 1 } }); let msg = proto!(NestedTestAllTypes { child: NestedTestAllTypes { repeated_child: [ NestedTestAllTypes { payload: TestAllTypes { optional_int32: 0 } }, msg2, __ { payload: TestAllTypes { optional_int32: 2 } } ] }, repeated_child: [ __ { payload: __ { optional_int32: 1 } }, NestedTestAllTypes { payload: TestAllTypes { optional_int32: 2 } } ] }); assert_that!(msg.child().repeated_child().len(), eq(3)); assert_that!(msg.child().repeated_child().get(0).unwrap().payload().optional_int32(), eq(0)); assert_that!(msg.child().repeated_child().get(1).unwrap().payload().optional_int32(), eq(1)); assert_that!(msg.child().repeated_child().get(2).unwrap().payload().optional_int32(), eq(2)); assert_that!(msg.repeated_child().len(), eq(2)); assert_that!(msg.repeated_child().get(0).unwrap().payload().optional_int32(), eq(1)); assert_that!(msg.repeated_child().get(1).unwrap().payload().optional_int32(), eq(2)); } #[gtest] fn test_string_maps() { let msg = proto!(TestMap { map_string_string: [("foo", "bar"), ("baz", "qux"), ("quux", "quuz")] }); assert_that!(msg.map_string_string().len(), eq(3)); assert_that!(msg.map_string_string().get("foo").unwrap(), eq("bar")); assert_that!(msg.map_string_string().get("baz").unwrap(), eq("qux")); assert_that!(msg.map_string_string().get("quux").unwrap(), eq("quuz")); } #[gtest] fn test_message_maps() { let msg3 = proto!(TestAllTypes { optional_int32: 3 }); let kv3 = ("quux", msg3); let msg = proto!(TestMapWithMessages { map_string_all_types: [ ("foo", TestAllTypes { optional_int32: 1 }), ("baz", __ { optional_int32: 2 }), kv3 ] }); assert_that!(msg.map_string_all_types().len(), eq(3)); assert_that!(msg.map_string_all_types().get("foo").unwrap().optional_int32(), eq(1)); assert_that!(msg.map_string_all_types().get("baz").unwrap().optional_int32(), eq(2)); assert_that!(msg.map_string_all_types().get("quux").unwrap().optional_int32(), eq(3)); }