Skip to content

Commit

Permalink
Update from TestConnector to StaticReplayClient
Browse files Browse the repository at this point in the history
  • Loading branch information
DavidSouther committed Oct 14, 2023
1 parent 0e3c26f commit 9e8a01d
Show file tree
Hide file tree
Showing 15 changed files with 60 additions and 165 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,8 @@ aws-sdk-dynamodb = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "
aws-sdk-rekognition = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-sdk-s3 = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-sdk-sns = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-smithy-client = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = [
"test-util",
] }
aws-smithy-http = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-smithy-runtime = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-smithy-types-convert ={ git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = ["convert-chrono"] }
aws_lambda_events = { version = "0.10.0", features = ["s3", "apigw"], default-features = false }
bytes = "1.4.0"
Expand All @@ -35,6 +33,7 @@ lambda_runtime = "0.8.0"
miniz_oxide = "0.7.1"
pin-project = "1.0.12"
pipe = "0.4.0"
sdk-examples-test-utils = { path = "../../test-utils" }
serde = { version = "1.0.159", features = ["derive"] }
serde_json = "1.0.95"
streaming-zip = "0.5.0"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -104,10 +104,9 @@ pub async fn handler(

#[cfg(test)]
mod test {
use sdk_examples_test_utils::single_shot_client;
use serde_json::json;

use crate::single_shot_client;

use super::{get_labels, Labels};

#[tokio::test]
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
pub mod chunked_uploader;
pub mod common;
pub mod handlers;
pub mod test_utils;
pub mod uploader;

This file was deleted.

This file was deleted.

1 change: 1 addition & 0 deletions rust_dev_preview/cross_service/rest_ses/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ aws-config = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next"
aws-sdk-cloudwatchlogs = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-sdk-rdsdata = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-sdk-ses = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-smithy-runtime = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
chrono = { version = "0.4.22", default-features = false, features = [
"clock",
"serde",
Expand Down
17 changes: 7 additions & 10 deletions rust_dev_preview/cross_service/rest_ses/src/client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -64,23 +64,20 @@ impl RdsClient {

#[cfg(test)]
mod rds_client_for_test {
use aws_smithy_http::body::SdkBody;
use aws_smithy_runtime::client::http::test_util::ReplayEvent;
use secrecy::Secret;

use super::RdsClient;
impl RdsClient {
pub fn for_test(
pairs: Vec<(
http::request::Request<SdkBody>,
http::response::Response<SdkBody>,
)>,
) -> Self {
pub fn for_test(pairs: Vec<ReplayEvent>) -> Self {
RdsClient {
client: aws_sdk_rdsdata::Client::from_conf(
sdk_examples_test_utils::client_config!(aws_sdk_rdsdata)
.http_connector(aws_smithy_client::test_connection::TestConnection::new(
pairs,
))
.http_client(
aws_smithy_runtime::client::http::test_util::StaticReplayClient::new(
pairs,
),
)
.build(),
),
secret_arn: Secret::from("secret".to_string()),
Expand Down
23 changes: 9 additions & 14 deletions rust_dev_preview/examples/dynamodb/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,30 +12,25 @@ edition = "2021"

[dependencies]
aws-config = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-sdk-dynamodb = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-http = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-smithy-client = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = [
"client-hyper",
"rustls",
"rt-tokio",
] }
aws-smithy-http = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = [
"rt-tokio",
] }
aws-sdk-dynamodb = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-smithy-client = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = [ "client-hyper", "rustls", "rt-tokio", ] }
aws-smithy-http = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = [ "rt-tokio", ] }
aws-smithy-runtime = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = ["test-util"] }
aws-smithy-types = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
axum = "0.5.16"
http = "0.2.5"
clap = { version = "~4.2", features = ["derive"] }
futures = "0.3"
http = "0.2.5"
log = "0.4.17"
rand = "0.8.3"
sdk-examples-test-utils = { path = "../../test-utils" }
serde = {version = "1.0", features = ["derive"]}
serde_json = "1"
serde_dynamo = { version = "4", features = ["aws-sdk-dynamodb+0_22"] }
clap = { version = "~4.2", features = ["derive"] }
tracing = "0.1"
serde_json = "1"
thiserror = "1.0"
tokio = { version = "1.20.1", features = ["full"] }
tokio-stream = "0.1.8"
tower-http = { version = "0.3.0", features = ["cors"] }
tracing-subscriber = { version = "0.3.15", features = ["env-filter"] }
tracing = "0.1"
tracing-subscriber = { version = "0.3.15", features = ["env-filter"] }
8 changes: 4 additions & 4 deletions rust_dev_preview/examples/dynamodb/src/scenario/list.rs
Original file line number Diff line number Diff line change
Expand Up @@ -119,8 +119,8 @@ mod test_list_more_tables {
async fn test_list_tables_iterative() {
let client = aws_sdk_dynamodb::Client::from_conf(
sdk_examples_test_utils::client_config!(aws_sdk_dynamodb)
.http_connector(aws_smithy_client::test_connection::TestConnection::new(
vec![
.http_client(
aws_smithy_runtime::client::http::test_util::StaticReplayClient::new(vec![
test_event!(
"",
(
Expand All @@ -136,8 +136,8 @@ mod test_list_more_tables {
)
),
test_event!("", (200, r#"{"TableNames":["g","h"]}"#)),
],
))
]),
)
.build(),
);

Expand Down
1 change: 1 addition & 0 deletions rust_dev_preview/examples/s3/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ aws-smithy-client = { git = "https://github.com/awslabs/aws-sdk-rust", branch =
"test-util",
] }
aws-smithy-http = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = ["rt-tokio"] }
aws-smithy-runtime = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-smithy-types = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
sdk-examples-test-utils = { path = "../../test-utils" }
bytes = "1.4.0"
Expand Down
6 changes: 3 additions & 3 deletions rust_dev_preview/examples/s3/src/s3-service-lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -163,7 +163,7 @@ pub async fn create_bucket(
mod test {
use std::env::temp_dir;

use aws_smithy_client::test_connection::TestConnection;
use aws_smithy_runtime::client::http::test_util::StaticReplayClient;
use sdk_examples_test_utils::{client_config, single_shot_client, test_event};
use tokio::{fs::File, io::AsyncWriteExt};
use uuid::Uuid;
Expand All @@ -190,7 +190,7 @@ mod test {
async fn test_delete_objects() {
let client = aws_sdk_s3::Client::from_conf(
client_config!(aws_sdk_s3)
.http_connector(TestConnection::new(vec![
.http_client(StaticReplayClient::new(vec![
// client.list_objects_v2().bucket(bucket_name)
test_event!(
r#""#,
Expand Down Expand Up @@ -241,7 +241,7 @@ mod test {
async fn test_delete_objects_failed() {
let client = aws_sdk_s3::Client::from_conf(
client_config!(aws_sdk_s3)
.http_connector(TestConnection::new(vec![
.http_client(StaticReplayClient::new(vec![
// client.list_objects_v2().bucket(bucket_name)
test_event!(
r#""#,
Expand Down
25 changes: 25 additions & 0 deletions rust_dev_preview/run_all.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
#!/usr/bin/env bash

DIRS=(
cross_service
examples
lambda
webassembly
)

# Clean Cargo.log
rm rust_dev_preview/**/Cargo.lock

export RUSTFLAGS="-D warnings" ;
export APP_ENVIRONMENT="test"

FAIL=()
for f in ${DIRS[@]} ; do
"$HOME/.cargo/bin/cargo" fmt --manifest-path rust_dev_preview/$f/Cargo.toml --all --check || FAIL+=("fmt $f")
"$HOME/.cargo/bin/cargo" clippy --manifest-path rust_dev_preview/$f/Cargo.toml --all || FAIL+=("clippy $f")
"$HOME/.cargo/bin/cargo" test --manifest-path rust_dev_preview/$f/Cargo.toml --all || FAIL+=("clippy $f")
done

echo $FAIL

exit "${#FAIL[@]}"
5 changes: 2 additions & 3 deletions rust_dev_preview/test-utils/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,9 @@ edition = "2021"

[dependencies]
aws-config = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-smithy-client = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = [
"test-util",
] }
aws-smithy-client = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = [ "test-util", ] }
aws-smithy-http = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next" }
aws-smithy-runtime = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next", features = ["test-util"] }
aws-types = { git = "https://github.com/awslabs/aws-sdk-rust", branch = "next"}
http = "0.2"

Expand Down
6 changes: 3 additions & 3 deletions rust_dev_preview/test-utils/src/macros.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ macro_rules! test_event {
$res:expr
)
) => {{
(
aws_smithy_runtime::client::http::test_util::ReplayEvent::new(
http::Request::builder()
.body(aws_smithy_http::body::SdkBody::from($req))
.unwrap(),
Expand All @@ -38,7 +38,7 @@ macro_rules! test_event {
$res:expr
)
) => {{
(
aws_smithy_runtime::client::http::test_util::ReplayEvent::new(
http::Request::builder()
.body(aws_smithy_http::body::SdkBody::from($req))
.unwrap(),
Expand Down Expand Up @@ -73,7 +73,7 @@ macro_rules! single_shot_client {
($sdk_crate:ident, $req:expr, $status:expr, $res_headers:expr, $res:expr) => {{
$sdk_crate::Client::from_conf(
sdk_examples_test_utils::client_config!($sdk_crate)
.http_connector(sdk_examples_test_utils::single_shot(
.http_client(sdk_examples_test_utils::single_shot(
$req.into(),
($status.try_into().unwrap(), $res_headers, $res.into()),
))
Expand Down
4 changes: 2 additions & 2 deletions rust_dev_preview/test-utils/src/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@ pub mod macros;
pub fn single_shot(
req: SdkBody,
res: (http::StatusCode, Vec<(&str, &str)>, SdkBody),
) -> aws_smithy_client::test_connection::TestConnection<SdkBody> {
aws_smithy_client::test_connection::TestConnection::new(vec![
) -> aws_smithy_runtime::client::http::test_util::StaticReplayClient {
aws_smithy_runtime::client::http::test_util::StaticReplayClient::new(vec![
(test_event!(req, (res.0, res.1, res.2))),
])
}

0 comments on commit 9e8a01d

Please sign in to comment.