From e5b80c10c5711c764a57e0bb23386886a7699260 Mon Sep 17 00:00:00 2001 From: "Herman J. Radtke III" Date: Sun, 12 Nov 2023 18:59:44 -0500 Subject: [PATCH] test: add test to ensure HeaderMap::iter safety --- tests/header_map.rs | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/tests/header_map.rs b/tests/header_map.rs index f2beba08..9859b0a8 100644 --- a/tests/header_map.rs +++ b/tests/header_map.rs @@ -190,7 +190,7 @@ fn drain_entry() { assert_eq!(vals[1], "world2"); } - assert_eq!(5-2+1, headers.len()); + assert_eq!(5 - 2 + 1, headers.len()); } #[test] @@ -427,7 +427,6 @@ fn value_htab() { HeaderValue::from_str("hello\tworld").unwrap(); } - #[test] fn remove_multiple_a() { let mut headers = HeaderMap::new(); @@ -570,7 +569,8 @@ fn remove_entry_multi_3_others() { } fn remove_all_values(headers: &mut HeaderMap, key: K) -> Vec - where K: IntoHeaderName +where + K: IntoHeaderName, { match headers.entry(key) { Entry::Occupied(e) => e.remove_entry_mult().1.collect(), @@ -629,10 +629,22 @@ fn remove_entry_3_others_b() { } fn remove_values(headers: &mut HeaderMap, key: K) -> Option - where K: IntoHeaderName +where + K: IntoHeaderName, { match headers.entry(key) { Entry::Occupied(e) => Some(e.remove_entry().1), Entry::Vacant(_) => None, } } + +#[test] +fn ensure_miri_sharedreadonly_not_violated() { + let mut headers = HeaderMap::new(); + headers.insert( + HeaderName::from_static("chunky-trailer"), + HeaderValue::from_static("header data"), + ); + + let _foo = &headers.iter().next(); +}