From aae30b9313fbb514fad5e70bd6679163d6c09dfd Mon Sep 17 00:00:00 2001 From: Casper Meijn Date: Fri, 3 Jan 2025 14:29:55 +0100 Subject: [PATCH] test: Move DecodeError tests closer to the implementation --- prost/src/error.rs | 30 ++++++++++++++++++++++++++++++ tests/src/decode_error.rs | 25 ------------------------- 2 files changed, 30 insertions(+), 25 deletions(-) diff --git a/prost/src/error.rs b/prost/src/error.rs index 78874b038..b46178590 100644 --- a/prost/src/error.rs +++ b/prost/src/error.rs @@ -148,3 +148,33 @@ impl fmt::Display for UnknownEnumValue { #[cfg(feature = "std")] impl std::error::Error for UnknownEnumValue {} + +#[cfg(test)] +mod test { + use super::*; + + #[test] + fn test_push() { + let mut decode_error = DecodeError::new("something failed"); + decode_error.push("Foo bad", "bar.foo"); + decode_error.push("Baz bad", "bar.baz"); + + assert_eq!( + decode_error.to_string(), + "failed to decode Protobuf message: Foo bad.bar.foo: Baz bad.bar.baz: something failed" + ); + } + + #[cfg(feature = "std")] + #[test] + fn test_into_std_io_error() { + let decode_error = DecodeError::new("something failed"); + let std_io_error = std::io::Error::from(decode_error); + + assert_eq!(std_io_error.kind(), std::io::ErrorKind::InvalidData); + assert_eq!( + std_io_error.to_string(), + "failed to decode Protobuf message: something failed" + ); + } +} diff --git a/tests/src/decode_error.rs b/tests/src/decode_error.rs index ff74240e7..16fb0c8d8 100644 --- a/tests/src/decode_error.rs +++ b/tests/src/decode_error.rs @@ -148,28 +148,3 @@ fn test_decode_error_any() { "failed to decode Protobuf message: unexpected type URL.type_url: expected type URL: \"type.googleapis.com/google.protobuf.Timestamp\" (got: \"non-existing-url\")" ); } - -#[test] -fn test_push() { - let mut decode_error = prost::DecodeError::new("something failed"); - decode_error.push("Foo bad", "bar.foo"); - decode_error.push("Baz bad", "bar.baz"); - - assert_eq!( - decode_error.to_string(), - "failed to decode Protobuf message: Foo bad.bar.foo: Baz bad.bar.baz: something failed" - ); -} - -#[cfg(feature = "std")] -#[test] -fn test_into_std_io_error() { - let decode_error = prost::DecodeError::new("something failed"); - let std_io_error = std::io::Error::from(decode_error); - - assert_eq!(std_io_error.kind(), std::io::ErrorKind::InvalidData); - assert_eq!( - std_io_error.to_string(), - "failed to decode Protobuf message: something failed" - ); -}