Protocol Buffers - Google's data interchange format (grpc依赖)
https://developers.google.com/protocol-buffers/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
88 lines
2.3 KiB
88 lines
2.3 KiB
// Protocol Buffers - Google's data interchange format |
|
// Copyright 2024 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 |
|
|
|
use googletest::prelude::*; |
|
use map_unittest_rust_proto::TestMapWithMessages; |
|
use protobuf_upb::proto; |
|
use unittest_rust_proto::{ |
|
test_all_types::NestedEnum as NestedEnumProto2, |
|
test_all_types::NestedMessage as NestedMessageProto2, TestAllTypes as TestAllTypesProto2, |
|
}; |
|
|
|
#[googletest::test] |
|
fn test_debug_string() { |
|
let mut msg = proto!(TestAllTypesProto2 { |
|
optional_int32: 42, |
|
optional_string: "Hello World", |
|
optional_nested_enum: NestedEnumProto2::Bar, |
|
oneof_uint32: 452235, |
|
optional_nested_message: proto!(NestedMessageProto2 { bb: 100 }), |
|
}); |
|
let mut repeated_string = msg.repeated_string_mut(); |
|
repeated_string.push("Hello World"); |
|
repeated_string.push("Hello World"); |
|
repeated_string.push("Hello World"); |
|
|
|
let mut msg_map = TestMapWithMessages::new(); |
|
println!("EMPTY MSG: {:?}", msg_map); // Make sure that we can print an empty message. |
|
msg_map.map_string_all_types_mut().insert("hello", msg.as_view()); |
|
msg_map.map_string_all_types_mut().insert("fizz", msg.as_view()); |
|
msg_map.map_string_all_types_mut().insert("boo", msg.as_view()); |
|
|
|
println!("{:?}", msg_map); |
|
println!("{:?}", msg_map.as_view()); // Make sure that we can print as_view |
|
println!("{:?}", msg_map.as_mut()); // Make sure that we can print as_mut |
|
let golden = r#"12 { |
|
key: "hello" |
|
value { |
|
1: 42 |
|
14: "Hello World" |
|
18 { |
|
1: 100 |
|
} |
|
21: 2 |
|
44: "Hello World" |
|
44: "Hello World" |
|
44: "Hello World" |
|
111: 452235 |
|
} |
|
} |
|
12 { |
|
key: "fizz" |
|
value { |
|
1: 42 |
|
14: "Hello World" |
|
18 { |
|
1: 100 |
|
} |
|
21: 2 |
|
44: "Hello World" |
|
44: "Hello World" |
|
44: "Hello World" |
|
111: 452235 |
|
} |
|
} |
|
12 { |
|
key: "boo" |
|
value { |
|
1: 42 |
|
14: "Hello World" |
|
18 { |
|
1: 100 |
|
} |
|
21: 2 |
|
44: "Hello World" |
|
44: "Hello World" |
|
44: "Hello World" |
|
111: 452235 |
|
} |
|
} |
|
"#; |
|
// C strings are null terminated while Rust strings are not. |
|
let null_terminated_str = format!("{}\0", golden); |
|
assert_that!(format!("{:?}", msg_map), eq(null_terminated_str.as_str())); |
|
}
|
|
|