Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Upgrade to Rust 1.62.0 #1825

Merged
merged 50 commits into from
Oct 17, 2022
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
6df5fbd
Run clippy --fix for Rust 1.62.0 and format the resulting code
LukeMathWalker Oct 7, 2022
292fbec
Run clippy --fix on all targets
LukeMathWalker Oct 7, 2022
0a2d01d
Run clippy --fix with all features enabled
LukeMathWalker Oct 7, 2022
74fafd9
Avoid extra allocation
LukeMathWalker Oct 7, 2022
3a99ce4
Use more idiomatic assert
LukeMathWalker Oct 7, 2022
37a51e3
Ignore noisy lint
LukeMathWalker Oct 7, 2022
1f85655
Update pyo3 and pyo3-asyncio to 0.17.0
jjant Oct 7, 2022
5da1704
Implement Eq on aws-smithy-checksums::Error
jjant Oct 7, 2022
5faf18d
Implement Eq on Protocol
jjant Oct 7, 2022
aaf14f3
Replace conditionals with range-containment
jjant Oct 7, 2022
c45a6b5
Implement Eq on types in aws-smithy-types
jjant Oct 7, 2022
f2cd901
Implement Eq on types in aws-smithy-http-server-python
jjant Oct 7, 2022
78f4b07
Implement Eq on types in aws-smithy-eventstream
jjant Oct 7, 2022
590f01a
Implement Eq on types in aws-smithy-xml
jjant Oct 7, 2022
d78bb62
Implement Eq on aws-sigv4
jjant Oct 7, 2022
3da634a
Update CI to use Rust 1.62.0
jjant Oct 7, 2022
5169bd9
Add Eq for generated types that implement PartialEq
jjant Oct 7, 2022
1d27e8f
Allow clippy::needless_return in generated code
jjant Oct 7, 2022
fc69639
Remove unnecessary reborrow in http_serde
jjant Oct 7, 2022
90be70c
Remove unnecessary borrow in operation_deser
jjant Oct 7, 2022
dbd6bc6
Add CHANGELOG entries
jjant Oct 7, 2022
afe4afb
Revert "Add Eq for generated types that implement PartialEq"
jjant Oct 7, 2022
625c6d4
Update pyo3 and pyo3-asyncio in generated code for python server
jjant Oct 7, 2022
068c63c
Allow clippy::derive_partial_eq_without_eq on structs and builders
jjant Oct 7, 2022
316b031
Run clippy on tools
jjant Oct 7, 2022
34ef535
Fix accidental move in generated code
jjant Oct 7, 2022
669e8ea
Revert "Allow clippy::derive_partial_eq_without_eq on structs and bui…
jjant Oct 7, 2022
38cfa85
Fix another accidental move in generated code
jjant Oct 7, 2022
ae35de2
Undo unwanted change to model
jjant Oct 10, 2022
bed03b5
Re-add reborrow in HttpBindingGenerator
jjant Oct 10, 2022
7b424ad
Fix clippy::format-push-string in changelogger
jjant Oct 10, 2022
60d27d1
Fix more uses of str.push_str(&format!(...))
jjant Oct 11, 2022
77f0b32
Remove unnecessary parenthesis
jjant Oct 11, 2022
ba28132
Run ktlint
jjant Oct 11, 2022
70785a1
Update aws/rust-runtime/aws-http/src/content_encoding.rs
jjant Oct 11, 2022
2cf21d1
Update aws/rust-runtime/aws-http/src/content_encoding.rs
jjant Oct 11, 2022
e68dfb7
Ignore doctest for non-exported macro
jjant Oct 11, 2022
96b54fa
Merge branch 'main' into upgrade-rust-1-62
jjant Oct 11, 2022
f1c8beb
Run cargo fmt
jjant Oct 11, 2022
a63c7b8
Use $crate instead of crate in macro
jjant Oct 11, 2022
a74aac2
Merge branch 'main' into upgrade-rust-1-62
jjant Oct 12, 2022
405f747
Revert "Implement Eq on types in aws-smithy-types"
jjant Oct 12, 2022
93ae155
Merge branch 'upgrade-rust-1-62' of github.com:awslabs/smithy-rs into…
jjant Oct 12, 2022
9c47ac8
Revert "Implement Eq on types in aws-smithy-eventstream"
jjant Oct 12, 2022
47fa662
Revert "Implement Eq on types in aws-smithy-xml"
jjant Oct 12, 2022
90f5429
Revert "Implement Eq on aws-sigv4"
jjant Oct 12, 2022
a133343
Revert "Implement Eq on types in aws-smithy-http-server-python"
jjant Oct 12, 2022
7b5b6a9
Revert "Implement Eq on aws-smithy-checksums::Error"
jjant Oct 12, 2022
1df977e
Merge branch 'main' into upgrade-rust-1-62
jjant Oct 14, 2022
64d2ea7
Merge branch 'main' into upgrade-rust-1-62
jjant Oct 14, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ on:
workflow_call:

env:
rust_version: 1.61.0
rust_version: 1.62.0
rust_toolchain_components: clippy,rustfmt

jobs:
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/pull-request-bot.yml
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ concurrency:

env:
java_version: 11
rust_version: 1.61.0
rust_version: 1.62.0
rust_toolchain_components: clippy,rustfmt
apt_dependencies: libssl-dev gnuplot jq

Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ concurrency:
cancel-in-progress: true

env:
rust_version: 1.61.0
rust_version: 1.62.0

name: Release smithy-rs
on:
Expand Down
6 changes: 2 additions & 4 deletions aws/rust-runtime/aws-endpoint/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -283,8 +283,7 @@ mod test {
props.insert(region.clone());
props.insert(SigningService::from_static("qldb"));
props.insert(
EndpointShim::from_arc(provider)
.resolve_endpoint(&Params::new(Some(region.clone()))),
EndpointShim::from_arc(provider).resolve_endpoint(&Params::new(Some(region))),
);
};
let req = AwsEndpointStage.apply(req).expect("should succeed");
Expand Down Expand Up @@ -314,8 +313,7 @@ mod test {
props.insert(region.clone());
props.insert(SigningService::from_static("qldb"));
props.insert(
EndpointShim::from_arc(provider)
.resolve_endpoint(&Params::new(Some(region.clone()))),
EndpointShim::from_arc(provider).resolve_endpoint(&Params::new(Some(region))),
);
};
let req = AwsEndpointStage.apply(req).expect("should succeed");
Expand Down
6 changes: 3 additions & 3 deletions aws/rust-runtime/aws-http/src/content_encoding.rs
Original file line number Diff line number Diff line change
Expand Up @@ -376,7 +376,7 @@ mod tests {

impl SputteringBody {
fn len(&self) -> usize {
self.parts.iter().flat_map(|b| b).map(|b| b.len()).sum()
self.parts.iter().flatten().map(|b| b.len()).sum()
}
}

Expand Down Expand Up @@ -462,7 +462,7 @@ mod tests {
};

let timeout_duration = Duration::from_secs(3);
if let Err(_) = tokio::time::timeout(timeout_duration, test_fut).await {
if (tokio::time::timeout(timeout_duration, test_fut).await).is_err() {
jjant marked this conversation as resolved.
Show resolved Hide resolved
panic!("test_aws_chunked_encoding timed out after {timeout_duration:?}");
}
}
Expand Down Expand Up @@ -513,7 +513,7 @@ mod tests {
};

let timeout_duration = Duration::from_secs(3);
if let Err(_) = tokio::time::timeout(timeout_duration, test_fut).await {
if (tokio::time::timeout(timeout_duration, test_fut).await).is_err() {
jjant marked this conversation as resolved.
Show resolved Hide resolved
panic!(
"test_aws_chunked_encoding_sputtering_body timed out after {timeout_duration:?}"
);
Expand Down
2 changes: 1 addition & 1 deletion aws/rust-runtime/aws-http/src/recursion_detection.rs
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,7 @@ mod test {
)
}
assert_ok(validate_headers(
&augmented_req.http().headers(),
augmented_req.http().headers(),
test_case.request_headers_after(),
))
}
Expand Down
6 changes: 2 additions & 4 deletions aws/rust-runtime/aws-http/src/retry.rs
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,7 @@ mod test {
) -> Result<SdkSuccess<()>, SdkError<E>> {
Err(SdkError::ServiceError {
err,
raw: operation::Response::new(raw.map(|b| SdkBody::from(b))),
raw: operation::Response::new(raw.map(SdkBody::from)),
})
}

Expand Down Expand Up @@ -265,9 +265,7 @@ mod test {
policy.classify_retry(
Result::<SdkSuccess<()>, SdkError<UnmodeledError>>::Err(SdkError::ResponseError {
err: Box::new(UnmodeledError),
raw: operation::Response::new(
http::Response::new("OK").map(|b| SdkBody::from(b))
),
raw: operation::Response::new(http::Response::new("OK").map(SdkBody::from)),
})
.as_ref()
),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -265,7 +265,7 @@ mod tests {
for i in 0..10000 {
let line = format!("This is a large file created for testing purposes {}", i);
file.as_file_mut().write(line.as_bytes()).unwrap();
crc32c_checksum.update(&line.as_bytes());
crc32c_checksum.update(line.as_bytes());
}

let body = ByteStream::read_from()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@ fn test_operation() -> Operation<TestOperationParser, AwsResponseRetryClassifier
.body(SdkBody::from("request body"))
.unwrap(),
)
.augment(|req, mut conf| {
.augment(|req, conf| {
conf.insert(
EndpointShim::from_resolver(aws_endpoint::partition::endpoint::Metadata {
uri_template: "test-service.{region}.amazonaws.com",
Expand All @@ -93,7 +93,7 @@ fn test_operation() -> Operation<TestOperationParser, AwsResponseRetryClassifier
.resolve_endpoint(&Params::new(Some(Region::new("test-region")))),
);
aws_http::auth::set_provider(
&mut conf,
conf,
SharedCredentialsProvider::new(Credentials::new(
"access_key",
"secret_key",
Expand Down
4 changes: 2 additions & 2 deletions aws/rust-runtime/aws-sigv4/src/event_stream.rs
Original file line number Diff line number Diff line change
Expand Up @@ -159,7 +159,7 @@ mod tests {
security_token: None,
region: "us-east-1",
service_name: "testservice",
time: (UNIX_EPOCH + Duration::new(123_456_789_u64, 1234u32)).into(),
time: (UNIX_EPOCH + Duration::new(123_456_789_u64, 1234u32)),
settings: (),
};

Expand Down Expand Up @@ -197,7 +197,7 @@ mod tests {
security_token: None,
region: "us-east-1",
service_name: "testservice",
time: (UNIX_EPOCH + Duration::new(123_456_789_u64, 1234u32)).into(),
time: (UNIX_EPOCH + Duration::new(123_456_789_u64, 1234u32)),
settings: (),
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -597,7 +597,7 @@ mod tests {
region: "us-east-1",
service: "iam",
};
assert_eq!(format!("{}\n", scope.to_string()), expected);
assert_eq!(format!("{}\n", scope), expected);
}

#[test]
Expand Down
2 changes: 1 addition & 1 deletion aws/rust-runtime/aws-sigv4/src/http_request/settings.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ use std::time::Duration;
pub type SigningParams<'a> = crate::SigningParams<'a, SigningSettings>;

/// HTTP-specific signing settings
#[derive(Debug, PartialEq)]
#[derive(Debug, PartialEq, Eq)]
jjant marked this conversation as resolved.
Show resolved Hide resolved
#[non_exhaustive]
pub struct SigningSettings {
/// Specifies how to encode the request URL when signing. Some services do not decode
Expand Down
2 changes: 1 addition & 1 deletion gradle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
#

# Rust MSRV (entered into the generated README)
rust.msrv=1.61.0
rust.msrv=1.62.0

org.gradle.jvmargs=-Xmx1024M

Expand Down
2 changes: 1 addition & 1 deletion rust-runtime/aws-smithy-async/src/future/fn_stream.rs
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,7 @@ mod test {
Box::pin(async move {
for i in 0..5 {
if i != 2 {
if let Err(_) = tx.send(Ok(i)).await {
if (tx.send(Ok(i)).await).is_err() {
jjant marked this conversation as resolved.
Show resolved Hide resolved
return;
}
} else {
Expand Down
2 changes: 1 addition & 1 deletion rust-runtime/aws-smithy-checksums/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@ impl ChecksumAlgorithm {
}
}

#[derive(Debug, PartialEq)]
#[derive(Debug, PartialEq, Eq)]
pub enum Error {
UnknownChecksumAlgorithm(String),
}
Expand Down
10 changes: 5 additions & 5 deletions rust-runtime/aws-smithy-eventstream/src/frame.rs
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ mod value {

/// Event Stream frame header value.
#[non_exhaustive]
#[derive(Clone, Debug, PartialEq)]
#[derive(Clone, Debug, PartialEq, Eq)]
pub enum HeaderValue {
Bool(bool),
Byte(i8),
Expand Down Expand Up @@ -300,7 +300,7 @@ pub use value::HeaderValue;

/// Event Stream header.
#[non_exhaustive]
#[derive(Clone, Debug, PartialEq)]
#[derive(Clone, Debug, PartialEq, Eq)]
#[cfg_attr(feature = "derive-arbitrary", derive(arbitrary::Arbitrary))]
pub struct Header {
name: StrBytes,
Expand Down Expand Up @@ -368,7 +368,7 @@ pub fn write_headers_to<B: BufMut>(headers: &[Header], mut buffer: B) -> Result<

/// Event Stream message.
#[non_exhaustive]
#[derive(Clone, Debug, PartialEq)]
#[derive(Clone, Debug, PartialEq, Eq)]
pub struct Message {
headers: Vec<Header>,
payload: Bytes,
Expand Down Expand Up @@ -601,7 +601,7 @@ mod message_tests {
0x36,
];

let result = Message::read_from(&mut Bytes::from_static(&data)).unwrap();
let result = Message::read_from(&mut Bytes::from_static(data)).unwrap();
assert_eq!(result.headers(), Vec::new());

let expected_payload = b"{'foo':'bar'}";
Expand All @@ -620,7 +620,7 @@ mod message_tests {
0x7d, 0x8D, 0x9C, 0x08, 0xB1,
];

let result = Message::read_from(&mut Bytes::from_static(&data)).unwrap();
let result = Message::read_from(&mut Bytes::from_static(data)).unwrap();
assert_eq!(
result.headers(),
vec![Header::new(
Expand Down
2 changes: 1 addition & 1 deletion rust-runtime/aws-smithy-eventstream/src/str_bytes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,7 @@ mod tests {
let str_bytes: StrBytes = valid_utf8.into();
assert_eq!(valid_utf8.as_bytes(), str_bytes.as_bytes());
assert_eq!(valid_utf8, str_bytes.as_str());
assert_eq!(valid_utf8, str_bytes.clone().as_str());
assert_eq!(valid_utf8, str_bytes.as_str());
}

#[test]
Expand Down
4 changes: 2 additions & 2 deletions rust-runtime/aws-smithy-http-server-python/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,8 @@ hyper = { version = "0.14.20", features = ["server", "http1", "http2", "tcp", "s
num_cpus = "1.13.1"
parking_lot = "0.12.1"
pin-project-lite = "0.2"
pyo3 = "0.16.5"
pyo3-asyncio = { version = "0.16.0", features = ["tokio-runtime"] }
pyo3 = "0.17.0"
pyo3-asyncio = { version = "0.17.0", features = ["tokio-runtime"] }
Comment on lines -29 to +30
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This was necessary to fix a bunch of noisy reborrow lints - is upgrading an issue? Everything compiles and all tests are passing.
@crisidev @unexge
https://pyo3.rs/v0.17.0/migration.html#from-016-to-017

signal-hook = { version = "0.3.14", features = ["extended-siginfo"] }
socket2 = { version = "0.4.4", features = ["all"] }
thiserror = "1.0.32"
Expand Down
4 changes: 2 additions & 2 deletions rust-runtime/aws-smithy-http-server-python/src/types.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ use crate::PyError;

/// Python Wrapper for [aws_smithy_types::Blob].
#[pyclass]
#[derive(Debug, Clone, PartialEq)]
#[derive(Debug, Clone, PartialEq, Eq)]
pub struct Blob(aws_smithy_types::Blob);

impl Blob {
Expand Down Expand Up @@ -88,7 +88,7 @@ impl<'blob> From<&'blob Blob> for &'blob aws_smithy_types::Blob {

/// Python Wrapper for [aws_smithy_types::date_time::DateTime].
#[pyclass]
#[derive(Debug, Clone, PartialEq)]
#[derive(Debug, Clone, PartialEq, Eq)]
pub struct DateTime(aws_smithy_types::date_time::DateTime);

#[pyclass]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -93,9 +93,9 @@ mod tests {
let sensitive = Sensitive(inner);
let actual = format!("{}", sensitive);
let expected = if cfg!(feature = "unredacted-logging") {
format!("{}", inner)
inner.to_string()
} else {
format!("{}", REDACTED)
REDACTED.to_string()
};
assert_eq!(actual, expected)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -186,7 +186,7 @@ mod tests {
let originals = EXAMPLES.into_iter().map(Uri::from_static);
for original in originals {
let expected = original.path().to_string();
let output = Label::new(&original.path(), |_| false, None).to_string();
let output = Label::new(original.path(), |_| false, None).to_string();
assert_eq!(output, expected, "original = {original}");
}
}
Expand Down Expand Up @@ -222,7 +222,7 @@ mod tests {
let originals = EXAMPLES.into_iter().map(Uri::from_static);
let expecteds = ALL_EXAMPLES.into_iter().map(Uri::from_static);
for (original, expected) in originals.zip(expecteds) {
let output = Label::new(&original.path(), |_| true, None).to_string();
let output = Label::new(original.path(), |_| true, None).to_string();
assert_eq!(output, expected.path(), "original = {original}");
}
}
Expand Down Expand Up @@ -258,7 +258,7 @@ mod tests {
let originals = EXAMPLES.into_iter().map(Uri::from_static);
let expecteds = GREEDY_EXAMPLES.into_iter().map(Uri::from_static);
for (original, expected) in originals.zip(expecteds) {
let output = Label::new(&original.path(), |_| false, Some(GreedyLabel::new(1, 0))).to_string();
let output = Label::new(original.path(), |_| false, Some(GreedyLabel::new(1, 0))).to_string();
assert_eq!(output, expected.path(), "original = {original}");
}
}
Expand Down Expand Up @@ -294,7 +294,7 @@ mod tests {
let originals = EXAMPLES.into_iter().map(Uri::from_static);
let expecteds = GREEDY_EXAMPLES_OFFSET.into_iter().map(Uri::from_static);
for (original, expected) in originals.zip(expecteds) {
let output = Label::new(&original.path(), |_| false, Some(GreedyLabel::new(1, 1))).to_string();
let output = Label::new(original.path(), |_| false, Some(GreedyLabel::new(1, 1))).to_string();
assert_eq!(output, expected.path(), "original = {original}");
}
}
Expand All @@ -321,7 +321,7 @@ mod tests {
let originals = EXTRA_EXAMPLES_UNREDACTED.into_iter().map(Uri::from_static);
let expecteds = EXTRA_EXAMPLES_REDACTED.into_iter().map(Uri::from_static);
for (original, expected) in originals.zip(expecteds) {
let output = Label::new(&original.path(), |_| false, Some(GreedyLabel::new(2, 5))).to_string();
let output = Label::new(original.path(), |_| false, Some(GreedyLabel::new(2, 5))).to_string();
assert_eq!(output, expected.path(), "original = {original}");
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -131,7 +131,7 @@ mod tests {
let originals = EXAMPLES.into_iter().chain(QUERY_STRING_EXAMPLES).map(Uri::from_static);
for original in originals {
if let Some(query) = original.query() {
let output = Query::new(&query, |_| QueryMarker::default()).to_string();
let output = Query::new(query, |_| QueryMarker::default()).to_string();
assert_eq!(output, query, "original = {original}");
}
}
Expand All @@ -142,7 +142,7 @@ mod tests {
let originals = QUERY_STRING_EXAMPLES.into_iter().map(Uri::from_static);
let expecteds = ALL_KEYS_QUERY_STRING_EXAMPLES.into_iter().map(Uri::from_static);
for (original, expected) in originals.zip(expecteds) {
let output = Query::new(&original.query().unwrap(), |_| QueryMarker {
let output = Query::new(original.query().unwrap(), |_| QueryMarker {
key: true,
value: false,
})
Expand All @@ -156,7 +156,7 @@ mod tests {
let originals = QUERY_STRING_EXAMPLES.into_iter().map(Uri::from_static);
let expecteds = ALL_VALUES_QUERY_STRING_EXAMPLES.into_iter().map(Uri::from_static);
for (original, expected) in originals.zip(expecteds) {
let output = Query::new(&original.query().unwrap(), |_| QueryMarker {
let output = Query::new(original.query().unwrap(), |_| QueryMarker {
key: false,
value: true,
})
Expand All @@ -170,7 +170,7 @@ mod tests {
let originals = QUERY_STRING_EXAMPLES.into_iter().map(Uri::from_static);
let expecteds = ALL_PAIRS_QUERY_STRING_EXAMPLES.into_iter().map(Uri::from_static);
for (original, expected) in originals.zip(expecteds) {
let output = Query::new(&original.query().unwrap(), |_| QueryMarker { key: true, value: true }).to_string();
let output = Query::new(original.query().unwrap(), |_| QueryMarker { key: true, value: true }).to_string();
assert_eq!(output, expected.query().unwrap(), "original = {original}");
}
}
Expand All @@ -180,7 +180,7 @@ mod tests {
let originals = QUERY_STRING_EXAMPLES.into_iter().map(Uri::from_static);
let expecteds = X_QUERY_STRING_EXAMPLES.into_iter().map(Uri::from_static);
for (original, expected) in originals.zip(expecteds) {
let output = Query::new(&original.query().unwrap(), |key| QueryMarker {
let output = Query::new(original.query().unwrap(), |key| QueryMarker {
key: false,
value: key == "x",
})
Expand Down
4 changes: 2 additions & 2 deletions rust-runtime/aws-smithy-http-server/src/protocols.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ use crate::rejection::MissingContentTypeReason;
use crate::request::RequestParts;

/// Supported protocols.
#[derive(Debug, Clone, Copy, PartialEq)]
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
pub enum Protocol {
RestJson1,
RestXml,
Expand Down Expand Up @@ -190,7 +190,7 @@ mod tests {
);
assert_eq!(found_mime, invalid_mime.parse::<mime::Mime>().ok());
}
_ => panic!("Unexpected `MissingContentTypeReason`: {}", e.to_string()),
_ => panic!("Unexpected `MissingContentTypeReason`: {}", e),
},
}
}
Expand Down
Loading