From df025dbc7d490799c4bbf7165e0f21f11e831cb6 Mon Sep 17 00:00:00 2001 From: Russell Cohen Date: Thu, 12 Oct 2023 14:35:09 -0400 Subject: [PATCH] Clear out external-types issue --- .../aws-inlineable/external-types.toml | 1 + .../aws-inlineable/src/presigning.rs | 22 +++---------------- .../polly/tests/presigning.rs | 2 +- .../integration-tests/s3/tests/presigning.rs | 12 +++++----- examples/pokemon-service-common/src/lib.rs | 2 +- 5 files changed, 13 insertions(+), 26 deletions(-) diff --git a/aws/rust-runtime/aws-inlineable/external-types.toml b/aws/rust-runtime/aws-inlineable/external-types.toml index 0d2b9f397ca..62904a6e4c4 100644 --- a/aws/rust-runtime/aws-inlineable/external-types.toml +++ b/aws/rust-runtime/aws-inlineable/external-types.toml @@ -1,6 +1,7 @@ allowed_external_types = [ "aws_credential_types::provider::ProvideCredentials", "aws_smithy_http::*", + "aws_smithy_runtime_api::*", "http::error::Error", "http::header::map::HeaderMap", diff --git a/aws/rust-runtime/aws-inlineable/src/presigning.rs b/aws/rust-runtime/aws-inlineable/src/presigning.rs index 3829e6b9686..76adace2639 100644 --- a/aws/rust-runtime/aws-inlineable/src/presigning.rs +++ b/aws/rust-runtime/aws-inlineable/src/presigning.rs @@ -13,7 +13,6 @@ //! Only operations that support presigning have the `presigned()` method on them. use aws_smithy_runtime_api::box_error::BoxError; -use aws_smithy_runtime_api::client::http::request::Headers; use aws_smithy_runtime_api::client::orchestrator::HttpRequest; use std::fmt; use std::time::{Duration, SystemTime}; @@ -195,8 +194,8 @@ impl PresignedRequest { /// Returns any HTTP headers that need to go along with the request, except for `Host`, /// which should be sent based on the endpoint in the URI by the HTTP client rather than /// added directly. - pub fn headers(&self) -> &Headers { - self.0.headers() + pub fn headers(&self) -> impl Iterator { + self.0.headers().iter() } /// Given a body, convert this `PresignedRequest` into an `http::Request` @@ -210,22 +209,7 @@ impl fmt::Debug for PresignedRequest { f.debug_struct("PresignedRequest") .field("method", &self.method()) .field("uri", &self.uri()) - .field("headers", self.headers()) + .field("headers", self.0.headers()) .finish() } } - -/* -impl From for http::request::Builder { - fn from(req: PresignedRequest) -> Self { - let mut builder = http::request::Builder::new() - .uri(req.uri()) - .method(req.method()); - - if let Some(headers) = builder.headers_mut() { - *headers = req.headers().clone(); - } - - builder - } -}*/ diff --git a/aws/sdk/integration-tests/polly/tests/presigning.rs b/aws/sdk/integration-tests/polly/tests/presigning.rs index 790a23c6c7a..f6841b932ae 100644 --- a/aws/sdk/integration-tests/polly/tests/presigning.rs +++ b/aws/sdk/integration-tests/polly/tests/presigning.rs @@ -56,5 +56,5 @@ async fn test_presigning() { ][..], &query_params ); - assert!(presigned.headers().is_empty()); + assert_eq!(presigned.headers().count(), 0); } diff --git a/aws/sdk/integration-tests/s3/tests/presigning.rs b/aws/sdk/integration-tests/s3/tests/presigning.rs index b97c9480fb2..768dd563bb5 100644 --- a/aws/sdk/integration-tests/s3/tests/presigning.rs +++ b/aws/sdk/integration-tests/s3/tests/presigning.rs @@ -4,6 +4,7 @@ */ use aws_sdk_s3 as s3; +use std::collections::HashMap; use futures_util::future::FutureExt; use futures_util::Future; @@ -99,7 +100,7 @@ async fn test_presigning() { ][..], &query_params ); - assert!(presigned.headers().is_empty()); + assert_eq!(presigned.headers().count(), 0); } #[tokio::test] @@ -140,13 +141,14 @@ async fn test_presigning_with_payload_headers() { ][..], &query_params ); + let headers = presigned.headers().collect::>(); assert_eq!( - presigned.headers().get(CONTENT_TYPE), - Some("application/x-test") + headers.get(CONTENT_TYPE.as_str()), + Some(&"application/x-test") ); - assert_eq!(presigned.headers().get(CONTENT_LENGTH), Some("12345")); - assert_eq!(presigned.headers().iter().count(), 2); + assert_eq!(headers.get(CONTENT_LENGTH.as_str()), Some(&"12345")); + assert_eq!(headers.len(), 2); } #[tokio::test] diff --git a/examples/pokemon-service-common/src/lib.rs b/examples/pokemon-service-common/src/lib.rs index 54503d4d613..c4c8bc4e752 100644 --- a/examples/pokemon-service-common/src/lib.rs +++ b/examples/pokemon-service-common/src/lib.rs @@ -334,7 +334,7 @@ pub async fn stream_pokemon_radio( .body(SdkBody::empty()) .unwrap() .try_into() - .uwrap(), + .unwrap(), ) .await .unwrap();