From cdaca590af2d26a5fe5182a98612b68c0e462408 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Sun, 22 Oct 2023 02:46:38 +0900 Subject: [PATCH 01/22] feat: define aws-sdk feature --- Cargo.lock | 483 ++++++++++++++++++++++++++++++++++++++++++++-- makefile | 7 +- raiden/Cargo.toml | 9 +- 3 files changed, 483 insertions(+), 16 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 289d32cb..829c14b8 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -69,6 +69,254 @@ version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" +[[package]] +name = "aws-credential-types" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "70a66ac8ef5fa9cf01c2d999f39d16812e90ec1467bd382cbbb74ba23ea86201" +dependencies = [ + "aws-smithy-async", + "aws-smithy-types", + "fastrand", + "tokio", + "tracing", + "zeroize", +] + +[[package]] +name = "aws-http" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3e626370f9ba806ae4c439e49675fd871f5767b093075cdf4fef16cac42ba900" +dependencies = [ + "aws-credential-types", + "aws-smithy-http", + "aws-smithy-types", + "aws-types", + "bytes", + "http", + "http-body", + "lazy_static", + "percent-encoding", + "pin-project-lite", + "tracing", +] + +[[package]] +name = "aws-runtime" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "07ac5cf0ff19c1bca0cea7932e11b239d1025a45696a4f44f72ea86e2b8bdd07" +dependencies = [ + "aws-credential-types", + "aws-http", + "aws-sigv4", + "aws-smithy-async", + "aws-smithy-http", + "aws-smithy-runtime-api", + "aws-smithy-types", + "aws-types", + "fastrand", + "http", + "percent-encoding", + "tracing", + "uuid", +] + +[[package]] +name = "aws-sdk-dynamodb" +version = "0.33.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c6c39120bb76fe32e13d4c0e9be67f3732f80ee63faee2c74ebf9ade4705b106" +dependencies = [ + "aws-credential-types", + "aws-http", + "aws-runtime", + "aws-smithy-async", + "aws-smithy-client", + "aws-smithy-http", + "aws-smithy-json", + "aws-smithy-runtime", + "aws-smithy-runtime-api", + "aws-smithy-types", + "aws-types", + "bytes", + "fastrand", + "http", + "regex", + "tokio-stream", + "tracing", +] + +[[package]] +name = "aws-sigv4" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b7b28f4910bb956b7ab320b62e98096402354eca976c587d1eeccd523d9bac03" +dependencies = [ + "aws-smithy-http", + "form_urlencoded", + "hex", + "hmac 0.12.1", + "http", + "once_cell", + "percent-encoding", + "regex", + "sha2 0.10.8", + "time 0.3.30", + "tracing", +] + +[[package]] +name = "aws-smithy-async" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2cdb73f85528b9d19c23a496034ac53703955a59323d581c06aa27b4e4e247af" +dependencies = [ + "futures-util", + "pin-project-lite", + "tokio", + "tokio-stream", +] + +[[package]] +name = "aws-smithy-client" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c27b2756264c82f830a91cb4d2d485b2d19ad5bea476d9a966e03d27f27ba59a" +dependencies = [ + "aws-smithy-async", + "aws-smithy-http", + "aws-smithy-http-tower", + "aws-smithy-types", + "bytes", + "fastrand", + "http", + "http-body", + "hyper", + "hyper-rustls 0.24.1", + "lazy_static", + "pin-project-lite", + "rustls 0.21.7", + "tokio", + "tower", + "tracing", +] + +[[package]] +name = "aws-smithy-http" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "54cdcf365d8eee60686885f750a34c190e513677db58bbc466c44c588abf4199" +dependencies = [ + "aws-smithy-types", + "bytes", + "bytes-utils", + "futures-core", + "http", + "http-body", + "hyper", + "once_cell", + "percent-encoding", + "pin-project-lite", + "pin-utils", + "tokio", + "tokio-util", + "tracing", +] + +[[package]] +name = "aws-smithy-http-tower" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "822de399d0ce62829a69dfa8c5cd08efdbe61a7426b953e2268f8b8b52a607bd" +dependencies = [ + "aws-smithy-http", + "aws-smithy-types", + "bytes", + "http", + "http-body", + "pin-project-lite", + "tower", + "tracing", +] + +[[package]] +name = "aws-smithy-json" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4fb1e7ab8fa7ad10c193af7ae56d2420989e9f4758bf03601a342573333ea34f" +dependencies = [ + "aws-smithy-types", +] + +[[package]] +name = "aws-smithy-runtime" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "745e096b3553e7e0f40622aa04971ce52765af82bebdeeac53aa6fc82fe801e6" +dependencies = [ + "aws-smithy-async", + "aws-smithy-client", + "aws-smithy-http", + "aws-smithy-runtime-api", + "aws-smithy-types", + "bytes", + "fastrand", + "http", + "http-body", + "once_cell", + "pin-project-lite", + "pin-utils", + "tokio", + "tracing", +] + +[[package]] +name = "aws-smithy-runtime-api" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "93d0ae0c9cfd57944e9711ea610b48a963fb174a53aabacc08c5794a594b1d02" +dependencies = [ + "aws-smithy-async", + "aws-smithy-http", + "aws-smithy-types", + "bytes", + "http", + "tokio", + "tracing", +] + +[[package]] +name = "aws-smithy-types" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d90dbc8da2f6be461fa3c1906b20af8f79d14968fe47f2b7d29d086f62a51728" +dependencies = [ + "base64-simd", + "itoa", + "num-integer", + "ryu", + "serde", + "time 0.3.30", +] + +[[package]] +name = "aws-types" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "85aa0451bf8af1bf22a4f028d5d28054507a14be43cb8ac0597a8471fba9edfe" +dependencies = [ + "aws-credential-types", + "aws-smithy-async", + "aws-smithy-client", + "aws-smithy-http", + "aws-smithy-types", + "http", + "rustc_version", + "tracing", +] + [[package]] name = "backtrace" version = "0.3.69" @@ -96,6 +344,16 @@ version = "0.21.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9ba43ea6f343b788c8764558649e08df62f86c6ef251fdaeb1ffd010a9ae50a2" +[[package]] +name = "base64-simd" +version = "0.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "339abbe78e73178762e23bea9dfd08e697eb3f3301cd4be981c0f78ba5859195" +dependencies = [ + "outref", + "vsimd", +] + [[package]] name = "bitflags" version = "1.3.2" @@ -117,6 +375,15 @@ dependencies = [ "generic-array", ] +[[package]] +name = "block-buffer" +version = "0.10.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3078c7629b62d3f0439517fa394996acacc5cbc91c5a20d8c658e77abd503a71" +dependencies = [ + "generic-array", +] + [[package]] name = "bumpalo" version = "3.14.0" @@ -132,6 +399,16 @@ dependencies = [ "serde", ] +[[package]] +name = "bytes-utils" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e47d3a8076e283f3acd27400535992edb3ba4b5bb72f8891ad8fbe7932a7d4b9" +dependencies = [ + "bytes", + "either", +] + [[package]] name = "cc" version = "1.0.83" @@ -209,6 +486,16 @@ dependencies = [ "cfg-if", ] +[[package]] +name = "crypto-common" +version = "0.1.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1bfb12502f3fc46cca1bb51ac28df9d618d813cdc3d2f25b9fe775a34af26bb3" +dependencies = [ + "generic-array", + "typenum", +] + [[package]] name = "crypto-mac" version = "0.11.1" @@ -243,6 +530,17 @@ dependencies = [ "generic-array", ] +[[package]] +name = "digest" +version = "0.10.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292" +dependencies = [ + "block-buffer 0.10.4", + "crypto-common", + "subtle", +] + [[package]] name = "dirs-next" version = "2.0.0" @@ -264,6 +562,12 @@ dependencies = [ "winapi", ] +[[package]] +name = "either" +version = "1.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a26ae43d7bcc3b814de94796a5e736d4029efb0ee900c12e2d54c993ad1a1e07" + [[package]] name = "errno" version = "0.3.5" @@ -301,6 +605,15 @@ version = "0.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" +[[package]] +name = "form_urlencoded" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a62bc1cf6f830c2ec14a513a9fb124d0a213a629668a4186f329db21fe045652" +dependencies = [ + "percent-encoding", +] + [[package]] name = "fuchsia-cprng" version = "0.1.1" @@ -484,7 +797,16 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2a2a2320eb7ec0ebe8da8f744d7812d9fc4cb4d09344ac01898dbcb6a20ae69b" dependencies = [ "crypto-mac", - "digest", + "digest 0.9.0", +] + +[[package]] +name = "hmac" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6c49c37c09c17a53d937dfbb742eb3a961d65a994e6bcdcf37e7399d0cc8ab5e" +dependencies = [ + "digest 0.10.7", ] [[package]] @@ -554,10 +876,26 @@ dependencies = [ "http", "hyper", "log", - "rustls", + "rustls 0.20.9", + "rustls-native-certs", + "tokio", + "tokio-rustls 0.23.4", +] + +[[package]] +name = "hyper-rustls" +version = "0.24.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8d78e1e73ec14cf7375674f74d7dde185c8206fd9dea6fb6295e8a98098aaa97" +dependencies = [ + "futures-util", + "http", + "hyper", + "log", + "rustls 0.21.7", "rustls-native-certs", "tokio", - "tokio-rustls", + "tokio-rustls 0.24.1", ] [[package]] @@ -685,8 +1023,8 @@ version = "0.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7b5a279bb9607f9f53c22d496eade00d138d1bdcccd07d74650387cf94942a15" dependencies = [ - "block-buffer", - "digest", + "block-buffer 0.9.0", + "digest 0.9.0", "opaque-debug", ] @@ -744,6 +1082,16 @@ dependencies = [ "winapi", ] +[[package]] +name = "num-integer" +version = "0.1.45" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "225d3389fb3509a24c93f5c29eb6bde2586b98d9f016636dff58d7c6f7569cd9" +dependencies = [ + "autocfg", + "num-traits", +] + [[package]] name = "num-traits" version = "0.2.17" @@ -828,6 +1176,12 @@ dependencies = [ "vcpkg", ] +[[package]] +name = "outref" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4030760ffd992bef45b0ae3f10ce1aba99e33464c90d14dd7c039884963ddc7a" + [[package]] name = "overload" version = "0.1.1" @@ -865,6 +1219,26 @@ version = "2.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9b2a4787296e9989611394c33f193f676704af1686e70b8f8033ab5ba9a35a94" +[[package]] +name = "pin-project" +version = "1.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fda4ed1c6c173e3fc7a83629421152e01d7b1f9b7f65fb301e490e8cfc656422" +dependencies = [ + "pin-project-internal", +] + +[[package]] +name = "pin-project-internal" +version = "1.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4359fd9c9171ec6e8c62926d6faaf553a8dc3f64e1507e76da7911b4f6a04405" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + [[package]] name = "pin-project-lite" version = "0.2.13" @@ -958,6 +1332,8 @@ name = "raiden" version = "0.1.0" dependencies = [ "again", + "aws-sdk-dynamodb", + "aws-smithy-types", "base64 0.21.4", "pretty_assertions", "raiden", @@ -1192,7 +1568,7 @@ dependencies = [ "futures", "http", "hyper", - "hyper-rustls", + "hyper-rustls 0.23.2", "hyper-tls", "lazy_static", "log", @@ -1246,10 +1622,10 @@ dependencies = [ "base64 0.13.1", "bytes", "chrono", - "digest", + "digest 0.9.0", "futures", "hex", - "hmac", + "hmac 0.11.0", "http", "hyper", "log", @@ -1259,7 +1635,7 @@ dependencies = [ "rusoto_credential", "rustc_version", "serde", - "sha2", + "sha2 0.9.9", "tokio", ] @@ -1322,6 +1698,18 @@ dependencies = [ "webpki", ] +[[package]] +name = "rustls" +version = "0.21.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cd8d6c9f025a446bc4d18ad9632e69aec8f287aa84499ee335599fabd20c3fd8" +dependencies = [ + "log", + "ring 0.16.20", + "rustls-webpki", + "sct", +] + [[package]] name = "rustls-native-certs" version = "0.6.3" @@ -1343,6 +1731,16 @@ dependencies = [ "base64 0.21.4", ] +[[package]] +name = "rustls-webpki" +version = "0.101.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c7d5dece342910d9ba34d259310cae3e0154b873b35408b787b59bce53d34fe" +dependencies = [ + "ring 0.16.20", + "untrusted 0.7.1", +] + [[package]] name = "ryu" version = "1.0.15" @@ -1460,13 +1858,24 @@ version = "0.9.9" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4d58a1e1bf39749807d89cf2d98ac2dfa0ff1cb3faa38fbb64dd88ac8013d800" dependencies = [ - "block-buffer", + "block-buffer 0.9.0", "cfg-if", "cpufeatures", - "digest", + "digest 0.9.0", "opaque-debug", ] +[[package]] +name = "sha2" +version = "0.10.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "793db75ad2bcafc3ffa7c68b215fee268f537982cd901d132f89c6343f3a3dc8" +dependencies = [ + "cfg-if", + "cpufeatures", + "digest 0.10.7", +] + [[package]] name = "sharded-slab" version = "0.1.7" @@ -1694,11 +2103,32 @@ version = "0.23.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c43ee83903113e03984cb9e5cebe6c04a5116269e900e3ddba8f068a62adda59" dependencies = [ - "rustls", + "rustls 0.20.9", "tokio", "webpki", ] +[[package]] +name = "tokio-rustls" +version = "0.24.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c28327cf380ac148141087fbfb9de9d7bd4e84ab5d2c28fbc911d753de8a7081" +dependencies = [ + "rustls 0.21.7", + "tokio", +] + +[[package]] +name = "tokio-stream" +version = "0.1.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "397c988d37662c7dda6d2208364a706264bf3d6138b11d436cbac0ad38832842" +dependencies = [ + "futures-core", + "pin-project-lite", + "tokio", +] + [[package]] name = "tokio-util" version = "0.7.9" @@ -1713,6 +2143,28 @@ dependencies = [ "tracing", ] +[[package]] +name = "tower" +version = "0.4.13" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b8fa9be0de6cf49e536ce1851f987bd21a43b771b09473c3549a6c853db37c1c" +dependencies = [ + "futures-core", + "futures-util", + "pin-project", + "pin-project-lite", + "tokio", + "tower-layer", + "tower-service", + "tracing", +] + +[[package]] +name = "tower-layer" +version = "0.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c20c8dbed6283a09604c3e69b4b7eeb54e298b8a600d4d5ecb5ad39de609f1d0" + [[package]] name = "tower-service" version = "0.3.2" @@ -1725,6 +2177,7 @@ version = "0.1.39" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ee2ef2af84856a50c1d430afce2fdded0a4ec7eda868db86409b4543df0797f9" dependencies = [ + "log", "pin-project-lite", "tracing-attributes", "tracing-core", @@ -1844,6 +2297,12 @@ version = "0.9.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "49874b5167b65d7193b8aba1567f5c7d93d001cafc34600cee003eda787e483f" +[[package]] +name = "vsimd" +version = "0.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5c3082ca00d5a5ef149bb8b555a72ae84c9c59f7250f013ac822ac2e49b19c64" + [[package]] name = "want" version = "0.3.1" diff --git a/makefile b/makefile index d89c27fb..00352003 100644 --- a/makefile +++ b/makefile @@ -9,16 +9,19 @@ dynamo: test: make dynamo cargo test -- --test-threads=1 + cargo test --no-default-features --features aws-sdk -- --test-threads=1 .PHONY: lint lint: cargo clippy --all-targets -- -D warnings - cargo clippy --all-targets --no-default-features --features rustls -- -D warnings cargo clippy --all-targets --features tracing -- -D warnings + cargo clippy --all-targets --no-default-features --features rustls -- -D warnings + cargo clippy --all-targets --no-default-features --features aws-sdk -- -D warnings .PHONY: check-deps check-deps: cargo machete || echo cargo +nightly udeps --all-targets - cargo +nightly udeps --all-targets --no-default-features --features rustls cargo +nightly udeps --all-targets --features tracing + cargo +nightly udeps --all-targets --no-default-features --features rustls + cargo +nightly udeps --all-targets --no-default-features --features aws-sdk diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index 5f079de9..c2499a56 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -8,6 +8,8 @@ edition = "2018" [dependencies] again = "0.1" +aws-sdk-dynamodb = { version = "0.33.0", optional = true } +aws-smithy-types = { version = "0.56.1", optional = true } base64 = "^0.21" raiden-derive = { version = "*", path = "../raiden-derive" } rusoto_core_default = { package = "rusoto_core", version = "0.48", optional = true } @@ -39,6 +41,9 @@ tokio = "1.33.0" tracing-subscriber = { version = "0.3.17", features = ["env-filter", "time"] } [features] -default = ["rusoto_core_default", "rusoto_dynamodb_default"] -rustls = ["rusoto_core_rustls", "rusoto_dynamodb_rustls"] +default = ["rusoto"] +aws-sdk = ["dep:aws-sdk-dynamodb", "dep:aws-smithy-types"] +rusoto = ["rusoto_core_default", "rusoto_dynamodb_default"] +rusoto_rustls = ["rusoto_core_rustls", "rusoto_dynamodb_rustls"] +rustls = ["rusoto_rustls"] tracing = ["dep:tracing", "raiden-derive/tracing"] From 0f30d55213fecd76eb11408777edb0462f2ab0d7 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Thu, 26 Oct 2023 23:26:48 +0900 Subject: [PATCH 02/22] chore: add implementation for aws-sdk-rust --- Cargo.lock | 119 ++++++ raiden/Cargo.toml | 17 +- raiden/src/aws_sdk/errors.rs | 314 +++++++++++++++ raiden/src/aws_sdk/mod.rs | 325 +++++++++++++++ raiden/src/aws_sdk/ops/batch_delete.rs | 123 ++++++ raiden/src/aws_sdk/ops/batch_get.rs | 148 +++++++ raiden/src/aws_sdk/ops/get.rs | 115 ++++++ raiden/src/aws_sdk/ops/mod.rs | 8 + raiden/src/aws_sdk/ops/put.rs | 115 ++++++ raiden/src/aws_sdk/ops/query.rs | 154 ++++++++ raiden/src/aws_sdk/ops/scan.rs | 185 +++++++++ raiden/src/aws_sdk/ops/transact_write.rs | 99 +++++ raiden/src/aws_sdk/ops/update.rs | 140 +++++++ .../src/aws_sdk/serialize/attribute_value.rs | 150 +++++++ .../aws_sdk/serialize/consumed_capacity.rs | 103 +++++ .../src/aws_sdk/serialize/delete_request.rs | 39 ++ .../serialize/item_collection_metrics.rs | 70 ++++ .../aws_sdk/serialize/keys_and_attributes.rs | 89 +++++ raiden/src/aws_sdk/serialize/mod.rs | 113 ++++++ raiden/src/condition/mod.rs | 26 ++ raiden/src/errors/mod.rs | 326 +++------------ raiden/src/errors/transaction.rs | 4 +- raiden/src/lib.rs | 370 ++--------------- raiden/src/next_token/mod.rs | 9 +- raiden/src/ops/batch_delete.rs | 8 +- raiden/src/ops/batch_get.rs | 8 +- raiden/src/ops/get.rs | 8 +- raiden/src/ops/put.rs | 8 +- raiden/src/ops/query.rs | 8 +- raiden/src/ops/scan.rs | 8 +- raiden/src/ops/transact_write.rs | 107 ----- raiden/src/ops/update.rs | 8 +- raiden/src/retry/mod.rs | 19 +- raiden/src/rusoto/errors.rs | 209 ++++++++++ raiden/src/rusoto/mod.rs | 372 ++++++++++++++++++ raiden/src/rusoto/ops.rs | 116 ++++++ raiden/src/update_expression/add.rs | 7 +- raiden/src/update_expression/delete.rs | 7 +- raiden/src/update_expression/set.rs | 2 +- 39 files changed, 3294 insertions(+), 762 deletions(-) create mode 100644 raiden/src/aws_sdk/errors.rs create mode 100644 raiden/src/aws_sdk/mod.rs create mode 100644 raiden/src/aws_sdk/ops/batch_delete.rs create mode 100644 raiden/src/aws_sdk/ops/batch_get.rs create mode 100644 raiden/src/aws_sdk/ops/get.rs create mode 100644 raiden/src/aws_sdk/ops/mod.rs create mode 100644 raiden/src/aws_sdk/ops/put.rs create mode 100644 raiden/src/aws_sdk/ops/query.rs create mode 100644 raiden/src/aws_sdk/ops/scan.rs create mode 100644 raiden/src/aws_sdk/ops/transact_write.rs create mode 100644 raiden/src/aws_sdk/ops/update.rs create mode 100644 raiden/src/aws_sdk/serialize/attribute_value.rs create mode 100644 raiden/src/aws_sdk/serialize/consumed_capacity.rs create mode 100644 raiden/src/aws_sdk/serialize/delete_request.rs create mode 100644 raiden/src/aws_sdk/serialize/item_collection_metrics.rs create mode 100644 raiden/src/aws_sdk/serialize/keys_and_attributes.rs create mode 100644 raiden/src/aws_sdk/serialize/mod.rs create mode 100644 raiden/src/rusoto/errors.rs create mode 100644 raiden/src/rusoto/mod.rs create mode 100644 raiden/src/rusoto/ops.rs diff --git a/Cargo.lock b/Cargo.lock index 829c14b8..c311af73 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -69,6 +69,36 @@ version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" +[[package]] +name = "aws-config" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fc6b3804dca60326e07205179847f17a4fce45af3a1106939177ad41ac08a6de" +dependencies = [ + "aws-credential-types", + "aws-http", + "aws-sdk-sso", + "aws-sdk-sts", + "aws-smithy-async", + "aws-smithy-client", + "aws-smithy-http", + "aws-smithy-http-tower", + "aws-smithy-json", + "aws-smithy-types", + "aws-types", + "bytes", + "fastrand", + "hex", + "http", + "hyper", + "ring 0.16.20", + "time 0.3.30", + "tokio", + "tower", + "tracing", + "zeroize", +] + [[package]] name = "aws-credential-types" version = "0.56.1" @@ -148,6 +178,54 @@ dependencies = [ "tracing", ] +[[package]] +name = "aws-sdk-sso" +version = "0.30.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "903f888ff190e64f6f5c83fb0f8d54f9c20481f1dc26359bb8896f5d99908949" +dependencies = [ + "aws-credential-types", + "aws-http", + "aws-runtime", + "aws-smithy-async", + "aws-smithy-client", + "aws-smithy-http", + "aws-smithy-json", + "aws-smithy-runtime", + "aws-smithy-runtime-api", + "aws-smithy-types", + "aws-types", + "bytes", + "http", + "regex", + "tokio-stream", + "tracing", +] + +[[package]] +name = "aws-sdk-sts" +version = "0.30.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a47ad6bf01afc00423d781d464220bf69fb6a674ad6629cbbcb06d88cdc2be82" +dependencies = [ + "aws-credential-types", + "aws-http", + "aws-runtime", + "aws-smithy-async", + "aws-smithy-client", + "aws-smithy-http", + "aws-smithy-json", + "aws-smithy-query", + "aws-smithy-runtime", + "aws-smithy-runtime-api", + "aws-smithy-types", + "aws-smithy-xml", + "aws-types", + "http", + "regex", + "tracing", +] + [[package]] name = "aws-sigv4" version = "0.56.1" @@ -250,6 +328,16 @@ dependencies = [ "aws-smithy-types", ] +[[package]] +name = "aws-smithy-query" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "28556a3902091c1f768a34f6c998028921bdab8d47d92586f363f14a4a32d047" +dependencies = [ + "aws-smithy-types", + "urlencoding", +] + [[package]] name = "aws-smithy-runtime" version = "0.56.1" @@ -301,6 +389,15 @@ dependencies = [ "time 0.3.30", ] +[[package]] +name = "aws-smithy-xml" +version = "0.56.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e01d2dedcdd8023043716cfeeb3c6c59f2d447fce365d8e194838891794b23b6" +dependencies = [ + "xmlparser", +] + [[package]] name = "aws-types" version = "0.56.1" @@ -1213,6 +1310,12 @@ dependencies = [ "winapi", ] +[[package]] +name = "paste" +version = "1.0.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "de3145af08024dea9fa9914f381a17b8fc6034dfb00f3a84013f7ff43f29ed4c" + [[package]] name = "percent-encoding" version = "2.3.0" @@ -1332,9 +1435,13 @@ name = "raiden" version = "0.1.0" dependencies = [ "again", + "aws-config", "aws-sdk-dynamodb", + "aws-smithy-http", + "aws-smithy-runtime-api", "aws-smithy-types", "base64 0.21.4", + "paste", "pretty_assertions", "raiden", "raiden-derive", @@ -2270,6 +2377,12 @@ version = "0.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1" +[[package]] +name = "urlencoding" +version = "2.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "daf8dba3b7eb870caf1ddeed7bc9d2a049f3cfdfae7cb521b087cc33ae4c49da" + [[package]] name = "uuid" version = "1.5.0" @@ -2534,6 +2647,12 @@ version = "0.8.19" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0fcb9cbac069e033553e8bb871be2fbdffcab578eb25bd0f7c508cedc6dcd75a" +[[package]] +name = "xmlparser" +version = "0.13.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "66fee0b777b0f5ac1c69bb06d361268faafa61cd4682ae064a171c16c433e9e4" + [[package]] name = "yansi" version = "0.5.1" diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index c2499a56..b44ba891 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -8,9 +8,13 @@ edition = "2018" [dependencies] again = "0.1" +aws-config = { version = "0.56.1", optional = true } aws-sdk-dynamodb = { version = "0.33.0", optional = true } +aws-smithy-http = { version = "0.56.1", optional = true } +aws-smithy-runtime-api = { version = "0.56.1", optional = true } aws-smithy-types = { version = "0.56.1", optional = true } base64 = "^0.21" +paste = "1.0.14" raiden-derive = { version = "*", path = "../raiden-derive" } rusoto_core_default = { package = "rusoto_core", version = "0.48", optional = true } rusoto_core_rustls = { package = "rusoto_core", version = "0.48", default_features = false, features = [ @@ -41,9 +45,16 @@ tokio = "1.33.0" tracing-subscriber = { version = "0.3.17", features = ["env-filter", "time"] } [features] +# default = ["aws-sdk"] default = ["rusoto"] -aws-sdk = ["dep:aws-sdk-dynamodb", "dep:aws-smithy-types"] -rusoto = ["rusoto_core_default", "rusoto_dynamodb_default"] -rusoto_rustls = ["rusoto_core_rustls", "rusoto_dynamodb_rustls"] +aws-sdk = [ + "dep:aws-config", + "dep:aws-sdk-dynamodb", + "dep:aws-smithy-http", + "dep:aws-smithy-runtime-api", + "dep:aws-smithy-types", +] +rusoto = ["dep:rusoto_core_default", "dep:rusoto_dynamodb_default"] +rusoto_rustls = ["dep:rusoto_core_rustls", "dep:rusoto_dynamodb_rustls"] rustls = ["rusoto_rustls"] tracing = ["dep:tracing", "raiden-derive/tracing"] diff --git a/raiden/src/aws_sdk/errors.rs b/raiden/src/aws_sdk/errors.rs new file mode 100644 index 00000000..35dd1c1a --- /dev/null +++ b/raiden/src/aws_sdk/errors.rs @@ -0,0 +1,314 @@ +use aws_smithy_http::result::SdkError; +use aws_smithy_runtime_api::client::orchestrator::HttpResponse; + +use crate::{ + aws_sdk::{ + batch_get_item::BatchGetItemError, batch_write_item::BatchWriteItemError, + delete_item::DeleteItemError, get_item::GetItemError, put_item::PutItemError, + query::QueryError, scan::ScanError, transact_write_items::TransactWriteItemsError, + update_item::UpdateItemError, + }, + RaidenError, RaidenTransactionCancellationReasons, +}; + +type AwsSdkError = SdkError; + +fn into_raiden_error(error: AwsSdkError) -> RaidenError { + match error { + AwsSdkError::ConstructionFailure(err) => RaidenError::Construction(err), + AwsSdkError::TimeoutError(err) => RaidenError::Timeout(err), + AwsSdkError::DispatchFailure(err) => RaidenError::HttpDispatch(err), + AwsSdkError::ResponseError(err) => RaidenError::Unknown(err.into_raw()), + AwsSdkError::ServiceError(err) => { + // AwsSdkError::ServiceError should be handled ( except for E::Unhandled(_)). + RaidenError::Unknown(err.into_raw()) + } + _ => unreachable!( + "Unexpected variant of AwsSdkError detected. Raiden must be handle this variant." + ), + } +} + +impl From> for RaidenError { + fn from(error: AwsSdkError) -> Self { + match &error { + AwsSdkError::ServiceError(err) => match err.err() { + BatchGetItemError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + BatchGetItemError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + BatchGetItemError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + BatchGetItemError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + BatchGetItemError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: AwsSdkError) -> Self { + match &error { + AwsSdkError::ServiceError(err) => match err.err() { + BatchWriteItemError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + BatchWriteItemError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + BatchWriteItemError::ItemCollectionSizeLimitExceededException(err) => { + RaidenError::ItemCollectionSizeLimitExceeded(err.to_string()) + } + BatchWriteItemError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + BatchWriteItemError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + BatchWriteItemError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: AwsSdkError) -> Self { + match &error { + AwsSdkError::ServiceError(err) => match err.err() { + GetItemError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + GetItemError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + GetItemError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + GetItemError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + GetItemError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: AwsSdkError) -> Self { + match &error { + AwsSdkError::ServiceError(err) => match err.err() { + QueryError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + QueryError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + QueryError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + QueryError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + QueryError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: AwsSdkError) -> Self { + match &error { + AwsSdkError::ServiceError(err) => match err.err() { + ScanError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + ScanError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + ScanError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + ScanError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + ScanError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: AwsSdkError) -> Self { + match &error { + AwsSdkError::ServiceError(err) => match err.err() { + PutItemError::ConditionalCheckFailedException(err) => { + RaidenError::ConditionalCheckFailed(err.to_string()) + } + PutItemError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + PutItemError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + PutItemError::ItemCollectionSizeLimitExceededException(err) => { + RaidenError::ItemCollectionSizeLimitExceeded(err.to_string()) + } + PutItemError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + PutItemError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + PutItemError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + PutItemError::TransactionConflictException(err) => { + RaidenError::TransactionConflict(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: AwsSdkError) -> Self { + match &error { + AwsSdkError::ServiceError(err) => match err.err() { + UpdateItemError::ConditionalCheckFailedException(err) => { + RaidenError::ConditionalCheckFailed(err.to_string()) + } + UpdateItemError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + UpdateItemError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + UpdateItemError::ItemCollectionSizeLimitExceededException(err) => { + RaidenError::ItemCollectionSizeLimitExceeded(err.to_string()) + } + UpdateItemError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + UpdateItemError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + UpdateItemError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + UpdateItemError::TransactionConflictException(err) => { + RaidenError::TransactionConflict(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: AwsSdkError) -> Self { + match &error { + AwsSdkError::ServiceError(err) => match err.err() { + DeleteItemError::ConditionalCheckFailedException(err) => { + RaidenError::ConditionalCheckFailed(err.to_string()) + } + DeleteItemError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + DeleteItemError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + DeleteItemError::ItemCollectionSizeLimitExceededException(err) => { + RaidenError::ItemCollectionSizeLimitExceeded(err.to_string()) + } + DeleteItemError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + DeleteItemError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + DeleteItemError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + DeleteItemError::TransactionConflictException(err) => { + RaidenError::TransactionConflict(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: AwsSdkError) -> Self { + match &error { + AwsSdkError::ServiceError(err) => match err.err() { + TransactWriteItemsError::IdempotentParameterMismatchException(err) => { + RaidenError::IdempotentParameterMismatch(err.to_string()) + } + TransactWriteItemsError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + TransactWriteItemsError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + TransactWriteItemsError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + TransactWriteItemsError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + TransactWriteItemsError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + TransactWriteItemsError::TransactionCanceledException(err) => { + let reasons = RaidenTransactionCancellationReasons::from_str( + err.message + .clone() + .unwrap_or_else(|| "transaction canceled".to_owned()) + .as_str(), + ); + let raw_reasons = err.cancellation_reasons.clone().unwrap_or_default(); + + RaidenError::TransactionCanceled { + reasons, + raw_reasons, + } + } + TransactWriteItemsError::TransactionInProgressException(err) => { + RaidenError::TransactionInProgress(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} diff --git a/raiden/src/aws_sdk/mod.rs b/raiden/src/aws_sdk/mod.rs new file mode 100644 index 00000000..aa6bd4aa --- /dev/null +++ b/raiden/src/aws_sdk/mod.rs @@ -0,0 +1,325 @@ +mod errors; +pub(crate) mod ops; +pub(crate) mod serialize; + +use std::collections::{BTreeSet, HashMap, HashSet}; + +pub use aws_sdk_dynamodb::{ + client::*, config::*, error::*, meta::*, operation::*, primitives::*, types::*, +}; +pub use errors::*; + +use crate::{ + AttributeType, AttributeValues, ConversionError, FromAttribute, FromStringSetItem, + IntoAttribute, IntoStringSetItem, RaidenError, +}; + +impl IntoAttribute for AttributeType { + fn into_attr(self) -> AttributeValue { + AttributeValue::S(self.to_string()) + } +} + +impl IntoAttribute for String { + fn into_attr(self) -> AttributeValue { + AttributeValue::S(self) + } +} + +impl FromAttribute for String { + fn from_attr(value: Option) -> Result { + match value { + Some(v) if v.is_null() => Ok("".to_owned()), + Some(AttributeValue::S(s)) => Ok(s), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +impl IntoAttribute for &'_ str { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + AttributeValue::Null(true) + } else { + AttributeValue::S(self.to_owned()) + } + } +} + +impl<'a> IntoAttribute for std::borrow::Cow<'a, str> { + fn into_attr(self) -> AttributeValue { + let s = match self { + std::borrow::Cow::Owned(o) => o, + std::borrow::Cow::Borrowed(b) => b.to_owned(), + }; + + if s.is_empty() { + AttributeValue::Null(true) + } else { + AttributeValue::S(s) + } + } +} + +impl<'a> FromAttribute for std::borrow::Cow<'a, str> { + fn from_attr(value: Option) -> Result { + match value { + Some(v) if v.is_null() => Ok(std::borrow::Cow::Owned("".to_owned())), + Some(AttributeValue::S(s)) => Ok(std::borrow::Cow::Owned(s.to_owned())), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +macro_rules! default_attr_for_num { + ($to: ty) => { + impl IntoAttribute for $to { + fn into_attr(self) -> AttributeValue { + AttributeValue::N(format!("{self}")) + } + } + + impl FromAttribute for $to { + fn from_attr(value: Option) -> Result { + if let Some(AttributeValue::N(n)) = value { + Ok(n.parse().unwrap()) + } else { + Err(ConversionError::ValueIsNone) + } + } + } + }; +} + +pub(crate) use default_attr_for_num; + +impl IntoAttribute for Option { + fn into_attr(self) -> AttributeValue { + if let Some(value) = self { + value.into_attr() + } else { + AttributeValue::Null(true) + } + } +} + +impl FromAttribute for Option { + fn from_attr(value: Option) -> Result { + Ok(if let Some(v) = value { + Some(FromAttribute::from_attr(Some(v))?) + } else { + None + }) + } +} + +impl IntoAttribute for bool { + fn into_attr(self) -> AttributeValue { + AttributeValue::Bool(self) + } +} + +impl FromAttribute for bool { + fn from_attr(value: Option) -> Result { + if let Some(AttributeValue::Bool(v)) = value { + Ok(v) + } else { + Err(ConversionError::ValueIsNone) + } + } +} + +impl IntoAttribute for Vec { + fn into_attr(mut self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + AttributeValue::Null(true) + } else { + AttributeValue::L(self.drain(..).map(|s| s.into_attr()).collect()) + } + } +} + +impl FromAttribute for Vec { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue::L(v)) => { + v.into_iter().map(|item| A::from_attr(Some(item))).collect() + } + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(v) if v.is_null() => Ok(vec![]), + None => Ok(vec![]), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +macro_rules! default_number_hash_set_convertor { + ($to: ty) => { + impl IntoAttribute for std::collections::HashSet<$to> { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + AttributeValue::Ns(Default::default()) + } else { + AttributeValue::Ns(self.into_iter().map(|s| s.to_string()).collect()) + } + } + } + + impl FromAttribute for std::collections::HashSet<$to> { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue::Ns(mut nums)) => { + let mut results: Vec> = nums + .drain(..) + .map(|ns| ns.parse().map_err(|_| ConversionError::ParseInt)) + .collect(); + + results.drain(..).collect() + } + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(v) if v.is_null() => Ok(std::collections::HashSet::new()), + None => Ok(std::collections::HashSet::new()), + _ => Err(ConversionError::ValueIsNone), + } + } + } + }; +} + +pub(crate) use default_number_hash_set_convertor; + +macro_rules! default_number_btree_set_convertor { + ($to: ty) => { + impl IntoAttribute for std::collections::BTreeSet<$to> { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + AttributeValue::Ns(Default::default()) + } else { + AttributeValue::Ns(self.into_iter().map(|s| s.to_string()).collect()) + } + } + } + + impl FromAttribute for std::collections::BTreeSet<$to> { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue::Ns(mut nums)) => { + let mut results: Vec> = nums + .drain(..) + .map(|ns| ns.parse().map_err(|_| ConversionError::ParseInt)) + .collect(); + + results.drain(..).collect() + } + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(v) if v.is_null() => Ok(std::collections::BTreeSet::new()), + None => Ok(std::collections::BTreeSet::new()), + _ => Err(ConversionError::ValueIsNone), + } + } + } + }; +} + +pub(crate) use default_number_btree_set_convertor; + +impl IntoAttribute for HashSet { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + AttributeValue::Ss(Default::default()) + } else { + AttributeValue::Ss(self.into_iter().map(|s| s.into_ss_item()).collect()) + } + } +} + +impl FromAttribute for HashSet { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue::Ss(mut ss)) => ss.drain(..).map(A::from_ss_item).collect(), + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(v) if v.is_null() => Ok(HashSet::new()), + None => Ok(HashSet::new()), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +impl IntoAttribute for BTreeSet { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + AttributeValue::Ss(Default::default()) + } else { + AttributeValue::Ss(self.into_iter().map(|s| s.into_ss_item()).collect()) + } + } +} + +impl FromAttribute for BTreeSet { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue::Ss(mut ss)) => ss.drain(..).map(A::from_ss_item).collect(), + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(v) if v.is_null() => Ok(BTreeSet::new()), + None => Ok(BTreeSet::new()), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +pub fn is_attr_value_empty(a: &AttributeValue) -> bool { + match &a { + &AttributeValue::B(v) => v == &aws_smithy_types::Blob::new(vec![]), + &AttributeValue::Bool(v) => *v == false, + &AttributeValue::Bs(v) => v.is_empty(), + &AttributeValue::L(v) => v.is_empty(), + &AttributeValue::M(v) => v.is_empty(), + &AttributeValue::N(v) => v.is_empty(), + &AttributeValue::Ns(v) => v.is_empty(), + &AttributeValue::Null(_) => a.is_null(), + &AttributeValue::S(v) => v.is_empty(), + &AttributeValue::Ss(v) => v.is_empty(), + _ => false, + } +} + +pub(crate) fn deserialize_attr_value(s: &str) -> Result { + let values: HashMap = match serde_json::from_str(s) { + Ok(v) => v, + Err(_) => return Err(RaidenError::NextTokenDecodeError), + }; + + let mut deserialized: HashMap = HashMap::new(); + + for (k, v) in values { + let v = crate::aws_sdk::serialize::value_to_attribute_value(v) + .map_err(|_| RaidenError::NextTokenDecodeError)?; + + deserialized.insert(k, v); + } + + Ok(deserialized) +} + +pub(crate) fn serialize_attr_values(value: &AttributeValues) -> String { + let m: HashMap = value + .into_iter() + .map(|(k, v)| { + ( + k.to_owned(), + crate::aws_sdk::serialize::attribute_value_to_value(v), + ) + }) + .collect(); + + serde_json::to_string(&m).expect("should serialize") +} diff --git a/raiden/src/aws_sdk/ops/batch_delete.rs b/raiden/src/aws_sdk/ops/batch_delete.rs new file mode 100644 index 00000000..4ca217eb --- /dev/null +++ b/raiden/src/aws_sdk/ops/batch_delete.rs @@ -0,0 +1,123 @@ +use serde::de::{self, Deserialize, Deserializer, MapAccess, Visitor}; +use serde::ser::{Serialize, SerializeStruct, Serializer}; + +use crate::ops::batch_delete::BatchDeleteOutput; + +impl Serialize for BatchDeleteOutput { + fn serialize(&self, serializer: S) -> Result + where + S: Serializer, + { + let mut state = serializer.serialize_struct("BatchDeleteOutput", 2)?; + state.serialize_field( + "consumed_capacity", + &self.consumed_capacity.as_ref().map(|v| { + v.iter() + .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)) + .collect::>() + }), + )?; + state.serialize_field( + "unprocessed_items", + &self + .unprocessed_items + .iter() + .map(|v| crate::aws_sdk::serialize::delete_request_to_value(&v)) + .collect::>(), + )?; + state.end() + } +} + +impl<'de> Deserialize<'de> for BatchDeleteOutput { + fn deserialize(deserializer: D) -> Result + where + D: Deserializer<'de>, + { + #[derive(serde::Deserialize)] + #[serde(field_identifier, rename_all = "snake_case")] + enum Field { + ConsumedCapacity, + UnprocessedItems, + } + + const FIELDS: &'static [&'static str] = &["consumed_capacity", "unprocessed_items"]; + + struct BatchDeleteOutputVisitor; + + impl<'de> Visitor<'de> for BatchDeleteOutputVisitor { + type Value = BatchDeleteOutput; + + fn expecting(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result { + formatter.write_str("struct BatchDeleteOutput") + } + + fn visit_map(self, mut map: V) -> Result + where + V: MapAccess<'de>, + { + let mut consumed_capacity = None; + let mut unprocessed_items = None; + + while let Some(key) = map.next_key()? { + match key { + Field::ConsumedCapacity => { + if consumed_capacity.is_some() { + return Err(de::Error::duplicate_field("consumed_capacity")); + } + + let vs: Option> = map.next_value()?; + + consumed_capacity = if let Some(vs) = vs { + let mut values = vec![]; + + for v in vs { + values.push( + crate::aws_sdk::serialize::value_to_consumed_capacity(v) + .map_err(de::Error::custom)?, + ); + } + + Some(values) + } else { + None + }; + } + Field::UnprocessedItems => { + if unprocessed_items.is_some() { + return Err(de::Error::duplicate_field("unprocessed_items")); + } + + let vs: Option> = map.next_value()?; + + unprocessed_items = if let Some(vs) = vs { + let mut values = vec![]; + + for v in vs { + values.push( + crate::aws_sdk::serialize::value_to_delete_request(v) + .map_err(de::Error::custom)?, + ); + } + + Some(values) + } else { + None + }; + } + } + } + + let unprocessed_items = unprocessed_items + .ok_or_else(|| de::Error::missing_field("unprocessed_items"))?; + + Ok(BatchDeleteOutput { + consumed_capacity, + unprocessed_items, + }) + } + } + + deserializer.deserialize_struct("BatchDeleteOutput", FIELDS, BatchDeleteOutputVisitor) + } +} diff --git a/raiden/src/aws_sdk/ops/batch_get.rs b/raiden/src/aws_sdk/ops/batch_get.rs new file mode 100644 index 00000000..4b006707 --- /dev/null +++ b/raiden/src/aws_sdk/ops/batch_get.rs @@ -0,0 +1,148 @@ +use serde::de::{self, Deserialize, Deserializer, MapAccess, Visitor}; +use serde::ser::{Serialize, SerializeStruct, Serializer}; + +use crate::ops::batch_get::BatchGetOutput; + +impl Serialize for BatchGetOutput +where + T: Serialize, +{ + fn serialize(&self, serializer: S) -> Result + where + S: Serializer, + { + let mut state = serializer.serialize_struct("BatchGetOutput", 3)?; + state.serialize_field( + "consumed_capacity", + &self.consumed_capacity.as_ref().map(|v| { + v.iter() + .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)) + .collect::>() + }), + )?; + state.serialize_field("items", &self.items)?; + state.serialize_field( + "unprocessed_keys", + &self + .unprocessed_keys + .as_ref() + .map(|v| crate::aws_sdk::serialize::keys_and_attributes_to_value(&v)), + )?; + state.end() + } +} + +impl<'de, T> Deserialize<'de> for BatchGetOutput +where + T: Deserialize<'de>, +{ + fn deserialize(deserializer: D) -> Result + where + D: Deserializer<'de>, + { + #[derive(serde::Deserialize)] + #[serde(field_identifier, rename_all = "snake_case")] + enum Field { + ConsumedCapacity, + Items, + UnprocessedKeys, + } + + const FIELDS: &'static [&'static str] = &["consumed_capacity", "items", "unprocessed_keys"]; + + struct BatchGetOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + marker: std::marker::PhantomData>, + lifetime: std::marker::PhantomData<&'de ()>, + } + + impl<'de, T> Visitor<'de> for BatchGetOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + type Value = BatchGetOutput; + + fn expecting(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result { + formatter.write_str("struct BatchGetOutput") + } + + fn visit_map(self, mut map: V) -> Result + where + V: MapAccess<'de>, + { + let mut consumed_capacity = None; + let mut items = None; + let mut unprocessed_keys = None; + + while let Some(key) = map.next_key()? { + match key { + Field::ConsumedCapacity => { + if consumed_capacity.is_some() { + return Err(de::Error::duplicate_field("consumed_capacity")); + } + + let vs: Option> = map.next_value()?; + + consumed_capacity = if let Some(vs) = vs { + let mut values = vec![]; + + for v in vs { + values.push( + crate::aws_sdk::serialize::value_to_consumed_capacity(v) + .map_err(de::Error::custom)?, + ); + } + + Some(values) + } else { + None + }; + } + Field::Items => { + if items.is_some() { + return Err(de::Error::duplicate_field("items")); + } + + items = Some(map.next_value()?); + } + Field::UnprocessedKeys => { + if unprocessed_keys.is_some() { + return Err(de::Error::duplicate_field("unprocessed_keys")); + } + + let v: Option = map.next_value()?; + + unprocessed_keys = if let Some(v) = v { + Some( + crate::aws_sdk::serialize::value_to_keys_and_attributes(v) + .map_err(de::Error::custom)?, + ) + } else { + None + }; + } + } + } + + let items = items.ok_or_else(|| de::Error::missing_field("items"))?; + + Ok(BatchGetOutput { + consumed_capacity, + items, + unprocessed_keys, + }) + } + } + + deserializer.deserialize_struct( + "BatchGetOutput", + FIELDS, + BatchGetOutputVisitor { + marker: std::marker::PhantomData::>, + lifetime: std::marker::PhantomData, + }, + ) + } +} diff --git a/raiden/src/aws_sdk/ops/get.rs b/raiden/src/aws_sdk/ops/get.rs new file mode 100644 index 00000000..77685bc2 --- /dev/null +++ b/raiden/src/aws_sdk/ops/get.rs @@ -0,0 +1,115 @@ +use serde::de::{self, Deserialize, Deserializer, MapAccess, Visitor}; +use serde::ser::{Serialize, SerializeStruct, Serializer}; + +use crate::ops::get::GetOutput; + +impl Serialize for GetOutput +where + T: Serialize, +{ + fn serialize(&self, serializer: S) -> Result + where + S: Serializer, + { + let mut state = serializer.serialize_struct("GetOutput", 2)?; + state.serialize_field( + "consumed_capacity", + &self + .consumed_capacity + .as_ref() + .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + )?; + state.serialize_field("item", &self.item)?; + state.end() + } +} + +impl<'de, T> Deserialize<'de> for GetOutput +where + T: Deserialize<'de>, +{ + fn deserialize(deserializer: D) -> Result + where + D: Deserializer<'de>, + { + #[derive(serde::Deserialize)] + #[serde(field_identifier, rename_all = "snake_case")] + enum Field { + ConsumedCapacity, + Item, + } + + const FIELDS: &'static [&'static str] = &["consumed_capacity", "item"]; + + struct GetOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + marker: std::marker::PhantomData>, + lifetime: std::marker::PhantomData<&'de ()>, + } + + impl<'de, T> Visitor<'de> for GetOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + type Value = GetOutput; + + fn expecting(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result { + formatter.write_str("struct GetOutput") + } + + fn visit_map(self, mut map: V) -> Result + where + V: MapAccess<'de>, + { + let mut consumed_capacity = None; + let mut item = None; + + while let Some(key) = map.next_key()? { + match key { + Field::ConsumedCapacity => { + if consumed_capacity.is_some() { + return Err(de::Error::duplicate_field("consumed_capacity")); + } + + let v: Option = map.next_value()?; + + consumed_capacity = if let Some(v) = v { + Some( + crate::aws_sdk::serialize::value_to_consumed_capacity(v) + .map_err(de::Error::custom)?, + ) + } else { + None + }; + } + Field::Item => { + if item.is_some() { + return Err(de::Error::duplicate_field("item")); + } + + item = Some(map.next_value()?); + } + } + } + + let item = item.ok_or_else(|| de::Error::missing_field("item"))?; + + Ok(GetOutput { + consumed_capacity, + item, + }) + } + } + + deserializer.deserialize_struct( + "GetOutput", + FIELDS, + GetOutputVisitor { + marker: std::marker::PhantomData::>, + lifetime: std::marker::PhantomData, + }, + ) + } +} diff --git a/raiden/src/aws_sdk/ops/mod.rs b/raiden/src/aws_sdk/ops/mod.rs new file mode 100644 index 00000000..7f7dabba --- /dev/null +++ b/raiden/src/aws_sdk/ops/mod.rs @@ -0,0 +1,8 @@ +pub mod batch_delete; +pub mod batch_get; +pub mod get; +pub mod put; +pub mod query; +pub mod scan; +pub mod transact_write; +pub mod update; diff --git a/raiden/src/aws_sdk/ops/put.rs b/raiden/src/aws_sdk/ops/put.rs new file mode 100644 index 00000000..b730f1d7 --- /dev/null +++ b/raiden/src/aws_sdk/ops/put.rs @@ -0,0 +1,115 @@ +use serde::de::{self, Deserialize, Deserializer, MapAccess, Visitor}; +use serde::ser::{Serialize, SerializeStruct, Serializer}; + +use crate::ops::put::PutOutput; + +impl Serialize for PutOutput +where + T: Serialize, +{ + fn serialize(&self, serializer: S) -> Result + where + S: Serializer, + { + let mut state = serializer.serialize_struct("PutOutput", 2)?; + state.serialize_field( + "consumed_capacity", + &self + .consumed_capacity + .as_ref() + .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + )?; + state.serialize_field("item", &self.item)?; + state.end() + } +} + +impl<'de, T> Deserialize<'de> for PutOutput +where + T: Deserialize<'de>, +{ + fn deserialize(deserializer: D) -> Result + where + D: Deserializer<'de>, + { + #[derive(serde::Deserialize)] + #[serde(field_identifier, rename_all = "snake_case")] + enum Field { + ConsumedCapacity, + Item, + } + + const FIELDS: &'static [&'static str] = &["consumed_capacity", "item"]; + + struct PutOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + marker: std::marker::PhantomData>, + lifetime: std::marker::PhantomData<&'de ()>, + } + + impl<'de, T> Visitor<'de> for PutOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + type Value = PutOutput; + + fn expecting(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result { + formatter.write_str("struct PutOutput") + } + + fn visit_map(self, mut map: V) -> Result + where + V: MapAccess<'de>, + { + let mut consumed_capacity = None; + let mut item = None; + + while let Some(key) = map.next_key()? { + match key { + Field::ConsumedCapacity => { + if consumed_capacity.is_some() { + return Err(de::Error::duplicate_field("consumed_capacity")); + } + + let v: Option = map.next_value()?; + + consumed_capacity = if let Some(v) = v { + Some( + crate::aws_sdk::serialize::value_to_consumed_capacity(v) + .map_err(de::Error::custom)?, + ) + } else { + None + }; + } + Field::Item => { + if item.is_some() { + return Err(de::Error::duplicate_field("item")); + } + + item = Some(map.next_value()?); + } + } + } + + let item = item.ok_or_else(|| de::Error::missing_field("item"))?; + + Ok(PutOutput { + consumed_capacity, + item, + }) + } + } + + deserializer.deserialize_struct( + "PutOutput", + FIELDS, + PutOutputVisitor { + marker: std::marker::PhantomData::>, + lifetime: std::marker::PhantomData, + }, + ) + } +} diff --git a/raiden/src/aws_sdk/ops/query.rs b/raiden/src/aws_sdk/ops/query.rs new file mode 100644 index 00000000..781a58ec --- /dev/null +++ b/raiden/src/aws_sdk/ops/query.rs @@ -0,0 +1,154 @@ +use serde::de::{self, Deserialize, Deserializer, MapAccess, Visitor}; +use serde::ser::{Serialize, SerializeStruct, Serializer}; + +use crate::ops::query::QueryOutput; + +impl Serialize for QueryOutput +where + T: Serialize, +{ + fn serialize(&self, serializer: S) -> Result + where + S: Serializer, + { + let mut state = serializer.serialize_struct("QueryOutput", 5)?; + state.serialize_field( + "consumed_capacity", + &self + .consumed_capacity + .as_ref() + .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + )?; + state.serialize_field("items", &self.items)?; + state.serialize_field("count", &self.count)?; + state.serialize_field("next_token", &self.next_token)?; + state.serialize_field("scanned_count", &self.scanned_count)?; + state.end() + } +} + +impl<'de, T> Deserialize<'de> for QueryOutput +where + T: Deserialize<'de>, +{ + fn deserialize(deserializer: D) -> Result + where + D: Deserializer<'de>, + { + #[derive(serde::Deserialize)] + #[serde(field_identifier, rename_all = "snake_case")] + enum Field { + ConsumedCapacity, + Items, + Count, + NextToken, + ScannedCount, + } + + const FIELDS: &'static [&'static str] = &[ + "consumed_capacity", + "items", + "count", + "next_token", + "scanned_count", + ]; + + struct QueryOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + marker: std::marker::PhantomData>, + lifetime: std::marker::PhantomData<&'de ()>, + } + + impl<'de, T> Visitor<'de> for QueryOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + type Value = QueryOutput; + + fn expecting(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result { + formatter.write_str("struct QueryOutput") + } + + fn visit_map(self, mut map: V) -> Result + where + V: MapAccess<'de>, + { + let mut consumed_capacity = None; + let mut items = None; + let mut count = None; + let mut next_token = None; + let mut scanned_count = None; + + while let Some(key) = map.next_key()? { + match key { + Field::ConsumedCapacity => { + if consumed_capacity.is_some() { + return Err(de::Error::duplicate_field("consumed_capacity")); + } + + let v: Option = map.next_value()?; + + consumed_capacity = if let Some(v) = v { + Some( + crate::aws_sdk::serialize::value_to_consumed_capacity(v) + .map_err(de::Error::custom)?, + ) + } else { + None + }; + } + Field::Items => { + if items.is_some() { + return Err(de::Error::duplicate_field("items")); + } + + items = Some(map.next_value()?); + } + Field::Count => { + if count.is_some() { + return Err(de::Error::duplicate_field("count")); + } + + count = map.next_value()?; + } + Field::NextToken => { + if next_token.is_some() { + return Err(de::Error::duplicate_field("next_token")); + } + + next_token = map.next_value()?; + } + Field::ScannedCount => { + if scanned_count.is_some() { + return Err(de::Error::duplicate_field("scanned_count")); + } + + scanned_count = map.next_value()?; + } + } + } + + let items = items.ok_or_else(|| de::Error::missing_field("items"))?; + + Ok(QueryOutput { + consumed_capacity, + items, + count, + next_token, + scanned_count, + }) + } + } + + deserializer.deserialize_struct( + "QueryOutput", + FIELDS, + QueryOutputVisitor { + marker: std::marker::PhantomData::>, + lifetime: std::marker::PhantomData, + }, + ) + } +} diff --git a/raiden/src/aws_sdk/ops/scan.rs b/raiden/src/aws_sdk/ops/scan.rs new file mode 100644 index 00000000..a94738a4 --- /dev/null +++ b/raiden/src/aws_sdk/ops/scan.rs @@ -0,0 +1,185 @@ +use std::collections::HashMap; + +use serde::de::{self, Deserialize, Deserializer, MapAccess, Visitor}; +use serde::ser::{Serialize, SerializeStruct, Serializer}; + +use crate::ops::scan::ScanOutput; +use crate::serialize::value_to_attribute_value; + +impl Serialize for ScanOutput +where + T: Serialize, +{ + fn serialize(&self, serializer: S) -> Result + where + S: Serializer, + { + let mut state = serializer.serialize_struct("ScanOutput", 5)?; + state.serialize_field( + "consumed_capacity", + &self + .consumed_capacity + .as_ref() + .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + )?; + state.serialize_field("items", &self.items)?; + state.serialize_field("count", &self.count)?; + state.serialize_field( + "last_evaluated_key", + &self.last_evaluated_key.as_ref().map(|v| { + v.iter() + .map(|(k, v)| (k, crate::aws_sdk::serialize::attribute_value_to_value(&v))) + .collect::>() + }), + )?; + state.serialize_field("scanned_count", &self.scanned_count)?; + state.end() + } +} + +impl<'de, T> Deserialize<'de> for ScanOutput +where + T: Deserialize<'de>, +{ + fn deserialize(deserializer: D) -> Result + where + D: Deserializer<'de>, + { + #[derive(serde::Deserialize)] + #[serde(field_identifier, rename_all = "snake_case")] + enum Field { + ConsumedCapacity, + Items, + Count, + LastEvaluatedKey, + ScannedCount, + } + + const FIELDS: &'static [&'static str] = &[ + "consumed_capacity", + "items", + "count", + "last_evaluated_key", + "scanned_count", + ]; + + struct ScanOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + marker: std::marker::PhantomData>, + lifetime: std::marker::PhantomData<&'de ()>, + } + + impl<'de, T> Visitor<'de> for ScanOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + type Value = ScanOutput; + + fn expecting(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result { + formatter.write_str("struct ScanOutput") + } + + fn visit_map(self, mut map: V) -> Result + where + V: MapAccess<'de>, + { + let mut consumed_capacity = None; + let mut items = None; + let mut count = None; + let mut last_evaluated_key = None; + let mut scanned_count = None; + + while let Some(key) = map.next_key()? { + match key { + Field::ConsumedCapacity => { + if consumed_capacity.is_some() { + return Err(de::Error::duplicate_field("consumed_capacity")); + } + + let v: Option = map.next_value()?; + + consumed_capacity = if let Some(v) = v { + Some( + crate::aws_sdk::serialize::value_to_consumed_capacity(v) + .map_err(de::Error::custom)?, + ) + } else { + None + }; + } + Field::Items => { + if items.is_some() { + return Err(de::Error::duplicate_field("items")); + } + + items = Some(map.next_value()?); + } + Field::Count => { + if count.is_some() { + return Err(de::Error::duplicate_field("count")); + } + + count = map.next_value()?; + } + Field::LastEvaluatedKey => { + if last_evaluated_key.is_some() { + return Err(de::Error::duplicate_field("last_evaluated_key")); + } + + let v: Option> = map.next_value()?; + + last_evaluated_key = if let Some(v) = v { + let mut map: HashMap = + HashMap::new(); + + for (k, v) in v { + map.insert( + k, + value_to_attribute_value(v) + .map_err(|err| { + de::Error::custom(format!( + "Invalid value was detected as AttributeValue: {err}", + )) + })?, + ); + } + + Some(map) + } else { + None + }; + } + Field::ScannedCount => { + if scanned_count.is_some() { + return Err(de::Error::duplicate_field("scanned_count")); + } + + scanned_count = map.next_value()?; + } + } + } + + let items = items.ok_or_else(|| de::Error::missing_field("items"))?; + + Ok(ScanOutput { + consumed_capacity, + items, + count, + last_evaluated_key, + scanned_count, + }) + } + } + + deserializer.deserialize_struct( + "ScanOutput", + FIELDS, + ScanOutputVisitor { + marker: std::marker::PhantomData::>, + lifetime: std::marker::PhantomData, + }, + ) + } +} diff --git a/raiden/src/aws_sdk/ops/transact_write.rs b/raiden/src/aws_sdk/ops/transact_write.rs new file mode 100644 index 00000000..367e4292 --- /dev/null +++ b/raiden/src/aws_sdk/ops/transact_write.rs @@ -0,0 +1,99 @@ +// DynamoDb, DynamoDbClient, TransactWriteItem, TransactWriteItemsInput +use crate::{ + aws_sdk::{ + transact_write_items::builders::TransactWriteItemsFluentBuilder, Client, Config, Region, + TransactWriteItem, + }, + RaidenError, RetryCondition, RetryStrategy, TransactWriteConditionCheckBuilder, + TransactWriteDeleteBuilder, TransactWritePutBuilder, TransactWriteUpdateBuilder, +}; + +pub struct WriteTx { + items: Vec, + client: Client, + retry_condition: RetryCondition, +} + +impl WriteTx { + pub fn new(region: Region) -> Self { + let config = Config::builder().region(region).build(); + + Self { + items: vec![], + client: Client::from_conf(config), + retry_condition: RetryCondition::new(), + } + } + + pub fn new_with_client(client: Client) -> Self { + Self { + items: vec![], + client, + retry_condition: RetryCondition::new(), + } + } + + pub fn with_retries(mut self, s: Box) -> Self { + self.retry_condition.strategy = s; + self + } + + pub fn put(mut self, builder: impl TransactWritePutBuilder) -> Self { + let builder = TransactWriteItem::builder().put(builder.build()); + + self.items.push(builder.build()); + self + } + + pub fn update(mut self, builder: impl TransactWriteUpdateBuilder) -> Self { + let builder = TransactWriteItem::builder().update(builder.build()); + + self.items.push(builder.build()); + self + } + + pub fn delete(mut self, builder: impl TransactWriteDeleteBuilder) -> Self { + let builder = TransactWriteItem::builder().delete(builder.build()); + + self.items.push(builder.build()); + self + } + + pub fn condition_check(mut self, builder: impl TransactWriteConditionCheckBuilder) -> Self { + let builder = TransactWriteItem::builder().condition_check(builder.build()); + + self.items.push(builder.build()); + self + } + + pub async fn run(self) -> Result<(), RaidenError> { + let policy: crate::RetryPolicy = self.retry_condition.strategy.policy().into(); + let req = self + .client + .transact_write_items() + .set_transact_items(Some(self.items)); + + policy + .retry_if( + move || { + let req = req.clone(); + async { WriteTx::inner_run(req).await } + }, + &self.retry_condition, + ) + .await + } + + #[cfg_attr(feature = "tracing", tracing::instrument( + level = tracing::Level::DEBUG, + name = "dynamodb::action", + skip_all, + fields(api = "transact_write_items") + ))] + async fn inner_run(req: TransactWriteItemsFluentBuilder) -> Result<(), RaidenError> { + let _res = req.send().await?; + + // TODO: ADD Resp + Ok(()) + } +} diff --git a/raiden/src/aws_sdk/ops/update.rs b/raiden/src/aws_sdk/ops/update.rs new file mode 100644 index 00000000..1fe63712 --- /dev/null +++ b/raiden/src/aws_sdk/ops/update.rs @@ -0,0 +1,140 @@ +use serde::de::{self, Deserialize, Deserializer, MapAccess, Visitor}; +use serde::ser::{Serialize, SerializeStruct, Serializer}; + +use crate::ops::update::UpdateOutput; + +impl Serialize for UpdateOutput +where + T: Serialize, +{ + fn serialize(&self, serializer: S) -> Result + where + S: Serializer, + { + let mut state = serializer.serialize_struct("UpdateOutput", 3)?; + state.serialize_field( + "consumed_capacity", + &self + .consumed_capacity + .as_ref() + .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + )?; + state.serialize_field("item", &self.item)?; + state.serialize_field( + "item_collection_metrics", + &self + .item_collection_metrics + .as_ref() + .map(|v| crate::aws_sdk::serialize::item_collection_metrics_to_value(&v)), + )?; + state.end() + } +} + +impl<'de, T> Deserialize<'de> for UpdateOutput +where + T: Deserialize<'de>, +{ + fn deserialize(deserializer: D) -> Result + where + D: Deserializer<'de>, + { + #[derive(serde::Deserialize)] + #[serde(field_identifier, rename_all = "snake_case")] + enum Field { + ConsumedCapacity, + Item, + ItemCollectionMetrics, + } + + const FIELDS: &'static [&'static str] = + &["consumed_capacity", "item", "item_collection_metrics"]; + + struct UpdateOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + marker: std::marker::PhantomData>, + lifetime: std::marker::PhantomData<&'de ()>, + } + + impl<'de, T> Visitor<'de> for UpdateOutputVisitor<'de, T> + where + T: Deserialize<'de>, + { + type Value = UpdateOutput; + + fn expecting(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result { + formatter.write_str("struct UpdateOutput") + } + + fn visit_map(self, mut map: V) -> Result + where + V: MapAccess<'de>, + { + let mut consumed_capacity = None; + let mut item = None; + let mut item_collection_metrics = None; + + while let Some(key) = map.next_key()? { + match key { + Field::ConsumedCapacity => { + if consumed_capacity.is_some() { + return Err(de::Error::duplicate_field("consumed_capacity")); + } + + let v: Option = map.next_value()?; + + consumed_capacity = if let Some(v) = v { + Some( + crate::aws_sdk::serialize::value_to_consumed_capacity(v) + .map_err(de::Error::custom)?, + ) + } else { + None + }; + } + Field::Item => { + if item.is_some() { + return Err(de::Error::duplicate_field("item")); + } + + item = map.next_value()?; + } + Field::ItemCollectionMetrics => { + if item_collection_metrics.is_some() { + return Err(de::Error::duplicate_field("item_collection_metrics")); + } + + let v: Option = map.next_value()?; + + item_collection_metrics = if let Some(v) = v { + Some( + crate::aws_sdk::serialize::value_to_item_collection_metrics(v) + .map_err(de::Error::custom)?, + ) + } else { + None + }; + } + } + } + + Ok(UpdateOutput { + consumed_capacity, + item, + item_collection_metrics, + }) + } + } + + deserializer.deserialize_struct( + "UpdateOutput", + FIELDS, + UpdateOutputVisitor { + marker: std::marker::PhantomData::>, + lifetime: std::marker::PhantomData, + }, + ) + } +} diff --git a/raiden/src/aws_sdk/serialize/attribute_value.rs b/raiden/src/aws_sdk/serialize/attribute_value.rs new file mode 100644 index 00000000..7a425fed --- /dev/null +++ b/raiden/src/aws_sdk/serialize/attribute_value.rs @@ -0,0 +1,150 @@ +use std::collections::HashMap; + +use aws_sdk_dynamodb::primitives::Blob; +use base64::{engine::general_purpose::STANDARD, Engine}; +use serde::de::{self, Error as _}; +use serde_json::{json, Error, Value}; + +use crate::AttributeValue; + +pub fn attribute_value_to_value(value: &AttributeValue) -> Value { + match &value { + &AttributeValue::B(v) => json!({ "B": STANDARD.encode(v) }), + &AttributeValue::Bool(v) => json!({ "BOOL": v }), + &AttributeValue::Bs(vs) => json!({ "BS": [ + vs.iter().map(|v| json!({ "B": STANDARD.encode(v) })).collect::>(), + ]}), + &AttributeValue::L(vs) => json!({ "L": [ + vs.iter().map(attribute_value_to_value).collect::>(), + ]}), + &AttributeValue::M(vs) => json!({ "M": vs.iter().map(|(k, v)| { + (k.clone(), attribute_value_to_value(v)) + }).collect::>() }), + &AttributeValue::N(v) => json!({ "N": v }), + &AttributeValue::Ns(vs) => json!({ "NS": [ + vs.iter().map(|v| json!({ "N": v })).collect::>(), + ]}), + &AttributeValue::Null(v) => json!({ "NULL": v }), + &AttributeValue::S(v) => json!({ "S": v }), + &AttributeValue::Ss(vs) => json!({ "SS": [ + vs.iter().map(|v| json!({ "S": v })).collect::>(), + ]}), + _ => { + panic!("Unknown data type. Consider upgrading your SDK to the latest version.") + } + } +} + +pub fn value_to_attribute_value(value: Value) -> Result { + let Value::Object(value) = value else { + return Err(de::Error::custom("value is not type of AttributeValue")); + }; + + if value.len() != 1 { + return Err(de::Error::custom( + "AttributeValue must include only 1 field", + )); + } + + let (ty, value) = value.into_iter().next().unwrap(); + let v = match (ty.as_str(), value) { + ("B", Value::String(s)) => { + let b = STANDARD.decode(s).map_err(Error::custom)?; + + AttributeValue::B(Blob::new(b)) + } + ("BOOL", Value::Bool(b)) => AttributeValue::Bool(b), + ("BS", Value::Array(vs)) => { + let mut values = vec![]; + + for (i, v) in vs.into_iter().enumerate() { + match v { + Value::String(s) => { + let b = STANDARD.decode(s).map_err(Error::custom)?; + + values.push(Blob::new(b)) + } + _ => { + return Err(Error::custom(format!( + "Unexpected value was detected in BS field at index of {i}", + ))) + } + }; + } + + AttributeValue::Bs(values) + } + ("L", Value::Array(vs)) => { + let mut values = vec![]; + + for (i, v) in vs.into_iter().enumerate() { + let v = value_to_attribute_value(v).map_err(|err| { + Error::custom(format!( + "Unexpected value was detected in L field at index of {i}: {err}", + )) + })?; + + values.push(v); + } + + AttributeValue::L(values) + } + ("M", Value::Object(m)) => { + let mut values: HashMap = HashMap::new(); + + for (k, v) in m { + let v = value_to_attribute_value(v).map_err(|err| { + Error::custom(format!( + "Unexpected value was detected in M field at key of {k}: {err}", + )) + })?; + + values.insert(k, v); + } + + AttributeValue::M(values) + } + ("N", Value::String(s)) => AttributeValue::N(s), + ("NS", Value::Array(vs)) => { + let mut values = vec![]; + + for (i, v) in vs.into_iter().enumerate() { + match v { + Value::String(s) => { + values.push(s); + } + _ => { + return Err(Error::custom(format!( + "Unexpected value was detected in NS field at index of {i}", + ))) + } + }; + } + + AttributeValue::Ns(values) + } + ("NULL", Value::Null) => AttributeValue::Null(true), + ("S", Value::String(s)) => AttributeValue::S(s), + ("SS", Value::Array(vs)) => { + let mut values = vec![]; + + for (i, v) in vs.into_iter().enumerate() { + match v { + Value::String(s) => { + values.push(s); + } + _ => { + return Err(Error::custom(format!( + "Unexpected value was detected in SS field at index of {i}", + ))) + } + }; + } + + AttributeValue::Ss(values) + } + _ => return Err(Error::custom("Unexpected data type was detected")), + }; + + Ok(v) +} diff --git a/raiden/src/aws_sdk/serialize/consumed_capacity.rs b/raiden/src/aws_sdk/serialize/consumed_capacity.rs new file mode 100644 index 00000000..5d280ee1 --- /dev/null +++ b/raiden/src/aws_sdk/serialize/consumed_capacity.rs @@ -0,0 +1,103 @@ +use std::collections::HashMap; + +use serde::de; +use serde_json::{json, Error, Map, Value}; + +use crate::aws_sdk::serialize::set_optional_value; + +pub fn consumed_capacity_to_value(v: &crate::ConsumedCapacity) -> Value { + json!({ + "table_name": v.table_name, + "capacity_units": v.capacity_units, + "read_capacity_units": v.read_capacity_units, + "write_capacity_units": v.write_capacity_units, + "table": v.table.as_ref().map(|v| capacity_to_value(&v)), + "local_secondary_indexes": v.local_secondary_indexes.as_ref() + .map(|v| { + v + .iter() + .map(|(k, v)| (k.clone(), capacity_to_value(v))) + .collect::>() + }), + "global_secondary_indexes": v.global_secondary_indexes.as_ref() + .map(|v| { + v + .iter() + .map(|(k, v)| (k.clone(), capacity_to_value(v))) + .collect::>() + }), + }) +} + +pub fn value_to_consumed_capacity(value: Value) -> Result { + let Value::Object(m) = value else { + return Err(de::Error::custom("value is not type of ConsumedCapacity")); + }; + + let mut builder = crate::ConsumedCapacity::builder(); + + set_optional_value!(builder, m, table_name, String); + set_optional_value!(builder, m, capacity_units, f64); + set_optional_value!(builder, m, read_capacity_units, f64); + set_optional_value!(builder, m, write_capacity_units, f64); + + if let Some(v) = m.get("table") { + builder = builder.table(value_to_capacity(v.clone())?); + } + + set_optional_value!(builder, m, local_secondary_indexes, object, |m: &Map< + _, + _, + >| + -> Result< + _, + _, + > { + let mut map = HashMap::new(); + for (k, v) in m.iter() { + map.insert(k.clone(), value_to_capacity(v.clone())?); + } + + Ok(Some(map)) + }); + + set_optional_value!(builder, m, global_secondary_indexes, object, |m: &Map< + _, + _, + >| + -> Result< + _, + _, + > { + let mut map = HashMap::new(); + for (k, v) in m.iter() { + map.insert(k.clone(), value_to_capacity(v.clone())?); + } + + Ok(Some(map)) + }); + + Ok(builder.build()) +} + +pub fn capacity_to_value(v: &crate::Capacity) -> Value { + json!({ + "read_capacity_units": v.read_capacity_units, + "write_capacity_units": v.write_capacity_units, + "capacity_units": v.capacity_units, + }) +} + +pub fn value_to_capacity(value: Value) -> Result { + let Value::Object(m) = value else { + return Err(de::Error::custom("value is not type of Capacity")); + }; + + let mut builder = crate::Capacity::builder(); + + set_optional_value!(builder, m, read_capacity_units, f64); + set_optional_value!(builder, m, write_capacity_units, f64); + set_optional_value!(builder, m, capacity_units, f64); + + Ok(builder.build()) +} diff --git a/raiden/src/aws_sdk/serialize/delete_request.rs b/raiden/src/aws_sdk/serialize/delete_request.rs new file mode 100644 index 00000000..f7abd09c --- /dev/null +++ b/raiden/src/aws_sdk/serialize/delete_request.rs @@ -0,0 +1,39 @@ +use std::collections::HashMap; + +use serde::de; +use serde_json::{json, Error, Map, Value}; + +use crate::aws_sdk::serialize::{ + attribute_value_to_value, set_optional_value, value_to_attribute_value, +}; + +pub fn delete_request_to_value(v: &crate::DeleteRequest) -> Value { + json!({ + "key": v.key.as_ref().map(|v| v.iter().map(|(k, v)| { + (k.clone(), attribute_value_to_value(v)) + }).collect::>()), + }) +} + +pub fn value_to_delete_request(value: Value) -> Result { + if let Value::Object(m) = value { + let mut builder = crate::DeleteRequest::builder(); + + set_optional_value!(builder, m, key, object, |m: &Map<_, _>| -> Result<_, _> { + let mut map = HashMap::new(); + + for (k, v) in m.iter() { + let v = value_to_attribute_value(v.clone()) + .map_err(|err| de::Error::custom(format!("{k} set in key: {err}")))?; + + map.insert(k.clone(), v); + } + + Ok(Some(map)) + }); + + Ok(builder.build()) + } else { + Err(de::Error::custom("value is not type of DeleteRequest")) + } +} diff --git a/raiden/src/aws_sdk/serialize/item_collection_metrics.rs b/raiden/src/aws_sdk/serialize/item_collection_metrics.rs new file mode 100644 index 00000000..1bf334d7 --- /dev/null +++ b/raiden/src/aws_sdk/serialize/item_collection_metrics.rs @@ -0,0 +1,70 @@ +use std::collections::HashMap; + +use serde::de; +use serde_json::{json, Error, Map, Value}; + +use crate::aws_sdk::serialize::{ + attribute_value_to_value, parse_value, set_optional_value, value_to_attribute_value, +}; + +pub fn item_collection_metrics_to_value(v: &crate::ItemCollectionMetrics) -> Value { + json!({ + "item_collection_key": v.item_collection_key.as_ref().map(|v| { + v + .iter() + .map(|(k, v)| (k.clone(), attribute_value_to_value(v))) + .collect::>() + }), + "size_estimate_range_gb": v.size_estimate_range_gb, + }) +} + +pub fn value_to_item_collection_metrics( + value: Value, +) -> Result { + if let Value::Object(m) = value { + let mut builder = crate::ItemCollectionMetrics::builder(); + + set_optional_value!( + builder, + m, + item_collection_key, + object, + |m: &Map<_, _>| -> Result<_, _> { + let mut map = HashMap::new(); + + for (k, v) in m.iter() { + let v = value_to_attribute_value(v.clone()).map_err(|err| { + de::Error::custom(format!("{k} set in item_collection_key: {err}")) + })?; + + map.insert(k.clone(), v); + } + + Ok(Some(map)) + } + ); + + set_optional_value!( + builder, + m, + size_estimate_range_gb, + array, + |vs: &Vec<_>| -> Result<_, _> { + let mut values = vec![]; + + for v in vs { + values.push(parse_value!(v, f64)?); + } + + Ok(Some(values)) + } + ); + + Ok(builder.build()) + } else { + Err(de::Error::custom( + "value is not type of ItemCollectionMetrics", + )) + } +} diff --git a/raiden/src/aws_sdk/serialize/keys_and_attributes.rs b/raiden/src/aws_sdk/serialize/keys_and_attributes.rs new file mode 100644 index 00000000..f56151d9 --- /dev/null +++ b/raiden/src/aws_sdk/serialize/keys_and_attributes.rs @@ -0,0 +1,89 @@ +use std::collections::HashMap; + +use serde::de; +use serde_json::{json, Error, Map, Value}; + +use crate::{ + aws_sdk::serialize::{attribute_value_to_value, parse_value, set_optional_value}, + serialize::value_to_attribute_value, +}; + +pub fn keys_and_attributes_to_value(v: &crate::KeysAndAttributes) -> Value { + json!({ + "keys": v.keys.as_ref().map(|v| v.iter().map(|v| v.iter().map(|(k, v)| { + (k.clone(), attribute_value_to_value(v)) + }).collect::>()).collect::>()), + "attributes_to_get": v.attributes_to_get, + "consistent_read": v.consistent_read, + "projection_expression": v.projection_expression, + "expression_attribute_names": v.expression_attribute_names, + }) +} + +pub fn value_to_keys_and_attributes(value: Value) -> Result { + if let Value::Object(m) = value { + let mut builder = crate::KeysAndAttributes::builder(); + + set_optional_value!(builder, m, keys, array, |vs: &Vec<_>| -> Result<_, _> { + let mut values = vec![]; + + for v in vs { + let v = parse_value!(v, object, |m: &Map<_, _>| -> Result<_, _> { + let mut map = HashMap::new(); + + for (k, v) in m.iter() { + let v = value_to_attribute_value(v.clone()) + .map_err(|err| de::Error::custom(format!("{k} set in keys: {err}")))?; + + map.insert(k.clone(), v); + } + + Ok(map) + })?; + + values.push(v); + } + + Ok(Some(values)) + }); + + set_optional_value!( + builder, + m, + attributes_to_get, + array, + |vs: &Vec<_>| -> Result<_, _> { + let mut values = vec![]; + + for v in vs { + values.push(parse_value!(v, String)?.clone()); + } + + Ok(Some(values)) + } + ); + + set_optional_value!(builder, m, consistent_read, bool); + set_optional_value!(builder, m, projection_expression, String); + + set_optional_value!( + builder, + m, + expression_attribute_names, + object, + |m: &Map<_, _>| -> Result<_, _> { + let mut map = HashMap::new(); + + for (k, v) in m.iter() { + map.insert(k.clone(), parse_value!(v, String)?.clone()); + } + + Ok(Some(map)) + } + ); + + Ok(builder.build()) + } else { + Err(de::Error::custom("value is not type of KeysAndAttributes")) + } +} diff --git a/raiden/src/aws_sdk/serialize/mod.rs b/raiden/src/aws_sdk/serialize/mod.rs new file mode 100644 index 00000000..20fa1398 --- /dev/null +++ b/raiden/src/aws_sdk/serialize/mod.rs @@ -0,0 +1,113 @@ +mod attribute_value; +mod consumed_capacity; +mod delete_request; +mod item_collection_metrics; +mod keys_and_attributes; + +pub use self::{ + attribute_value::*, consumed_capacity::*, delete_request::*, item_collection_metrics::*, + keys_and_attributes::*, +}; + +macro_rules! set_optional_value { + ($builder: expr, $object: expr, $key: ident, bool) => { + if let Some(v) = $object.get(stringify!($key)) { + let v = crate::aws_sdk::serialize::parse_value!(v, bool).map_err( + |err: serde_json::Error| { + serde::de::Error::custom(format!("{}: {err}", stringify!($key))) + }, + )?; + + $builder = $builder.$key(*v); + } + }; + ($builder: expr, $object: expr, $key: ident, String) => { + if let Some(v) = $object.get(stringify!($key)) { + let v = crate::aws_sdk::serialize::parse_value!(v, String).map_err( + |err: serde_json::Error| { + serde::de::Error::custom(format!("{}: {err}", stringify!($key))) + }, + )?; + + $builder = $builder.$key(v); + } + }; + ($builder: expr, $object: expr, $key: ident, f64) => { + if let Some(v) = $object.get(stringify!($key)) { + let v = crate::aws_sdk::serialize::parse_value!(v, f64).map_err( + |err: serde_json::Error| { + serde::de::Error::custom(format!("{}: {err}", stringify!($key))) + }, + )?; + + $builder = $builder.$key(v); + } + }; + ($builder: expr, $object: expr, $key: ident, object, $closure: expr) => { + if let Some(v) = $object.get(stringify!($key)) { + let v = crate::aws_sdk::serialize::parse_value!(v, object, $closure).map_err( + |err: serde_json::Error| { + serde::de::Error::custom(format!("{}: {err}", stringify!($key))) + }, + )?; + + paste::paste! { + $builder = $builder.[](v); + } + } + }; + ($builder: expr, $object: expr, $key: ident, array, $closure: expr) => { + if let Some(v) = $object.get(stringify!($key)) { + let v = crate::aws_sdk::serialize::parse_value!(v, array, $closure).map_err( + |err: serde_json::Error| { + serde::de::Error::custom(format!("{}: {err}", stringify!($key))) + }, + )?; + + paste::paste! { + $builder = $builder.[](v); + } + } + }; +} + +macro_rules! parse_value { + ($value: expr, bool) => {{ + if let serde_json::Value::Bool(v) = $value { + Ok(v) + } else { + Err(serde::de::Error::custom("value must be type of bool")) + } + }}; + ($value: expr, String) => {{ + if let serde_json::Value::String(v) = $value { + Ok(v) + } else { + Err(serde::de::Error::custom("value must be type of String")) + } + }}; + ($value: expr, f64) => {{ + if let serde_json::Value::Number(v) = $value { + v.as_f64() + .ok_or_else(|| de::Error::custom("value must be type of f64")) + } else { + Err(de::Error::custom("value must be type of Number")) + } + }}; + ($value: expr, object, $closure: expr) => {{ + if let serde_json::Value::Object(__m) = $value { + Ok($closure(__m)?) + } else { + Err(serde::de::Error::custom("value must be type of Object")) + } + }}; + ($value: expr, array, $closure: expr) => {{ + if let serde_json::Value::Array(__vs) = $value { + Ok($closure(__vs)?) + } else { + Err(serde::de::Error::custom("value must be type of Array")) + } + }}; +} + +use {parse_value, set_optional_value}; diff --git a/raiden/src/condition/mod.rs b/raiden/src/condition/mod.rs index f639b0ad..b191e0e1 100644 --- a/raiden/src/condition/mod.rs +++ b/raiden/src/condition/mod.rs @@ -150,6 +150,8 @@ impl super::IntoAttrValues for ConditionFunctionExpression { use crypto::digest::Digest; use crypto::md5::Md5; let mut m: super::AttributeValues = std::collections::HashMap::new(); + + #[cfg(any(feature = "rusoto", feature = "rustls"))] match self { Self::AttributeType(_path, t) => { m.insert( @@ -184,6 +186,30 @@ impl super::IntoAttrValues for ConditionFunctionExpression { } _ => {} } + + #[cfg(feature = "aws-sdk")] + match self { + Self::AttributeType(_path, t) => { + m.insert(format!(":type{t}"), super::AttributeValue::S(t.to_string())); + } + Self::BeginsWith(_path, s) => { + let mut md5 = Md5::new(); + md5.input(s.as_bytes()); + m.insert( + format!(":begins_with_{}", md5.result_str()), + super::AttributeValue::S(s), + ); + } + Self::Contains(_path, s) => { + let mut md5 = Md5::new(); + md5.input(s.as_bytes()); + m.insert( + format!(":contains_{}", md5.result_str()), + super::AttributeValue::S(s), + ); + } + _ => {} + } m } } diff --git a/raiden/src/errors/mod.rs b/raiden/src/errors/mod.rs index 146b4adb..96fed7c3 100644 --- a/raiden/src/errors/mod.rs +++ b/raiden/src/errors/mod.rs @@ -1,297 +1,85 @@ mod transaction; -use crate::*; -use thiserror::Error; - pub use transaction::*; -#[derive(Error, Debug, PartialEq)] +#[derive(thiserror::Error, Debug)] pub enum RaidenError { - #[error("`{0}`")] - DataExistsError(String), + #[error("attribute {attr_name:?} convert error")] + AttributeConvertError { attr_name: String }, #[error("`{0}`")] ConditionalCheckFailed(String), #[error("`{0}`")] - ItemCollectionSizeLimitExceeded(String), + IdempotentParameterMismatch(String), #[error("`{0}`")] - TransactionConflict(String), + InternalServerError(String), #[error("`{0}`")] - ResourceNotFound(String), + ItemCollectionSizeLimitExceeded(String), + #[error("next_token decode error")] + NextTokenDecodeError, + #[error("`{0}`")] + ProvisionedThroughputExceeded(String), #[error("`{0}`")] RequestLimitExceeded(String), #[error("`{0}`")] - TransactionConflictError(String), + ResourceNotFound(String), #[error("`{0}`")] SizeLimitExceeded(String), + #[error("`transaction canceled error {reasons}`")] + TransactionCanceled { + reasons: RaidenTransactionCancellationReasons, + #[cfg(feature = "aws-sdk")] + raw_reasons: Vec, + }, #[error("`{0}`")] - InternalServerError(String), - #[error("`{0}`")] - ProvisionedThroughputExceeded(String), + TransactionConflict(String), #[error("`{0}`")] - HttpDispatch(crate::request::HttpDispatchError), + TransactionInProgress(String), + // + // Next errors returns only using rusoto. + // + #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[error("blocking error")] + Blocking, + #[cfg(any(feature = "rusoto", feature = "rustls"))] #[error("`{0}`")] Credentials(crate::CredentialsError), + #[cfg(any(feature = "rusoto", feature = "rustls"))] #[error("`{0}`")] - Validation(String), + HttpDispatch(crate::HttpDispatchError), + #[cfg(any(feature = "rusoto", feature = "rustls"))] #[error("`{0}`")] ParseError(String), + #[cfg(any(feature = "rusoto", feature = "rustls"))] #[error("unknown error")] Unknown(crate::request::BufferedHttpResponse), - #[error("`transaction canceled error {reasons}`")] - TransactionCanceled { - reasons: RaidenTransactionCancellationReasons, - }, + #[cfg(any(feature = "rusoto", feature = "rustls"))] #[error("`{0}`")] - TransactionInProgress(String), - #[error("`{0}`")] - IdempotentParameterMismatch(String), - #[error("blocking error")] - Blocking, - #[error("next_token decode error")] - NextTokenDecodeError, - #[error("attribute {attr_name:?} convert error")] - AttributeConvertError { attr_name: String }, + Validation(String), + // + // Next errors returns only using aws-sdk. + // + #[cfg(feature = "aws-sdk")] + #[error("`{0:?}`")] + Construction(aws_smithy_http::result::ConstructionFailure), + #[cfg(feature = "aws-sdk")] + #[error("`{0:?}`")] + HttpDispatch(aws_smithy_http::result::DispatchFailure), + #[cfg(feature = "aws-sdk")] + #[error("`{0:?}`")] + Timeout(aws_smithy_http::result::TimeoutError), + #[cfg(feature = "aws-sdk")] + #[error("unknown error")] + Unknown(aws_smithy_runtime_api::client::orchestrator::HttpResponse), + // + // Next errors are not used. + // + #[deprecated = "unused. this variant never returns."] #[error("attribute {attr_name:?} value not found")] AttributeValueNotFoundError { attr_name: String }, -} - -impl From> for RaidenError { - fn from(error: RusotoError) -> Self { - match error { - RusotoError::Service(error) => match error { - BatchGetItemError::InternalServerError(msg) => { - RaidenError::InternalServerError(msg) - } - BatchGetItemError::ProvisionedThroughputExceeded(msg) => { - RaidenError::ProvisionedThroughputExceeded(msg) - } - BatchGetItemError::RequestLimitExceeded(msg) => { - RaidenError::RequestLimitExceeded(msg) - } - BatchGetItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), - }, - RusotoError::HttpDispatch(e) => RaidenError::HttpDispatch(e), - RusotoError::Credentials(e) => RaidenError::Credentials(e), - RusotoError::Validation(msg) => RaidenError::Validation(msg), - RusotoError::ParseError(msg) => RaidenError::ParseError(msg), - RusotoError::Unknown(res) => RaidenError::Unknown(res), - RusotoError::Blocking => RaidenError::Blocking, - } - } -} - -impl From> for RaidenError { - fn from(error: RusotoError) -> Self { - match error { - RusotoError::Service(error) => match error { - BatchWriteItemError::InternalServerError(msg) => { - RaidenError::InternalServerError(msg) - } - BatchWriteItemError::ItemCollectionSizeLimitExceeded(msg) => { - RaidenError::ItemCollectionSizeLimitExceeded(msg) - } - BatchWriteItemError::ProvisionedThroughputExceeded(msg) => { - RaidenError::ProvisionedThroughputExceeded(msg) - } - BatchWriteItemError::RequestLimitExceeded(msg) => { - RaidenError::RequestLimitExceeded(msg) - } - BatchWriteItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), - }, - RusotoError::HttpDispatch(e) => RaidenError::HttpDispatch(e), - RusotoError::Credentials(e) => RaidenError::Credentials(e), - RusotoError::Validation(msg) => RaidenError::Validation(msg), - RusotoError::ParseError(msg) => RaidenError::ParseError(msg), - RusotoError::Unknown(res) => RaidenError::Unknown(res), - RusotoError::Blocking => RaidenError::Blocking, - } - } -} - -impl From> for RaidenError { - fn from(error: RusotoError) -> Self { - match error { - RusotoError::Service(error) => match error { - GetItemError::InternalServerError(msg) => RaidenError::InternalServerError(msg), - GetItemError::ProvisionedThroughputExceeded(msg) => { - RaidenError::ProvisionedThroughputExceeded(msg) - } - GetItemError::RequestLimitExceeded(msg) => RaidenError::RequestLimitExceeded(msg), - GetItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), - }, - RusotoError::HttpDispatch(e) => RaidenError::HttpDispatch(e), - RusotoError::Credentials(e) => RaidenError::Credentials(e), - RusotoError::Validation(msg) => RaidenError::Validation(msg), - RusotoError::ParseError(msg) => RaidenError::ParseError(msg), - RusotoError::Unknown(res) => RaidenError::Unknown(res), - RusotoError::Blocking => RaidenError::Blocking, - } - } -} - -impl From> for RaidenError { - fn from(error: RusotoError) -> Self { - match error { - RusotoError::Service(error) => match error { - QueryError::InternalServerError(msg) => RaidenError::InternalServerError(msg), - QueryError::ProvisionedThroughputExceeded(msg) => { - RaidenError::ProvisionedThroughputExceeded(msg) - } - QueryError::RequestLimitExceeded(msg) => RaidenError::RequestLimitExceeded(msg), - QueryError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), - }, - RusotoError::HttpDispatch(e) => RaidenError::HttpDispatch(e), - RusotoError::Credentials(e) => RaidenError::Credentials(e), - RusotoError::Validation(msg) => RaidenError::Validation(msg), - RusotoError::ParseError(msg) => RaidenError::ParseError(msg), - RusotoError::Unknown(res) => RaidenError::Unknown(res), - RusotoError::Blocking => RaidenError::Blocking, - } - } -} - -impl From> for RaidenError { - fn from(error: RusotoError) -> Self { - match error { - RusotoError::Service(error) => match error { - ScanError::InternalServerError(msg) => RaidenError::InternalServerError(msg), - ScanError::ProvisionedThroughputExceeded(msg) => { - RaidenError::ProvisionedThroughputExceeded(msg) - } - ScanError::RequestLimitExceeded(msg) => RaidenError::RequestLimitExceeded(msg), - ScanError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), - }, - RusotoError::HttpDispatch(e) => RaidenError::HttpDispatch(e), - RusotoError::Credentials(e) => RaidenError::Credentials(e), - RusotoError::Validation(msg) => RaidenError::Validation(msg), - RusotoError::ParseError(msg) => RaidenError::ParseError(msg), - RusotoError::Unknown(res) => RaidenError::Unknown(res), - RusotoError::Blocking => RaidenError::Blocking, - } - } -} - -impl From> for RaidenError { - fn from(error: RusotoError) -> Self { - match error { - RusotoError::Service(error) => match error { - PutItemError::InternalServerError(msg) => RaidenError::InternalServerError(msg), - PutItemError::ProvisionedThroughputExceeded(msg) => { - RaidenError::ProvisionedThroughputExceeded(msg) - } - PutItemError::RequestLimitExceeded(msg) => RaidenError::RequestLimitExceeded(msg), - PutItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), - PutItemError::ConditionalCheckFailed(msg) => { - RaidenError::ConditionalCheckFailed(msg) - } - PutItemError::ItemCollectionSizeLimitExceeded(msg) => { - RaidenError::ItemCollectionSizeLimitExceeded(msg) - } - PutItemError::TransactionConflict(msg) => RaidenError::TransactionConflict(msg), - }, - RusotoError::HttpDispatch(e) => RaidenError::HttpDispatch(e), - RusotoError::Credentials(e) => RaidenError::Credentials(e), - RusotoError::Validation(msg) => RaidenError::Validation(msg), - RusotoError::ParseError(msg) => RaidenError::ParseError(msg), - RusotoError::Unknown(res) => RaidenError::Unknown(res), - RusotoError::Blocking => RaidenError::Blocking, - } - } -} - -impl From> for RaidenError { - fn from(error: RusotoError) -> Self { - match error { - RusotoError::Service(error) => match error { - UpdateItemError::InternalServerError(msg) => RaidenError::InternalServerError(msg), - UpdateItemError::ProvisionedThroughputExceeded(msg) => { - RaidenError::ProvisionedThroughputExceeded(msg) - } - UpdateItemError::RequestLimitExceeded(msg) => { - RaidenError::RequestLimitExceeded(msg) - } - UpdateItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), - UpdateItemError::ConditionalCheckFailed(msg) => { - RaidenError::ConditionalCheckFailed(msg) - } - UpdateItemError::ItemCollectionSizeLimitExceeded(msg) => { - RaidenError::ItemCollectionSizeLimitExceeded(msg) - } - UpdateItemError::TransactionConflict(msg) => RaidenError::TransactionConflict(msg), - }, - RusotoError::HttpDispatch(e) => RaidenError::HttpDispatch(e), - RusotoError::Credentials(e) => RaidenError::Credentials(e), - RusotoError::Validation(msg) => RaidenError::Validation(msg), - RusotoError::ParseError(msg) => RaidenError::ParseError(msg), - RusotoError::Unknown(res) => RaidenError::Unknown(res), - RusotoError::Blocking => RaidenError::Blocking, - } - } -} - -impl From> for RaidenError { - fn from(error: RusotoError) -> Self { - match error { - RusotoError::Service(error) => match error { - DeleteItemError::InternalServerError(msg) => RaidenError::InternalServerError(msg), - DeleteItemError::ProvisionedThroughputExceeded(msg) => { - RaidenError::ProvisionedThroughputExceeded(msg) - } - DeleteItemError::RequestLimitExceeded(msg) => { - RaidenError::RequestLimitExceeded(msg) - } - DeleteItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), - DeleteItemError::ConditionalCheckFailed(msg) => { - RaidenError::ConditionalCheckFailed(msg) - } - DeleteItemError::ItemCollectionSizeLimitExceeded(msg) => { - RaidenError::ItemCollectionSizeLimitExceeded(msg) - } - DeleteItemError::TransactionConflict(msg) => RaidenError::TransactionConflict(msg), - }, - RusotoError::HttpDispatch(e) => RaidenError::HttpDispatch(e), - RusotoError::Credentials(e) => RaidenError::Credentials(e), - RusotoError::Validation(msg) => RaidenError::Validation(msg), - RusotoError::ParseError(msg) => RaidenError::ParseError(msg), - RusotoError::Unknown(res) => RaidenError::Unknown(res), - RusotoError::Blocking => RaidenError::Blocking, - } - } -} - -impl From> for RaidenError { - fn from(error: RusotoError) -> Self { - match error { - RusotoError::Service(error) => match error { - TransactWriteItemsError::IdempotentParameterMismatch(msg) => { - RaidenError::IdempotentParameterMismatch(msg) - } - TransactWriteItemsError::InternalServerError(msg) => { - RaidenError::InternalServerError(msg) - } - TransactWriteItemsError::ProvisionedThroughputExceeded(msg) => { - RaidenError::ProvisionedThroughputExceeded(msg) - } - TransactWriteItemsError::RequestLimitExceeded(msg) => { - RaidenError::RequestLimitExceeded(msg) - } - TransactWriteItemsError::ResourceNotFound(msg) => { - RaidenError::ResourceNotFound(msg) - } - TransactWriteItemsError::TransactionCanceled(msg) => { - let reasons = RaidenTransactionCancellationReasons::from_str(&msg); - RaidenError::TransactionCanceled { reasons } - } - TransactWriteItemsError::TransactionInProgress(msg) => { - RaidenError::TransactionInProgress(msg) - } - }, - RusotoError::HttpDispatch(e) => RaidenError::HttpDispatch(e), - RusotoError::Credentials(e) => RaidenError::Credentials(e), - RusotoError::Validation(msg) => RaidenError::Validation(msg), - RusotoError::ParseError(msg) => RaidenError::ParseError(msg), - RusotoError::Unknown(res) => RaidenError::Unknown(res), - RusotoError::Blocking => RaidenError::Blocking, - } - } + #[deprecated = "unused. this variant never returns."] + #[error("`{0}`")] + DataExistsError(String), + #[deprecated = "unused. this variant never returns."] + #[error("`{0}`")] + TransactionConflictError(String), } diff --git a/raiden/src/errors/transaction.rs b/raiden/src/errors/transaction.rs index 2bd36e8d..35c2226b 100644 --- a/raiden/src/errors/transaction.rs +++ b/raiden/src/errors/transaction.rs @@ -1,7 +1,5 @@ use std::fmt; -use thiserror::Error; - const TRANSACTION_CANCELLED_MESSAGE_PREFIX: &str = "Transaction cancelled, please refer cancellation reasons for specific reasons"; @@ -80,7 +78,7 @@ impl fmt::Display for RaidenTransactionCancellationReasons { } } -#[derive(Error, Clone, Debug, PartialEq)] +#[derive(thiserror::Error, Clone, Debug, PartialEq)] pub enum RaidenTransactionCancellationReason { #[error("Unknown")] Unknown, diff --git a/raiden/src/lib.rs b/raiden/src/lib.rs index 0af27a63..bd6c6326 100644 --- a/raiden/src/lib.rs +++ b/raiden/src/lib.rs @@ -13,6 +13,29 @@ pub mod types; pub mod update_expression; pub mod value_id; +#[cfg(all(feature = "rusoto", feature = "rusoto_rustls"))] +compile_error!("feature \"rusoto\" and \"rusoto_rustls\" cannot be enabled at the same time."); + +#[cfg(any( + all(feature = "aws-sdk", feature = "rusoto"), + all(feature = "aws-sdk", feature = "rusoto_rustls") +))] +compile_error!( + "feature \"aws-sdk\" and \"rusoto\" or \"rusoto_rustls\" cannot be enabled at the same time." +); + +#[cfg(any(feature = "rusoto", feature = "rustls"))] +mod rusoto; + +#[cfg(any(feature = "rusoto", feature = "rustls"))] +pub use rusoto::*; + +#[cfg(feature = "aws-sdk")] +mod aws_sdk; + +#[cfg(feature = "aws-sdk")] +pub use aws_sdk::*; + pub use condition::*; pub use errors::*; pub use filter_expression::*; @@ -23,21 +46,8 @@ pub use retry::*; pub use id_generator::*; pub use raiden_derive::*; -pub use rusoto_credential::*; pub use value_id::*; -#[cfg(feature = "default")] -pub use rusoto_dynamodb_default::*; - -#[cfg(feature = "default")] -pub use rusoto_core_default::*; - -#[cfg(feature = "rustls")] -pub use rusoto_dynamodb_rustls::*; - -#[cfg(feature = "rustls")] -pub use rusoto_core_rustls::*; - pub type Placeholder = String; pub use safe_builder::Builder; @@ -57,15 +67,6 @@ pub enum AttributeType { M, // Map } -impl IntoAttribute for AttributeType { - fn into_attr(self) -> AttributeValue { - AttributeValue { - s: Some(self.to_string()), - ..AttributeValue::default() - } - } -} - impl std::fmt::Display for AttributeType { fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result { write!(f, "{self:?}") @@ -73,7 +74,6 @@ impl std::fmt::Display for AttributeType { } pub type AttributeNames = std::collections::HashMap; - pub type AttributeValues = std::collections::HashMap; pub struct Attributes(AttributeValues); @@ -129,109 +129,6 @@ pub trait FromStringSetItem: Sized { fn from_ss_item(value: String) -> Result; } -impl IntoAttribute for String { - fn into_attr(self) -> AttributeValue { - // Empty String is allowed since 2020/5 - // https://aws.amazon.com/jp/about-aws/whats-new/2020/05/amazon-dynamodb-now-supports-empty-values-for-non-key-string-and-binary-attributes-in-dynamodb-tables/ - AttributeValue { - s: Some(self), - ..AttributeValue::default() - } - } -} - -impl FromAttribute for String { - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Err(ConversionError::ValueIsNone); - } - let value = value.unwrap(); - if let Some(true) = value.null { - // See. https://github.com/raiden-rs/raiden/issues/58 - return Ok("".to_owned()); - } - value.s.ok_or(ConversionError::ValueIsNone) - } -} - -impl IntoAttribute for &'_ str { - fn into_attr(self) -> AttributeValue { - if self.is_empty() { - // See. https://github.com/raiden-rs/raiden-dynamo/issues/58 - return AttributeValue { - null: Some(true), - ..Default::default() - }; - } - AttributeValue { - s: Some(self.to_owned()), - ..AttributeValue::default() - } - } -} - -impl<'a> IntoAttribute for std::borrow::Cow<'a, str> { - fn into_attr(self) -> AttributeValue { - let s = match self { - std::borrow::Cow::Owned(o) => o, - std::borrow::Cow::Borrowed(b) => b.to_owned(), - }; - if s.is_empty() { - // See. https://github.com/raiden-rs/raiden-dynamo/issues/58 - return AttributeValue { - null: Some(true), - ..Default::default() - }; - } - AttributeValue { - s: Some(s), - ..AttributeValue::default() - } - } -} - -impl<'a> FromAttribute for std::borrow::Cow<'a, str> { - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Err(ConversionError::ValueIsNone); - } - let value = value.unwrap(); - if let Some(true) = value.null { - // See. https://github.com/raiden-rs/raiden/issues/58 - return Ok(std::borrow::Cow::Owned("".to_owned())); - } - value - .s - .map(std::borrow::Cow::Owned) - .ok_or(ConversionError::ValueIsNone) - } -} - -macro_rules! default_attr_for_num { - ($to: ty) => { - impl IntoAttribute for $to { - fn into_attr(self) -> AttributeValue { - AttributeValue { - n: Some(format!("{}", self)), - ..AttributeValue::default() - } - } - } - impl FromAttribute for $to { - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Err(ConversionError::ValueIsNone); - } - value - .unwrap() - .n - .map(|v| v.parse().unwrap()) - .ok_or(ConversionError::ValueIsNone) - } - } - }; -} - default_attr_for_num!(usize); default_attr_for_num!(u64); default_attr_for_num!(u32); @@ -247,49 +144,6 @@ default_attr_for_num!(i8); default_attr_for_num!(f32); default_attr_for_num!(f64); -impl IntoAttribute for Option { - fn into_attr(self) -> AttributeValue { - match self { - Some(value) => value.into_attr(), - _ => AttributeValue { - null: Some(true), - ..Default::default() - }, - } - } -} - -impl FromAttribute for Option { - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Ok(None); - } - let value = value.unwrap(); - match value.null { - Some(true) => Ok(None), - _ => Ok(Some(FromAttribute::from_attr(Some(value))?)), - } - } -} - -impl IntoAttribute for bool { - fn into_attr(self) -> AttributeValue { - AttributeValue { - bool: Some(self), - ..AttributeValue::default() - } - } -} - -impl FromAttribute for bool { - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Err(ConversionError::ValueIsNone); - } - value.unwrap().bool.ok_or(ConversionError::ValueIsNone) - } -} - impl IntoStringSetItem for String { fn into_ss_item(self) -> String { self @@ -302,78 +156,6 @@ impl FromStringSetItem for String { } } -impl IntoAttribute for Vec { - fn into_attr(mut self) -> AttributeValue { - if self.is_empty() { - // See. https://github.com/raiden-rs/raiden/issues/57 - return AttributeValue { - null: Some(true), - ..Default::default() - }; - } - AttributeValue { - l: Some(self.drain(..).map(|s| s.into_attr()).collect()), - ..AttributeValue::default() - } - } -} - -impl FromAttribute for Vec { - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Ok(vec![]); - } - let value = value.unwrap(); - if let Some(true) = value.null { - // See. https://github.com/raiden-rs/raiden/issues/57 - return Ok(vec![]); - } - value - .l - .ok_or(ConversionError::ValueIsNone)? - .into_iter() - .map(|item| A::from_attr(Some(item))) - .collect() - } -} - -macro_rules! default_number_hash_set_convertor { - ($to: ty) => { - impl IntoAttribute for std::collections::HashSet<$to> { - fn into_attr(self) -> AttributeValue { - if self.is_empty() { - // See. https://github.com/raiden-rs/raiden/issues/57 - // https://github.com/raiden-rs/raiden-dynamo/issues/64 - return AttributeValue::default(); - } - AttributeValue { - ns: Some(self.into_iter().map(|s| s.to_string()).collect()), - ..AttributeValue::default() - } - } - } - - impl FromAttribute for std::collections::HashSet<$to> { - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Ok(std::collections::HashSet::new()); - } - let value = value.unwrap(); - if let Some(true) = value.null { - // See. https://github.com/raiden-rs/raiden/issues/57 - return Ok(std::collections::HashSet::new()); - } - let mut nums = value.ns.ok_or(ConversionError::ValueIsNone)?; - let mut results: Vec> = nums - .drain(..) - .map(|ns| ns.parse().map_err(|_| ConversionError::ParseInt)) - .collect(); - results.drain(..).collect() - } - } - }; -} - default_number_hash_set_convertor!(usize); default_number_hash_set_convertor!(u64); default_number_hash_set_convertor!(u32); @@ -386,43 +168,6 @@ default_number_hash_set_convertor!(i32); default_number_hash_set_convertor!(i16); default_number_hash_set_convertor!(i8); -macro_rules! default_number_btree_set_convertor { - ($to: ty) => { - impl IntoAttribute for std::collections::BTreeSet<$to> { - fn into_attr(self) -> AttributeValue { - if self.is_empty() { - // See. https://github.com/raiden-rs/raiden/issues/57 - // https://github.com/raiden-rs/raiden-dynamo/issues/64 - return AttributeValue::default(); - } - AttributeValue { - ns: Some(self.into_iter().map(|s| s.to_string()).collect()), - ..AttributeValue::default() - } - } - } - - impl FromAttribute for std::collections::BTreeSet<$to> { - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Ok(std::collections::BTreeSet::new()); - } - let value = value.unwrap(); - if let Some(true) = value.null { - // See. https://github.com/raiden-rs/raiden/issues/57 - return Ok(std::collections::BTreeSet::new()); - } - let mut nums = value.ns.ok_or(ConversionError::ValueIsNone)?; - let mut results: Vec> = nums - .drain(..) - .map(|ns| ns.parse().map_err(|_| ConversionError::ParseInt)) - .collect(); - results.drain(..).collect() - } - } - }; -} - default_number_btree_set_convertor!(usize); default_number_btree_set_convertor!(u64); default_number_btree_set_convertor!(u32); @@ -435,66 +180,6 @@ default_number_btree_set_convertor!(i32); default_number_btree_set_convertor!(i16); default_number_btree_set_convertor!(i8); -impl IntoAttribute for std::collections::HashSet { - fn into_attr(self) -> AttributeValue { - if self.is_empty() { - // See. https://github.com/raiden-rs/raiden/issues/57 - // https://github.com/raiden-rs/raiden-dynamo/issues/64 - return AttributeValue::default(); - } - AttributeValue { - ss: Some(self.into_iter().map(|s| s.into_ss_item()).collect()), - ..AttributeValue::default() - } - } -} - -impl FromAttribute - for std::collections::HashSet -{ - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Ok(std::collections::HashSet::new()); - } - let value = value.unwrap(); - if let Some(true) = value.null { - // See. https://github.com/raiden-rs/raiden/issues/57 - return Ok(std::collections::HashSet::new()); - } - let mut ss = value.ss.ok_or(ConversionError::ValueIsNone)?; - ss.drain(..).map(A::from_ss_item).collect() - } -} - -impl IntoAttribute for std::collections::BTreeSet { - fn into_attr(self) -> AttributeValue { - if self.is_empty() { - // See. https://github.com/raiden-rs/raiden/issues/57 - // https://github.com/raiden-rs/raiden-dynamo/issues/64 - return AttributeValue::default(); - } - AttributeValue { - ss: Some(self.into_iter().map(|s| s.into_ss_item()).collect()), - ..AttributeValue::default() - } - } -} - -impl FromAttribute for std::collections::BTreeSet { - fn from_attr(value: Option) -> Result { - if value.is_none() { - return Ok(std::collections::BTreeSet::new()); - } - let value = value.unwrap(); - if let Some(true) = value.null { - // See. https://github.com/raiden-rs/raiden/issues/57 - return Ok(std::collections::BTreeSet::new()); - } - let mut ss = value.ss.ok_or(ConversionError::ValueIsNone)?; - ss.drain(..).map(A::from_ss_item).collect() - } -} - pub trait ResolveAttribute: Sized + FromAttribute { fn resolve_attr( key: &str, @@ -504,18 +189,9 @@ pub trait ResolveAttribute: Sized + FromAttribute { } } -pub struct GetItemController<'a> { - pub client: &'a DynamoDbClient, - pub item: GetItemInput, -} - pub fn merge_map( map1: std::collections::HashMap, map2: std::collections::HashMap, ) -> std::collections::HashMap { map1.into_iter().chain(map2).collect() } - -pub fn is_attr_value_empty(a: &AttributeValue) -> bool { - a == &AttributeValue::default() -} diff --git a/raiden/src/next_token/mod.rs b/raiden/src/next_token/mod.rs index ad273700..570c4aed 100644 --- a/raiden/src/next_token/mod.rs +++ b/raiden/src/next_token/mod.rs @@ -19,16 +19,11 @@ impl NextToken { Err(_) => return Err(super::RaidenError::NextTokenDecodeError), }; - let deserialized: std::collections::HashMap = - match serde_json::from_str(s) { - Ok(deserialized) => deserialized, - Err(_) => return Err(super::RaidenError::NextTokenDecodeError), - }; - Ok(deserialized) + crate::deserialize_attr_value(s) } pub fn from_attr(key: &super::AttributeValues) -> Self { - let serialized = serde_json::to_string(key).expect("should serialize"); + let serialized = crate::serialize_attr_values(key); Self(STANDARD.encode(serialized)) } } diff --git a/raiden/src/ops/batch_delete.rs b/raiden/src/ops/batch_delete.rs index d740592f..20eece32 100644 --- a/raiden/src/ops/batch_delete.rs +++ b/raiden/src/ops/batch_delete.rs @@ -1,7 +1,9 @@ -use serde::{Deserialize, Serialize}; - // See. https://github.com/rusoto/rusoto/blob/69e7c9150d98916ef8fc814f5cd17eb0e4dee3d3/rusoto/services/dynamodb/src/generated.rs#L395 -#[derive(Default, Debug, Clone, PartialEq, Deserialize, Serialize)] +#[derive(Default, Debug, Clone, PartialEq)] +#[cfg_attr( + any(feature = "rusoto", feature = "rusoto_rustls"), + derive(serde::Deserialize, serde::Serialize) +)] pub struct BatchDeleteOutput { pub consumed_capacity: Option>, pub unprocessed_items: Vec, diff --git a/raiden/src/ops/batch_get.rs b/raiden/src/ops/batch_get.rs index 432144a1..77727259 100644 --- a/raiden/src/ops/batch_get.rs +++ b/raiden/src/ops/batch_get.rs @@ -1,7 +1,9 @@ -use serde::{Deserialize, Serialize}; - // See. https://github.com/rusoto/rusoto/blob/69e7c9150d98916ef8fc814f5cd17eb0e4dee3d3/rusoto/services/dynamodb/src/generated.rs#L356 -#[derive(Default, Debug, Clone, PartialEq, Deserialize, Serialize)] +#[derive(Default, Debug, Clone, PartialEq)] +#[cfg_attr( + any(feature = "rusoto", feature = "rusoto_rustls"), + derive(serde::Deserialize, serde::Serialize) +)] pub struct BatchGetOutput { pub consumed_capacity: Option>, pub items: Vec, diff --git a/raiden/src/ops/get.rs b/raiden/src/ops/get.rs index 3a68e68f..77814491 100644 --- a/raiden/src/ops/get.rs +++ b/raiden/src/ops/get.rs @@ -1,7 +1,9 @@ -use serde::{Deserialize, Serialize}; - // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L1168 -#[derive(Default, Debug, Clone, PartialEq, Deserialize, Serialize)] +#[derive(Default, Debug, Clone, PartialEq)] +#[cfg_attr( + any(feature = "rusoto", feature = "rusoto_rustls"), + derive(serde::Deserialize, serde::Serialize) +)] pub struct GetOutput { pub consumed_capacity: Option, pub item: T, diff --git a/raiden/src/ops/put.rs b/raiden/src/ops/put.rs index 16927619..d9d75b31 100644 --- a/raiden/src/ops/put.rs +++ b/raiden/src/ops/put.rs @@ -1,7 +1,9 @@ -use serde::{Deserialize, Serialize}; - // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L1168 -#[derive(Default, Debug, Clone, PartialEq, Deserialize, Serialize)] +#[derive(Default, Debug, Clone, PartialEq)] +#[cfg_attr( + any(feature = "rusoto", feature = "rusoto_rustls"), + derive(serde::Deserialize, serde::Serialize) +)] pub struct PutOutput { pub consumed_capacity: Option, pub item: T, diff --git a/raiden/src/ops/query.rs b/raiden/src/ops/query.rs index 091af0fa..539f9cb9 100644 --- a/raiden/src/ops/query.rs +++ b/raiden/src/ops/query.rs @@ -1,7 +1,9 @@ -use serde::{Deserialize, Serialize}; - // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L1168 -#[derive(Default, Debug, Clone, PartialEq, Deserialize, Serialize)] +#[derive(Default, Debug, Clone, PartialEq)] +#[cfg_attr( + any(feature = "rusoto", feature = "rusoto_rustls"), + derive(serde::Deserialize, serde::Serialize) +)] pub struct QueryOutput { pub consumed_capacity: Option, pub items: Vec, diff --git a/raiden/src/ops/scan.rs b/raiden/src/ops/scan.rs index 6038e984..6d2a5641 100644 --- a/raiden/src/ops/scan.rs +++ b/raiden/src/ops/scan.rs @@ -1,7 +1,9 @@ -use serde::{Deserialize, Serialize}; - // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L2406 -#[derive(Default, Debug, Clone, PartialEq, Deserialize, Serialize)] +#[derive(Default, Debug, Clone, PartialEq)] +#[cfg_attr( + any(feature = "rusoto", feature = "rusoto_rustls"), + derive(serde::Deserialize, serde::Serialize) +)] pub struct ScanOutput { pub consumed_capacity: Option, pub items: Vec, diff --git a/raiden/src/ops/transact_write.rs b/raiden/src/ops/transact_write.rs index e53c31b6..bf38d8ce 100644 --- a/raiden/src/ops/transact_write.rs +++ b/raiden/src/ops/transact_write.rs @@ -1,110 +1,3 @@ -use crate::{DynamoDb, TransactWriteItem}; - -pub struct WriteTx { - items: Vec, - client: crate::DynamoDbClient, - retry_condition: crate::RetryCondition, -} -impl WriteTx { - pub fn new(region: crate::Region) -> Self { - let client = crate::DynamoDbClient::new(region); - Self { - items: vec![], - client, - retry_condition: crate::RetryCondition::new(), - } - } - pub fn new_with_client(client: crate::Client, region: crate::Region) -> Self { - let client = crate::DynamoDbClient::new_with_client(client, region); - Self { - items: vec![], - client, - retry_condition: crate::RetryCondition::new(), - } - } - - pub fn with_retries(mut self, s: Box) -> Self { - self.retry_condition.strategy = s; - self - } - - pub fn put(mut self, builder: impl TransactWritePutBuilder) -> Self { - self.items.push(TransactWriteItem { - condition_check: None, - delete: None, - update: None, - put: Some(builder.build()), - }); - self - } - - pub fn update(mut self, builder: impl TransactWriteUpdateBuilder) -> Self { - self.items.push(TransactWriteItem { - condition_check: None, - delete: None, - update: Some(builder.build()), - put: None, - }); - self - } - - pub fn delete(mut self, builder: impl TransactWriteDeleteBuilder) -> Self { - self.items.push(TransactWriteItem { - condition_check: None, - delete: Some(builder.build()), - update: None, - put: None, - }); - self - } - - pub fn condition_check(mut self, builder: impl TransactWriteConditionCheckBuilder) -> Self { - self.items.push(TransactWriteItem { - condition_check: Some(builder.build()), - delete: None, - update: None, - put: None, - }); - self - } - - pub async fn run(self) -> Result<(), crate::RaidenError> { - let policy: crate::RetryPolicy = self.retry_condition.strategy.policy().into(); - let client = self.client; - let input = crate::TransactWriteItemsInput { - client_request_token: None, - return_consumed_capacity: None, - return_item_collection_metrics: None, - transact_items: self.items, - }; - policy - .retry_if( - move || { - let client = client.clone(); - let input = input.clone(); - async { WriteTx::inner_run(client, input).await } - }, - &self.retry_condition, - ) - .await - } - - #[cfg_attr(feature = "tracing", tracing::instrument( - level = tracing::Level::DEBUG, - name = "dynamodb::action", - skip_all, - fields(api = "transact_write_items") - ))] - async fn inner_run( - client: crate::DynamoDbClient, - input: crate::TransactWriteItemsInput, - ) -> Result<(), crate::RaidenError> { - let _res = client.transact_write_items(input).await?; - // TODO: ADD Resp - Ok(()) - } -} - pub trait TransactWritePutBuilder { fn build(self) -> crate::Put; } diff --git a/raiden/src/ops/update.rs b/raiden/src/ops/update.rs index 6e0ca91b..9c7087c2 100644 --- a/raiden/src/ops/update.rs +++ b/raiden/src/ops/update.rs @@ -1,7 +1,9 @@ -use serde::{Deserialize, Serialize}; - // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L2971 -#[derive(Default, Debug, Clone, PartialEq, Deserialize, Serialize)] +#[derive(Default, Debug, Clone, PartialEq)] +#[cfg_attr( + any(feature = "rusoto", feature = "rusoto_rustls"), + derive(serde::Deserialize, serde::Serialize) +)] pub struct UpdateOutput { pub consumed_capacity: Option, pub item: Option, diff --git a/raiden/src/retry/mod.rs b/raiden/src/retry/mod.rs index abd95922..465694e0 100644 --- a/raiden/src/retry/mod.rs +++ b/raiden/src/retry/mod.rs @@ -69,7 +69,8 @@ pub struct DefaultRetryStrategy; impl RetryStrategy for DefaultRetryStrategy { fn should_retry(&self, error: &RaidenError) -> bool { - matches!( + #[cfg(any(feature = "rusoto", feature = "rustls"))] + return matches!( error, RaidenError::InternalServerError(_) | RaidenError::ProvisionedThroughputExceeded(_) @@ -82,7 +83,21 @@ impl RetryStrategy for DefaultRetryStrategy { // This is because, sometimes throttlingException is included in unknown error. // please make more rigorous classification of errors. | RaidenError::Unknown(_) - ) + ); + + #[cfg(feature = "aws-sdk")] + return matches!( + error, + RaidenError::InternalServerError(_) + | RaidenError::ProvisionedThroughputExceeded(_) + | RaidenError::RequestLimitExceeded(_) + | RaidenError::HttpDispatch(_) + | RaidenError::Timeout(_) + // INFO: For now, return true, when unknown error detected. + // This is because, sometimes throttlingException is included in unknown error. + // please make more rigorous classification of errors. + | RaidenError::Unknown(_) + ); } fn policy(&self) -> Policy { diff --git a/raiden/src/rusoto/errors.rs b/raiden/src/rusoto/errors.rs new file mode 100644 index 00000000..525ec866 --- /dev/null +++ b/raiden/src/rusoto/errors.rs @@ -0,0 +1,209 @@ +use crate::*; + +fn into_raiden_error(err: RusotoError) -> RaidenError { + match err { + RusotoError::HttpDispatch(err) => RaidenError::HttpDispatch(err), + RusotoError::Credentials(err) => RaidenError::Credentials(err), + RusotoError::Validation(msg) => RaidenError::Validation(msg), + RusotoError::ParseError(msg) => RaidenError::ParseError(msg), + RusotoError::Unknown(res) => RaidenError::Unknown(res), + RusotoError::Blocking => RaidenError::Blocking, + RusotoError::Service(_) => unimplemented!("RusotoError::Service should be handled."), + } +} + +impl From> for RaidenError { + fn from(error: RusotoError) -> Self { + match error { + RusotoError::Service(error) => match error { + BatchGetItemError::InternalServerError(msg) => { + RaidenError::InternalServerError(msg) + } + BatchGetItemError::ProvisionedThroughputExceeded(msg) => { + RaidenError::ProvisionedThroughputExceeded(msg) + } + BatchGetItemError::RequestLimitExceeded(msg) => { + RaidenError::RequestLimitExceeded(msg) + } + BatchGetItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: RusotoError) -> Self { + match error { + RusotoError::Service(error) => match error { + BatchWriteItemError::InternalServerError(msg) => { + RaidenError::InternalServerError(msg) + } + BatchWriteItemError::ItemCollectionSizeLimitExceeded(msg) => { + RaidenError::ItemCollectionSizeLimitExceeded(msg) + } + BatchWriteItemError::ProvisionedThroughputExceeded(msg) => { + RaidenError::ProvisionedThroughputExceeded(msg) + } + BatchWriteItemError::RequestLimitExceeded(msg) => { + RaidenError::RequestLimitExceeded(msg) + } + BatchWriteItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: RusotoError) -> Self { + match error { + RusotoError::Service(error) => match error { + GetItemError::InternalServerError(msg) => RaidenError::InternalServerError(msg), + GetItemError::ProvisionedThroughputExceeded(msg) => { + RaidenError::ProvisionedThroughputExceeded(msg) + } + GetItemError::RequestLimitExceeded(msg) => RaidenError::RequestLimitExceeded(msg), + GetItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: RusotoError) -> Self { + match error { + RusotoError::Service(error) => match error { + QueryError::InternalServerError(msg) => RaidenError::InternalServerError(msg), + QueryError::ProvisionedThroughputExceeded(msg) => { + RaidenError::ProvisionedThroughputExceeded(msg) + } + QueryError::RequestLimitExceeded(msg) => RaidenError::RequestLimitExceeded(msg), + QueryError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: RusotoError) -> Self { + match error { + RusotoError::Service(error) => match error { + ScanError::InternalServerError(msg) => RaidenError::InternalServerError(msg), + ScanError::ProvisionedThroughputExceeded(msg) => { + RaidenError::ProvisionedThroughputExceeded(msg) + } + ScanError::RequestLimitExceeded(msg) => RaidenError::RequestLimitExceeded(msg), + ScanError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: RusotoError) -> Self { + match error { + RusotoError::Service(error) => match error { + PutItemError::InternalServerError(msg) => RaidenError::InternalServerError(msg), + PutItemError::ProvisionedThroughputExceeded(msg) => { + RaidenError::ProvisionedThroughputExceeded(msg) + } + PutItemError::RequestLimitExceeded(msg) => RaidenError::RequestLimitExceeded(msg), + PutItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), + PutItemError::ConditionalCheckFailed(msg) => { + RaidenError::ConditionalCheckFailed(msg) + } + PutItemError::ItemCollectionSizeLimitExceeded(msg) => { + RaidenError::ItemCollectionSizeLimitExceeded(msg) + } + PutItemError::TransactionConflict(msg) => RaidenError::TransactionConflict(msg), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: RusotoError) -> Self { + match error { + RusotoError::Service(error) => match error { + UpdateItemError::InternalServerError(msg) => RaidenError::InternalServerError(msg), + UpdateItemError::ProvisionedThroughputExceeded(msg) => { + RaidenError::ProvisionedThroughputExceeded(msg) + } + UpdateItemError::RequestLimitExceeded(msg) => { + RaidenError::RequestLimitExceeded(msg) + } + UpdateItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), + UpdateItemError::ConditionalCheckFailed(msg) => { + RaidenError::ConditionalCheckFailed(msg) + } + UpdateItemError::ItemCollectionSizeLimitExceeded(msg) => { + RaidenError::ItemCollectionSizeLimitExceeded(msg) + } + UpdateItemError::TransactionConflict(msg) => RaidenError::TransactionConflict(msg), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: RusotoError) -> Self { + match error { + RusotoError::Service(error) => match error { + DeleteItemError::InternalServerError(msg) => RaidenError::InternalServerError(msg), + DeleteItemError::ProvisionedThroughputExceeded(msg) => { + RaidenError::ProvisionedThroughputExceeded(msg) + } + DeleteItemError::RequestLimitExceeded(msg) => { + RaidenError::RequestLimitExceeded(msg) + } + DeleteItemError::ResourceNotFound(msg) => RaidenError::ResourceNotFound(msg), + DeleteItemError::ConditionalCheckFailed(msg) => { + RaidenError::ConditionalCheckFailed(msg) + } + DeleteItemError::ItemCollectionSizeLimitExceeded(msg) => { + RaidenError::ItemCollectionSizeLimitExceeded(msg) + } + DeleteItemError::TransactionConflict(msg) => RaidenError::TransactionConflict(msg), + }, + _ => into_raiden_error(error), + } + } +} + +impl From> for RaidenError { + fn from(error: RusotoError) -> Self { + match error { + RusotoError::Service(error) => match error { + TransactWriteItemsError::IdempotentParameterMismatch(msg) => { + RaidenError::IdempotentParameterMismatch(msg) + } + TransactWriteItemsError::InternalServerError(msg) => { + RaidenError::InternalServerError(msg) + } + TransactWriteItemsError::ProvisionedThroughputExceeded(msg) => { + RaidenError::ProvisionedThroughputExceeded(msg) + } + TransactWriteItemsError::RequestLimitExceeded(msg) => { + RaidenError::RequestLimitExceeded(msg) + } + TransactWriteItemsError::ResourceNotFound(msg) => { + RaidenError::ResourceNotFound(msg) + } + TransactWriteItemsError::TransactionCanceled(msg) => { + let reasons = RaidenTransactionCancellationReasons::from_str(&msg); + RaidenError::TransactionCanceled { reasons } + } + TransactWriteItemsError::TransactionInProgress(msg) => { + RaidenError::TransactionInProgress(msg) + } + }, + _ => into_raiden_error(error), + } + } +} diff --git a/raiden/src/rusoto/mod.rs b/raiden/src/rusoto/mod.rs new file mode 100644 index 00000000..ebbdaaa5 --- /dev/null +++ b/raiden/src/rusoto/mod.rs @@ -0,0 +1,372 @@ +mod errors; +mod ops; + +#[cfg(feature = "rusoto")] +pub use rusoto_dynamodb_default::*; + +#[cfg(feature = "rusoto")] +pub use rusoto_core_default::*; + +#[cfg(feature = "rustls")] +pub use rusoto_dynamodb_rustls::*; + +#[cfg(feature = "rustls")] +pub use rusoto_core_rustls::*; + +pub use self::{errors::*, ops::*}; +pub use rusoto_credential::*; + +use std::collections::{BTreeSet, HashSet}; + +use crate::{ + AttributeType, AttributeValues, ConversionError, FromAttribute, FromStringSetItem, + IntoAttribute, IntoStringSetItem, RaidenError, +}; + +impl IntoAttribute for AttributeType { + fn into_attr(self) -> AttributeValue { + AttributeValue { + s: Some(self.to_string()), + ..AttributeValue::default() + } + } +} + +impl IntoAttribute for String { + fn into_attr(self) -> AttributeValue { + // Empty String is allowed since 2020/5 + // https://aws.amazon.com/jp/about-aws/whats-new/2020/05/amazon-dynamodb-now-supports-empty-values-for-non-key-string-and-binary-attributes-in-dynamodb-tables/ + AttributeValue { + s: Some(self), + ..AttributeValue::default() + } + } +} + +impl FromAttribute for String { + fn from_attr(value: Option) -> Result { + match value { + // See. https://github.com/raiden-rs/raiden/issues/58 + Some(AttributeValue { null: Some(v), .. }) if v => Ok("".to_owned()), + Some(AttributeValue { s: Some(v), .. }) => Ok(v), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +impl IntoAttribute for &'_ str { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden-dynamo/issues/58 + AttributeValue { + null: Some(true), + ..Default::default() + } + } else { + AttributeValue { + s: Some(self.to_owned()), + ..AttributeValue::default() + } + } + } +} + +impl<'a> IntoAttribute for std::borrow::Cow<'a, str> { + fn into_attr(self) -> AttributeValue { + let s = match self { + std::borrow::Cow::Owned(o) => o, + std::borrow::Cow::Borrowed(b) => b.to_owned(), + }; + + if s.is_empty() { + // See. https://github.com/raiden-rs/raiden-dynamo/issues/58 + AttributeValue { + null: Some(true), + ..Default::default() + } + } else { + AttributeValue { + s: Some(s), + ..AttributeValue::default() + } + } + } +} + +impl<'a> FromAttribute for std::borrow::Cow<'a, str> { + fn from_attr(value: Option) -> Result { + match value { + // See. https://github.com/raiden-rs/raiden/issues/58 + Some(AttributeValue { null: Some(v), .. }) if v => { + Ok(std::borrow::Cow::Owned("".to_owned())) + } + Some(AttributeValue { s: Some(v), .. }) => Ok(std::borrow::Cow::Owned(v.to_owned())), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +macro_rules! default_attr_for_num { + ($to: ty) => { + impl IntoAttribute for $to { + fn into_attr(self) -> AttributeValue { + AttributeValue { + n: Some(format!("{self}")), + ..AttributeValue::default() + } + } + } + + impl FromAttribute for $to { + fn from_attr(value: Option) -> Result { + if let Some(AttributeValue { n: Some(v), .. }) = value { + Ok(v.parse().unwrap()) + } else { + Err(ConversionError::ValueIsNone) + } + } + } + }; +} + +pub(crate) use default_attr_for_num; + +impl IntoAttribute for Option { + fn into_attr(self) -> AttributeValue { + if let Some(value) = self { + value.into_attr() + } else { + AttributeValue { + null: Some(true), + ..Default::default() + } + } + } +} + +impl FromAttribute for Option { + fn from_attr(value: Option) -> Result { + Ok(if let Some(v) = value { + Some(FromAttribute::from_attr(Some(v))?) + } else { + None + }) + } +} + +impl IntoAttribute for bool { + fn into_attr(self) -> AttributeValue { + AttributeValue { + bool: Some(self), + ..AttributeValue::default() + } + } +} + +impl FromAttribute for bool { + fn from_attr(value: Option) -> Result { + if let Some(AttributeValue { bool: Some(v), .. }) = value { + Ok(v) + } else { + Err(ConversionError::ValueIsNone) + } + } +} + +impl IntoAttribute for Vec { + fn into_attr(mut self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + AttributeValue { + null: Some(true), + ..Default::default() + } + } else { + AttributeValue { + l: Some(self.drain(..).map(|s| s.into_attr()).collect()), + ..AttributeValue::default() + } + } + } +} + +impl FromAttribute for Vec { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue { l: Some(v), .. }) => { + v.into_iter().map(|item| A::from_attr(Some(item))).collect() + } + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(AttributeValue { + null: Some(true), .. + }) + | None => Ok(vec![]), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +macro_rules! default_number_hash_set_convertor { + ($to: ty) => { + impl IntoAttribute for std::collections::HashSet<$to> { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + AttributeValue::default() + } else { + AttributeValue { + ns: Some(self.into_iter().map(|s| s.to_string()).collect()), + ..AttributeValue::default() + } + } + } + } + + impl FromAttribute for std::collections::HashSet<$to> { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue { + ns: Some(mut nums), .. + }) => { + let mut results: Vec> = nums + .drain(..) + .map(|ns| ns.parse().map_err(|_| ConversionError::ParseInt)) + .collect(); + + results.drain(..).collect() + } + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(AttributeValue { + null: Some(true), .. + }) + | None => Ok(std::collections::HashSet::new()), + _ => Err(ConversionError::ValueIsNone), + } + } + } + }; +} + +pub(crate) use default_number_hash_set_convertor; + +macro_rules! default_number_btree_set_convertor { + ($to: ty) => { + impl IntoAttribute for std::collections::BTreeSet<$to> { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + AttributeValue::default() + } else { + AttributeValue { + ns: Some(self.into_iter().map(|s| s.to_string()).collect()), + ..AttributeValue::default() + } + } + } + } + + impl FromAttribute for std::collections::BTreeSet<$to> { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue { + ns: Some(mut nums), .. + }) => { + let mut results: Vec> = nums + .drain(..) + .map(|ns| ns.parse().map_err(|_| ConversionError::ParseInt)) + .collect(); + + results.drain(..).collect() + } + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(AttributeValue { + null: Some(true), .. + }) + | None => Ok(std::collections::BTreeSet::new()), + _ => Err(ConversionError::ValueIsNone), + } + } + } + }; +} + +pub(crate) use default_number_btree_set_convertor; + +impl IntoAttribute for HashSet { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + AttributeValue::default() + } else { + AttributeValue { + ss: Some(self.into_iter().map(|s| s.into_ss_item()).collect()), + ..AttributeValue::default() + } + } + } +} + +impl FromAttribute for HashSet { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue { + ss: Some(mut ss), .. + }) => ss.drain(..).map(A::from_ss_item).collect(), + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(AttributeValue { + null: Some(true), .. + }) + | None => Ok(HashSet::new()), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +impl IntoAttribute for BTreeSet { + fn into_attr(self) -> AttributeValue { + if self.is_empty() { + // See. https://github.com/raiden-rs/raiden/issues/57 + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + AttributeValue::default() + } else { + AttributeValue { + ss: Some(self.into_iter().map(|s| s.into_ss_item()).collect()), + ..AttributeValue::default() + } + } + } +} + +impl FromAttribute for BTreeSet { + fn from_attr(value: Option) -> Result { + match value { + Some(AttributeValue { + ss: Some(mut ss), .. + }) => ss.drain(..).map(A::from_ss_item).collect(), + // See. https://github.com/raiden-rs/raiden/issues/57 + Some(AttributeValue { + null: Some(true), .. + }) + | None => Ok(BTreeSet::new()), + _ => Err(ConversionError::ValueIsNone), + } + } +} + +pub fn is_attr_value_empty(a: &AttributeValue) -> bool { + a == &AttributeValue::default() +} + +pub(crate) fn deserialize_attr_value(s: &str) -> Result { + match serde_json::from_str(s) { + Ok(deserialized) => Ok(deserialized), + Err(_) => Err(super::RaidenError::NextTokenDecodeError), + } +} + +pub(crate) fn serialize_attr_values(value: &AttributeValues) -> String { + serde_json::to_string(value).expect("should serialize") +} diff --git a/raiden/src/rusoto/ops.rs b/raiden/src/rusoto/ops.rs new file mode 100644 index 00000000..cd1c50fd --- /dev/null +++ b/raiden/src/rusoto/ops.rs @@ -0,0 +1,116 @@ +pub use transact_write::*; +pub mod transact_write { + use crate::{ + DynamoDb, TransactWriteConditionCheckBuilder, TransactWriteDeleteBuilder, + TransactWriteItem, TransactWritePutBuilder, TransactWriteUpdateBuilder, + }; + + pub struct WriteTx { + items: Vec, + client: crate::DynamoDbClient, + retry_condition: crate::RetryCondition, + } + + impl WriteTx { + pub fn new(region: crate::Region) -> Self { + Self { + items: vec![], + client: crate::DynamoDbClient::new(region), + retry_condition: crate::RetryCondition::new(), + } + } + + pub fn new_with_client(client: crate::Client, region: crate::Region) -> Self { + Self { + items: vec![], + client: crate::DynamoDbClient::new_with_client(client, region), + retry_condition: crate::RetryCondition::new(), + } + } + + pub fn with_retries( + mut self, + s: Box, + ) -> Self { + self.retry_condition.strategy = s; + self + } + + pub fn put(mut self, builder: impl TransactWritePutBuilder) -> Self { + self.items.push(TransactWriteItem { + condition_check: None, + delete: None, + update: None, + put: Some(builder.build()), + }); + self + } + + pub fn update(mut self, builder: impl TransactWriteUpdateBuilder) -> Self { + self.items.push(TransactWriteItem { + condition_check: None, + delete: None, + update: Some(builder.build()), + put: None, + }); + self + } + + pub fn delete(mut self, builder: impl TransactWriteDeleteBuilder) -> Self { + self.items.push(TransactWriteItem { + condition_check: None, + delete: Some(builder.build()), + update: None, + put: None, + }); + self + } + + pub fn condition_check(mut self, builder: impl TransactWriteConditionCheckBuilder) -> Self { + self.items.push(TransactWriteItem { + condition_check: Some(builder.build()), + delete: None, + update: None, + put: None, + }); + self + } + + pub async fn run(self) -> Result<(), crate::RaidenError> { + let policy: crate::RetryPolicy = self.retry_condition.strategy.policy().into(); + let client = self.client; + let input = crate::TransactWriteItemsInput { + client_request_token: None, + return_consumed_capacity: None, + return_item_collection_metrics: None, + transact_items: self.items, + }; + + policy + .retry_if( + move || { + let client = client.clone(); + let input = input.clone(); + async { WriteTx::inner_run(client, input).await } + }, + &self.retry_condition, + ) + .await + } + + #[cfg_attr(feature = "tracing", tracing::instrument( + level = tracing::Level::DEBUG, + name = "dynamodb::action", + skip_all, + fields(api = "transact_write_items") + ))] + async fn inner_run( + client: crate::DynamoDbClient, + input: crate::TransactWriteItemsInput, + ) -> Result<(), crate::RaidenError> { + let _res = client.transact_write_items(input).await?; + // TODO: ADD Resp + Ok(()) + } + } +} diff --git a/raiden/src/update_expression/add.rs b/raiden/src/update_expression/add.rs index a2320ca5..1210a768 100644 --- a/raiden/src/update_expression/add.rs +++ b/raiden/src/update_expression/add.rs @@ -33,7 +33,12 @@ impl UpdateAddExpressionBuilder for AddExpressionFilled< // See. https://github.com/raiden-rs/raiden/issues/57 // https://github.com/raiden-rs/raiden/issues/58 - if value.null.is_some() || value == AttributeValue::default() { + #[cfg(any(feature = "rusoto", feature = "rustls"))] + let is_null = value.null.is_some(); + #[cfg(feature = "aws-sdk")] + let is_null = value.is_null(); + + if is_null || crate::is_attr_value_empty(&value) { return ("".to_owned(), names, values); } diff --git a/raiden/src/update_expression/delete.rs b/raiden/src/update_expression/delete.rs index 3531f8df..ed8fa10d 100644 --- a/raiden/src/update_expression/delete.rs +++ b/raiden/src/update_expression/delete.rs @@ -33,7 +33,12 @@ impl UpdateDeleteExpressionBuilder for DeleteExpressionF // See. https://github.com/raiden-rs/raiden/issues/57 // https://github.com/raiden-rs/raiden/issues/58 - if value.null.is_some() || value == AttributeValue::default() { + #[cfg(any(feature = "rusoto", feature = "rustls"))] + let is_null = value.null.is_some(); + #[cfg(feature = "aws-sdk")] + let is_null = value.is_null(); + + if is_null || crate::is_attr_value_empty(&value) { return ("".to_owned(), names, values); } diff --git a/raiden/src/update_expression/set.rs b/raiden/src/update_expression/set.rs index 3fbda230..07c60dde 100644 --- a/raiden/src/update_expression/set.rs +++ b/raiden/src/update_expression/set.rs @@ -137,7 +137,7 @@ impl UpdateSetExpressionBuilder for SetExpressionFilledW SetValue::Value(placeholder, value) => { // See. https://github.com/raiden-rs/raiden/issues/57 // https://github.com/raiden-rs/raiden/issues/58 - if value == AttributeValue::default() { + if crate::is_attr_value_empty(&value) { // Use remove instead of set return SetOrRemove::Remove(attr_name, names); } From a08c830f48838bf97261673f40a42c0a7a8dec12 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Sun, 29 Oct 2023 21:59:20 +0900 Subject: [PATCH 03/22] chore: implement derive macro for aws-sdk --- Cargo.lock | 9 +- compose.yaml | 19 + makefile | 6 +- raiden-derive/Cargo.toml | 8 +- raiden-derive/src/aws_sdk/client.rs | 86 ++++ raiden-derive/src/aws_sdk/mod.rs | 2 + raiden-derive/src/aws_sdk/ops/batch_delete.rs | 192 ++++++++ raiden-derive/src/aws_sdk/ops/batch_get.rs | 212 +++++++++ raiden-derive/src/aws_sdk/ops/delete.rs | 142 ++++++ raiden-derive/src/aws_sdk/ops/get.rs | 156 +++++++ raiden-derive/src/{ => aws_sdk}/ops/mod.rs | 0 raiden-derive/src/aws_sdk/ops/put.rs | 229 +++++++++ raiden-derive/src/aws_sdk/ops/query.rs | 223 +++++++++ raiden-derive/src/aws_sdk/ops/scan.rs | 152 ++++++ raiden-derive/src/aws_sdk/ops/shared.rs | 110 +++++ .../src/aws_sdk/ops/transact_write.rs | 434 ++++++++++++++++++ raiden-derive/src/aws_sdk/ops/update.rs | 360 +++++++++++++++ raiden-derive/src/lib.rs | 143 ++---- raiden-derive/src/rusoto/client.rs | 85 ++++ raiden-derive/src/rusoto/mod.rs | 2 + .../src/{ => rusoto}/ops/batch_delete.rs | 0 .../src/{ => rusoto}/ops/batch_get.rs | 0 raiden-derive/src/{ => rusoto}/ops/delete.rs | 0 raiden-derive/src/{ => rusoto}/ops/get.rs | 0 raiden-derive/src/rusoto/ops/mod.rs | 21 + raiden-derive/src/{ => rusoto}/ops/put.rs | 0 raiden-derive/src/{ => rusoto}/ops/query.rs | 0 raiden-derive/src/{ => rusoto}/ops/scan.rs | 0 raiden-derive/src/{ => rusoto}/ops/shared.rs | 0 .../src/{ => rusoto}/ops/transact_write.rs | 0 raiden-derive/src/{ => rusoto}/ops/update.rs | 0 raiden/Cargo.toml | 25 +- raiden/examples/delete.rs | 41 +- raiden/examples/get_with_reserved.rs | 37 +- raiden/examples/get_with_retries.rs | 49 +- raiden/examples/hello.rs | 61 ++- raiden/examples/last_key.rs | 61 ++- raiden/examples/put.rs | 69 ++- raiden/examples/query.rs | 63 ++- raiden/examples/query_rename.rs | 57 ++- raiden/examples/scan.rs | 38 +- raiden/examples/scan_with_filter.rs | 41 +- raiden/examples/transact_write.rs | 75 ++- .../transact_write_with_http_client.rs | 110 +++-- raiden/examples/update.rs | 63 ++- raiden/examples/with_http_client.rs | 76 ++- raiden/src/aws_sdk/errors.rs | 10 +- raiden/src/aws_sdk/mod.rs | 22 +- raiden/src/aws_sdk/ops/mod.rs | 25 +- raiden/src/aws_sdk/ops/transact_write.rs | 9 +- raiden/src/condition/mod.rs | 2 +- raiden/src/errors/mod.rs | 29 +- raiden/src/lib.rs | 29 +- raiden/src/retry/mod.rs | 2 +- raiden/src/rusoto/mod.rs | 4 +- raiden/src/update_expression/add.rs | 2 +- raiden/src/update_expression/delete.rs | 2 +- raiden/tests/all/get.rs | 29 +- raiden/tests/all/put.rs | 26 +- raiden/tests/all/transact_write.rs | 29 +- 60 files changed, 3241 insertions(+), 436 deletions(-) create mode 100644 compose.yaml create mode 100644 raiden-derive/src/aws_sdk/client.rs create mode 100644 raiden-derive/src/aws_sdk/mod.rs create mode 100644 raiden-derive/src/aws_sdk/ops/batch_delete.rs create mode 100644 raiden-derive/src/aws_sdk/ops/batch_get.rs create mode 100644 raiden-derive/src/aws_sdk/ops/delete.rs create mode 100644 raiden-derive/src/aws_sdk/ops/get.rs rename raiden-derive/src/{ => aws_sdk}/ops/mod.rs (100%) create mode 100644 raiden-derive/src/aws_sdk/ops/put.rs create mode 100644 raiden-derive/src/aws_sdk/ops/query.rs create mode 100644 raiden-derive/src/aws_sdk/ops/scan.rs create mode 100644 raiden-derive/src/aws_sdk/ops/shared.rs create mode 100644 raiden-derive/src/aws_sdk/ops/transact_write.rs create mode 100644 raiden-derive/src/aws_sdk/ops/update.rs create mode 100644 raiden-derive/src/rusoto/client.rs create mode 100644 raiden-derive/src/rusoto/mod.rs rename raiden-derive/src/{ => rusoto}/ops/batch_delete.rs (100%) rename raiden-derive/src/{ => rusoto}/ops/batch_get.rs (100%) rename raiden-derive/src/{ => rusoto}/ops/delete.rs (100%) rename raiden-derive/src/{ => rusoto}/ops/get.rs (100%) create mode 100644 raiden-derive/src/rusoto/ops/mod.rs rename raiden-derive/src/{ => rusoto}/ops/put.rs (100%) rename raiden-derive/src/{ => rusoto}/ops/query.rs (100%) rename raiden-derive/src/{ => rusoto}/ops/scan.rs (100%) rename raiden-derive/src/{ => rusoto}/ops/shared.rs (100%) rename raiden-derive/src/{ => rusoto}/ops/transact_write.rs (100%) rename raiden-derive/src/{ => rusoto}/ops/update.rs (100%) diff --git a/Cargo.lock b/Cargo.lock index c311af73..4111c0cd 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -272,7 +272,7 @@ dependencies = [ "http", "http-body", "hyper", - "hyper-rustls 0.24.1", + "hyper-rustls 0.24.2", "lazy_static", "pin-project-lite", "rustls 0.21.7", @@ -981,9 +981,9 @@ dependencies = [ [[package]] name = "hyper-rustls" -version = "0.24.1" +version = "0.24.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8d78e1e73ec14cf7375674f74d7dde185c8206fd9dea6fb6295e8a98098aaa97" +checksum = "ec3efd23720e2049821a693cbc7e65ea87c72f1c58ff2f9522ff332b1491e590" dependencies = [ "futures-util", "http", @@ -1436,11 +1436,14 @@ version = "0.1.0" dependencies = [ "again", "aws-config", + "aws-credential-types", "aws-sdk-dynamodb", + "aws-smithy-client", "aws-smithy-http", "aws-smithy-runtime-api", "aws-smithy-types", "base64 0.21.4", + "hyper-rustls 0.24.2", "paste", "pretty_assertions", "raiden", diff --git a/compose.yaml b/compose.yaml new file mode 100644 index 00000000..7097b32d --- /dev/null +++ b/compose.yaml @@ -0,0 +1,19 @@ +name: "raiden-rs-raiden-dynamo" + +services: + dynamodb: + image: "amazon/dynamodb-local:latest" + command: "-jar DynamoDBLocal.jar -sharedDb" + ports: + - "127.0.0.1:8000:8000" + + aws-cli: + image: "amazon/aws-cli:latest" + command: "dynamodb list-tables --endpoint-url http://dynamodb:8000" + depends_on: + - "dynamodb" + environment: + AWS_ACCESS_KEY_ID: "dummy" + AWS_SECRET_ACCESS_KEY: "dummy" + AWS_REGION: "ap-northeast-1" + restart: "on-failure" diff --git a/makefile b/makefile index 00352003..2c3d307f 100644 --- a/makefile +++ b/makefile @@ -1,8 +1,8 @@ .PHONY: dynamo dynamo: - - docker rm -f dynamodb - - docker stop dynamodb - docker run --rm -d --name dynamodb -p 8000:8000 amazon/dynamodb-local:latest + - docker compose down --volumes + docker compose up -d --wait dynamodb + docker compose up aws-cli deno run --allow-net=localhost:8000 --allow-env --no-check ./setup/setup.ts .PHONY: test diff --git a/raiden-derive/Cargo.toml b/raiden-derive/Cargo.toml index 263d251f..b5a18434 100644 --- a/raiden-derive/Cargo.toml +++ b/raiden-derive/Cargo.toml @@ -12,10 +12,12 @@ proc-macro = true [dependencies] convert_case = "^0.6.0" ident_case = "^1.0.1" -proc-macro2 = "^1.0.67" +proc-macro2 = "^1.0.69" quote = "^1.0.33" -syn = "^2.0.37" +syn = "^2.0.38" [features] -default = [] +default = ["rusoto"] +aws-sdk = [] +rusoto = [] tracing = [] diff --git a/raiden-derive/src/aws_sdk/client.rs b/raiden-derive/src/aws_sdk/client.rs new file mode 100644 index 00000000..1331d21f --- /dev/null +++ b/raiden-derive/src/aws_sdk/client.rs @@ -0,0 +1,86 @@ +use quote::*; +use syn::*; + +pub(crate) fn expand_client_constructor( + struct_name: &Ident, + client_name: &Ident, + dynamodb_client_name: &Ident, + table_name: &str, + fields: &FieldsNamed, + rename_all_type: &crate::rename::RenameAllType, +) -> proc_macro2::TokenStream { + let insertion_attribute_name = fields.named.iter().map(|f| { + let ident = &f.ident.clone().unwrap(); + let renamed = crate::finder::find_rename_value(&f.attrs); + let result = crate::create_renamed(ident.to_string(), renamed, *rename_all_type); + quote! { + names.insert( + format!("#{}", #result.clone()), + #result.to_string(), + ); + } + }); + + quote! { + impl #client_name { + + pub fn new(region: ::raiden::Region) -> Self { + let config = ::raiden::Config::builder().region(region).build(); + let client = ::raiden::#dynamodb_client_name::from_conf(config); + Self::new_with_dynamo_db_client(client) + } + + pub fn new_with_client(client: ::raiden::Client) -> Self { + Self::new_with_dynamo_db_client(client) + } + + fn new_with_dynamo_db_client(client: ::raiden::#dynamodb_client_name) -> Self { + let names = { + let mut names: ::raiden::AttributeNames = std::collections::HashMap::new(); + #(#insertion_attribute_name)* + names + }; + let projection_expression = Some(names.keys().map(|v| v.to_string()).collect::>().join(", ")); + + Self { + table_name: #table_name, + table_prefix: "".to_owned(), + table_suffix: "".to_owned(), + client, + retry_condition: ::raiden::RetryCondition::new(), + attribute_names: Some(names), + projection_expression + } + } + + pub fn with_retries(mut self, s: Box) -> Self { + self.retry_condition.strategy = s; + self + } + + pub fn table_prefix(mut self, prefix: impl Into) -> Self { + self.table_prefix = prefix.into(); + self + } + + pub fn table_suffix(mut self, suffix: impl Into) -> Self { + self.table_suffix = suffix.into(); + self + } + + pub fn table_name(&self) -> String { + format!("{}{}{}", self.table_prefix, self.table_name.to_string(), self.table_suffix) + } + } + + impl #struct_name { + pub fn client(region: ::raiden::Region) -> #client_name { + #client_name::new(region) + } + + pub fn client_with(client: ::raiden::Client) -> #client_name { + #client_name::new_with_client(client) + } + } + } +} diff --git a/raiden-derive/src/aws_sdk/mod.rs b/raiden-derive/src/aws_sdk/mod.rs new file mode 100644 index 00000000..c5a66c24 --- /dev/null +++ b/raiden-derive/src/aws_sdk/mod.rs @@ -0,0 +1,2 @@ +pub mod client; +pub mod ops; diff --git a/raiden-derive/src/aws_sdk/ops/batch_delete.rs b/raiden-derive/src/aws_sdk/ops/batch_delete.rs new file mode 100644 index 00000000..ab35c663 --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/batch_delete.rs @@ -0,0 +1,192 @@ +use quote::*; +use syn::*; + +pub(crate) fn expand_batch_delete( + partition_key: &(Ident, Type), + sort_key: &Option<(Ident, Type)>, + struct_name: &Ident, +) -> proc_macro2::TokenStream { + let trait_name = format_ident!("{}BatchDelete", struct_name); + let client_name = format_ident!("{}Client", struct_name); + let builder_name = format_ident!("{}BatchDeleteBuilder", struct_name); + let (partition_key_ident, partition_key_type) = partition_key; + + let client_trait = if let Some(sort_key) = sort_key { + let (sort_key_ident, sort_key_type) = sort_key; + quote! { + pub trait #trait_name { + fn batch_delete(&self, keys: std::vec::Vec<(impl Into<#partition_key_type>, impl Into<#sort_key_type>)>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn batch_delete(&self, keys: std::vec::Vec<(impl Into<#partition_key_type>, impl Into<#sort_key_type>)>) -> #builder_name { + use ::std::iter::FromIterator; + + let write_requests = { + let mut write_requests = vec![]; + for (pk, sk) in keys.into_iter() { + let pk_attr_value = pk.into().into_attr(); + let sk_attr_value = sk.into().into_attr(); + let write_request = { + let delete_request = ::raiden::DeleteRequest::builder() + .set_key(Some(::std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_string(), pk_attr_value), + (stringify!(#sort_key_ident).to_string(), sk_attr_value), + ]))) + .build(); + + ::raiden::WriteRequest::builder() + .delete_request(delete_request) + .build() + }; + write_requests.push(write_request); + } + + write_requests + }; + + #builder_name { + client: &self.client, + write_requests, + table_name: self.table_name(), + } + } + } + } + } else { + quote! { + pub trait #trait_name { + fn batch_delete(&self, keys: std::vec::Vec>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn batch_delete(&self, keys: std::vec::Vec>) -> #builder_name { + use ::std::iter::FromIterator; + + let write_requests = { + let mut write_requests = vec![]; + for pk in keys.into_iter() { + let pk_attr_value = pk.into().into_attr(); + let write_request = { + let delete_request = ::raiden::DeleteRequest::builder() + .set_key(Some(::std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_string(), pk_attr_value), + ]))) + .build(); + + ::raiden::WriteRequest::builder() + .delete_request(delete_request) + .build() + }; + write_requests.push(write_request); + } + + write_requests + }; + + #builder_name { + client: &self.client, + write_requests, + table_name: self.table_name(), + } + } + } + } + }; + + let api_call_token = super::api_call_token!("batch_write_item"); + let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { + ( + quote! { #builder_name::inner_run(&self.table_name, &self.client, builder).await? }, + quote! { table_name: &str, }, + ) + } else { + ( + quote! { #builder_name::inner_run(&self.client, builder).await? }, + quote! {}, + ) + }; + + quote! { + #client_trait + + pub struct #builder_name<'a> { + pub client: &'a ::raiden::Client, + pub write_requests: ::std::vec::Vec<::raiden::WriteRequest>, + pub table_name: String, + } + + impl<'a> #builder_name<'a> { + pub async fn run(mut self) -> Result<::raiden::batch_delete::BatchDeleteOutput, ::raiden::RaidenError> { + // TODO: set the number of retry to 5 for now, which should be made more flexible + const RETRY: usize = 5; + const MAX_ITEMS_PER_REQUEST: usize = 25; + + for _ in 0..RETRY { + loop { + let len = self.write_requests.len(); + + // len == 0 means there are no items to be processed anymore + if len == 0 { + break; + } + + let start = len.saturating_sub(MAX_ITEMS_PER_REQUEST); + let end = std::cmp::min(len, start + MAX_ITEMS_PER_REQUEST); + // take requests up to 25 from the request buffer + let req = self.write_requests.drain(start..end).collect::>(); + let request_items = vec![(self.table_name.clone(), req)] + .into_iter() + .collect::>(); + let builder = ::raiden::BatchWriteItemInput::builder() + .set_request_items(Some(request_items)); + + let result = #call_inner_run; + + let mut unprocessed_items = match result.unprocessed_items { + None => { + // move on to the next iteration to check if there are unprocessed + // requests + continue; + } + Some(unprocessed_items) => { + if unprocessed_items.is_empty() { + // move on to the next iteration to check if there are unprocessed + // requests + continue; + } + + unprocessed_items + }, + }; + + let unprocessed_requests = unprocessed_items + .remove(&self.table_name) + .expect("reqeust_items hashmap must have a value for the table name"); + // push unprocessed requests back to the request buffer + self.write_requests.extend(unprocessed_requests); + } + } + + // when retry is done the specified times, treat it as success even if there are + // still unprocessed items + let unprocessed_items = self.write_requests + .into_iter() + .filter_map(|write_request| write_request.delete_request) + .collect::>(); + Ok(::raiden::batch_delete::BatchDeleteOutput { + consumed_capacity: None, + unprocessed_items, + }) + } + + async fn inner_run( + #inner_run_args + client: &::raiden::Client, + builder: ::raiden::BatchWriteItemInputBuilder, + ) -> Result<::raiden::BatchWriteItemOutput, ::raiden::RaidenError> { + Ok(#api_call_token?) + } + } + } +} diff --git a/raiden-derive/src/aws_sdk/ops/batch_get.rs b/raiden-derive/src/aws_sdk/ops/batch_get.rs new file mode 100644 index 00000000..54e9cc09 --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/batch_get.rs @@ -0,0 +1,212 @@ +use proc_macro2::*; +use quote::*; +use syn::*; + +use crate::rename::*; + +pub(crate) fn expand_batch_get( + partition_key: &(Ident, Type), + sort_key: &Option<(Ident, Type)>, + struct_name: &Ident, + fields: &FieldsNamed, + rename_all_type: RenameAllType, +) -> proc_macro2::TokenStream { + let trait_name = format_ident!("{}BatchGetItem", struct_name); + let client_name = format_ident!("{}Client", struct_name); + let builder_name = format_ident!("{}BatchGetItemBuilder", struct_name); + let from_item = super::expand_attr_to_item(format_ident!("res_item"), fields, rename_all_type); + let (partition_key_ident, partition_key_type) = partition_key; + + let builder_keys_type = if sort_key.is_none() { + quote! { std::vec::Vec<::raiden::AttributeValue> } + } else { + quote! { std::vec::Vec<(::raiden::AttributeValue, ::raiden::AttributeValue)> } + }; + + let insertion_attribute_name = fields.named.iter().map(|f| { + let ident = &f.ident.clone().unwrap(); + let renamed = crate::finder::find_rename_value(&f.attrs); + let result = create_renamed(ident.to_string(), renamed, rename_all_type); + quote! { + names.insert( + format!("#{}", #result.clone()), + #result.to_string(), + ); + } + }); + + let builder_init = quote! { + let names = { + let mut names: ::raiden::AttributeNames = std::collections::HashMap::new(); + #(#insertion_attribute_name)* + names + }; + let projection_expression = Some(names.keys().map(|v| v.to_string()).collect::>().join(", ")); + + #builder_name { + client: &self.client, + table_name: self.table_name(), + keys: key_attrs, + attribute_names: Some(names), + projection_expression + } + }; + + let client_trait = if sort_key.is_none() { + quote! { + pub trait #trait_name { + fn batch_get(&self, keys: std::vec::Vec>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn batch_get(&self, keys: std::vec::Vec>) -> #builder_name { + let key_attrs = keys.into_iter().map(|v| v.into().into_attr()).collect(); + + #builder_init + } + } + } + } else { + let (_, sort_key_type) = sort_key.clone().unwrap(); + quote! { + pub trait #trait_name { + fn batch_get(&self, keys: std::vec::Vec<(impl Into<#partition_key_type>, impl Into<#sort_key_type>)>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn batch_get(&self, keys: std::vec::Vec<(impl Into<#partition_key_type>, impl Into<#sort_key_type>)>) -> #builder_name { + let key_attrs = keys.into_iter().map(|(pk, sk)| (pk.into().into_attr(), sk.into().into_attr())).collect(); + + #builder_init + } + } + } + }; + + let convert_to_external_proc = if let Some(sort_key) = sort_key { + let (sort_key_ident, _sort_key_type) = sort_key; + quote! { + for (pk_attr, sk_attr) in keys.into_iter() { + let key_val: std::collections::HashMap = ::std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), pk_attr), + (stringify!(#sort_key_ident).to_owned(), sk_attr), + ]); + + item_builder = item_builder.keys(key_val); + } + } + } else { + quote! { + for key_attr in keys.into_iter() { + let key_val: std::collections::HashMap = ::std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), key_attr), + ]); + + item_builder = item_builder.keys(key_val); + } + } + }; + + let api_call_token = super::api_call_token!("batch_get_item"); + let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { + ( + quote! { #builder_name::inner_run(&self.table_name, &self.client, builder).await? }, + quote! { table_name: &str, }, + ) + } else { + ( + quote! { #builder_name::inner_run(&self.client, builder).await? }, + quote! {}, + ) + }; + + quote! { + #client_trait + + pub struct #builder_name<'a> { + pub client: &'a ::raiden::Client, + pub table_name: String, + pub keys: #builder_keys_type, + pub attribute_names: Option<::raiden::AttributeNames>, + pub projection_expression: Option + } + + impl<'a> #builder_name<'a> { + + #![allow(clippy::field_reassign_with_default)] + pub async fn run(mut self) -> Result<::raiden::batch_get::BatchGetOutput<#struct_name>, ::raiden::RaidenError> { + use ::std::iter::FromIterator; + + let mut items: std::vec::Vec<#struct_name> = vec![]; + let mut unprocessed_keys = ::raiden::KeysAndAttributes::builder().build(); + + // TODO: for now set 5, however we should make it more flexible. + let mut unprocessed_retry = 5; + loop { + let unprocessed_key_len = unprocessed_keys.keys().map_or(0, |v| v.len()); + let mut item_builder = ::raiden::KeysAndAttributes::builder() + .set_expression_attribute_names(self.attribute_names.clone()) + .set_projection_expression(self.projection_expression.clone()) + .set_keys(unprocessed_keys.keys); + + if unprocessed_key_len < 100 { + let keys = self.keys.drain(0..std::cmp::min(100 - unprocessed_key_len, self.keys.len())); + #convert_to_external_proc + } + + let builder = ::raiden::BatchGetItemInput::builder() + .request_items(self.table_name.to_string(), item_builder.build()); + + let res = #call_inner_run; + + if self.keys.is_empty() { + unprocessed_retry -= 1; + } + + if let Some(res_responses) = res.responses { + let mut res_responses = res_responses; + if let Some(res_items) = (&mut res_responses).remove(&self.table_name) { + for res_item in res_items.into_iter() { + let mut res_item = res_item; + items.push(#struct_name { + #(#from_item)* + }) + } + } else { + return Err(::raiden::RaidenError::ResourceNotFound(format!("'{}' table not found or not active", &self.table_name))); + } + } else { + return Err(::raiden::RaidenError::ResourceNotFound("resource not found".to_owned())); + } + + unprocessed_keys.keys = None; + + if let Some(keys_by_table) = res.unprocessed_keys { + if let Some(keys_attrs) = keys_by_table.get(&self.table_name) { + unprocessed_keys.keys = keys_attrs.keys.clone(); + } + } + + if ( + self.keys.is_empty() && unprocessed_keys.keys.clone().map_or(true, |v| v.is_empty()) + ) || unprocessed_retry == 0 + { + return Ok(::raiden::batch_get::BatchGetOutput { + consumed_capacity: res.consumed_capacity, + items, + unprocessed_keys: Some(unprocessed_keys), + }) + } + } + } + + async fn inner_run( + #inner_run_args + client: &::raiden::Client, + builder: ::raiden::BatchGetItemInputBuilder, + ) -> Result<::raiden::BatchGetItemOutput, ::raiden::RaidenError> { + Ok(#api_call_token?) + } + } + } +} diff --git a/raiden-derive/src/aws_sdk/ops/delete.rs b/raiden-derive/src/aws_sdk/ops/delete.rs new file mode 100644 index 00000000..c815eb1a --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/delete.rs @@ -0,0 +1,142 @@ +use proc_macro2::*; +use quote::*; +use syn::*; + +pub(crate) fn expand_delete_item( + partition_key: &(Ident, Type), + sort_key: &Option<(Ident, Type)>, + struct_name: &Ident, +) -> TokenStream { + let trait_name = format_ident!("{}DeleteItem", struct_name); + let client_name = format_ident!("{}Client", struct_name); + let builder_name = format_ident!("{}DeleteItemBuilder", struct_name); + let condition_token_name = format_ident!("{}ConditionToken", struct_name); + let (partition_key_ident, partition_key_type) = partition_key; + + let client_trait = if let Some(sort_key) = sort_key { + let (sort_key_ident, sort_key_type) = sort_key; + quote! { + pub trait #trait_name { + fn delete(&self, pk: impl Into<#partition_key_type>, sk: impl Into<#sort_key_type>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn delete(&self, pk: impl Into<#partition_key_type>, sk: impl Into<#sort_key_type>) -> #builder_name { + use ::std::iter::FromIterator; + + let pk_attr: ::raiden::AttributeValue = pk.into().into_attr(); + let sk_attr: ::raiden::AttributeValue = sk.into().into_attr(); + let key_set: std::collections::HashMap = + std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), pk_attr), + (stringify!(#sort_key_ident).to_owned(), sk_attr), + ]); + + let mut builder = ::raiden::DeleteItemInput::builder() + .set_key(Some(key_set)) + .table_name(self.table_name()); + + #builder_name { + client: &self.client, + builder, + } + } + } + } + } else { + quote! { + pub trait #trait_name { + fn delete(&self, key: impl Into<#partition_key_type>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn delete(&self, key: impl Into<#partition_key_type>) -> #builder_name { + use ::std::iter::FromIterator; + + let key_attr: ::raiden::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = + std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), key_attr), + ]); + + let mut builder = ::raiden::DeleteItemInput::builder() + .set_key(Some(key_set)) + .table_name(self.table_name()); + + #builder_name { + client: &self.client, + builder, + } + } + } + } + }; + + let api_call_token = super::api_call_token!("delete_item"); + let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { + ( + quote! { + let table_name = self + .builder + .get_table_name() + .clone() + .expect("table name should be set"); + + #builder_name::inner_run(&table_name, &self.client, self.builder).await? + }, + quote! { table_name: &str, }, + ) + } else { + ( + quote! { #builder_name::inner_run(&self.client, self.builder).await? }, + quote! {}, + ) + }; + + quote! { + #client_trait + + pub struct #builder_name<'a> { + pub client: &'a ::raiden::Client, + pub builder: ::raiden::DeleteItemInputBuilder, + } + + impl<'a> #builder_name<'a> { + pub fn raw_input(mut self, builder: ::raiden::DeleteItemInputBuilder) -> Self { + self.builder = builder; + self + } + + pub fn condition(mut self, cond: impl ::raiden::condition::ConditionBuilder<#condition_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_names.is_empty() { + self.builder = self.builder + .set_expression_attribute_names(Some(attr_names)); + } + + if !attr_values.is_empty() { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } + + self.builder = self.builder.condition_expression(cond_str); + self + } + + pub async fn run(self) -> Result<(), ::raiden::RaidenError> { + #call_inner_run; + Ok(()) + } + + async fn inner_run( + #inner_run_args + client: &::raiden::Client, + builder: ::raiden::DeleteItemInputBuilder, + ) -> Result<(), ::raiden::RaidenError> { + #api_call_token?; + Ok(()) + } + } + } +} diff --git a/raiden-derive/src/aws_sdk/ops/get.rs b/raiden-derive/src/aws_sdk/ops/get.rs new file mode 100644 index 00000000..211ec984 --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/get.rs @@ -0,0 +1,156 @@ +use proc_macro2::*; +use quote::*; +use syn::*; + +pub(crate) fn expand_get_item( + partition_key: &(Ident, Type), + sort_key: &Option<(Ident, Type)>, + struct_name: &Ident, + fields: &syn::FieldsNamed, + rename_all_type: crate::rename::RenameAllType, +) -> TokenStream { + let trait_name = format_ident!("{}GetItem", struct_name); + let client_name = format_ident!("{}Client", struct_name); + let builder_name = format_ident!("{}GetItemBuilder", struct_name); + let from_item = super::expand_attr_to_item(format_ident!("res_item"), fields, rename_all_type); + let (partition_key_ident, partition_key_type) = partition_key; + + let client_trait = if let Some(sort_key) = sort_key { + let (sort_key_ident, sort_key_type) = sort_key; + quote! { + pub trait #trait_name { + fn get(&self, pk: impl Into<#partition_key_type>, sk: impl Into<#sort_key_type>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn get(&self, pk: impl Into<#partition_key_type>, sk: impl Into<#sort_key_type>) -> #builder_name { + use ::std::iter::FromIterator; + + let pk_attr: ::raiden::AttributeValue = pk.into().into_attr(); + let sk_attr: ::raiden::AttributeValue = sk.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), pk_attr), + (stringify!(#sort_key_ident).to_owned(), sk_attr), + ]); + + let mut builder = ::raiden::GetItemInput::builder() + .set_expression_attribute_names(self.attribute_names.clone()) + .set_key(Some(key_set)) + .table_name(self.table_name()); + + if let Some(ref v) = self.projection_expression { + builder = builder.projection_expression(v.clone()); + } + + #builder_name { + client: &self.client, + builder, + policy: self.retry_condition.strategy.policy(), + condition: &self.retry_condition, + } + } + } + } + } else { + quote! { + pub trait #trait_name { + fn get(&self, key: impl Into<#partition_key_type>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn get(&self, key: impl Into<#partition_key_type>) -> #builder_name { + use ::std::iter::FromIterator; + + let key_attr: ::raiden::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), key_attr), + ]); + + let mut builder = ::raiden::GetItemInput::builder() + .set_expression_attribute_names(self.attribute_names.clone()) + .set_key(Some(key_set)) + .table_name(self.table_name()); + + if let Some(ref v) = self.projection_expression { + builder = builder.projection_expression(v.clone()); + } + + #builder_name { + client: &self.client, + builder, + policy: self.retry_condition.strategy.policy(), + condition: &self.retry_condition, + } + } + } + } + }; + + let api_call_token = super::api_call_token!("get_item"); + let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { + ( + quote! { + let table_name = builder + .get_table_name() + .clone() + .expect("table name should be set"); + + #builder_name::inner_run(table_name, client, builder).await + }, + quote! { table_name: String, }, + ) + } else { + ( + quote! { #builder_name::inner_run(client, builder).await }, + quote! {}, + ) + }; + + quote! { + #client_trait + + pub struct #builder_name<'a> { + pub client: &'a ::raiden::Client, + pub builder: ::raiden::GetItemInputBuilder, + pub policy: ::raiden::Policy, + pub condition: &'a ::raiden::retry::RetryCondition, + } + + impl<'a> #builder_name<'a> { + pub fn consistent(mut self) -> Self { + self.builder = self.builder.consistent_read(true); + self + } + + pub async fn run(self) -> Result<::raiden::get::GetOutput<#struct_name>, ::raiden::RaidenError> { + let policy: ::raiden::RetryPolicy = self.policy.into(); + let client = self.client; + let builder = self.builder; + policy.retry_if(move || { + let client = client.clone(); + let builder = builder.clone(); + async { #call_inner_run } + }, self.condition).await + } + + async fn inner_run( + #inner_run_args + client: ::raiden::Client, + builder: ::raiden::GetItemInputBuilder, + ) -> Result<::raiden::get::GetOutput<#struct_name>, ::raiden::RaidenError> { + let res = #api_call_token?; + if res.item.is_none() { + return Err(::raiden::RaidenError::ResourceNotFound("resource not found".to_owned())); + }; + let mut res_item = res.item.unwrap(); + let item = #struct_name { + #(#from_item)* + }; + Ok(::raiden::get::GetOutput { + item, + consumed_capacity: res.consumed_capacity, + }) + } + } + } +} diff --git a/raiden-derive/src/ops/mod.rs b/raiden-derive/src/aws_sdk/ops/mod.rs similarity index 100% rename from raiden-derive/src/ops/mod.rs rename to raiden-derive/src/aws_sdk/ops/mod.rs diff --git a/raiden-derive/src/aws_sdk/ops/put.rs b/raiden-derive/src/aws_sdk/ops/put.rs new file mode 100644 index 00000000..f86f9829 --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/put.rs @@ -0,0 +1,229 @@ +use crate::rename::*; +use proc_macro2::*; +use quote::*; + +pub(crate) fn expand_put_item( + struct_name: &Ident, + fields: &syn::FieldsNamed, + rename_all_type: crate::rename::RenameAllType, +) -> TokenStream { + let item_input_name = format_ident!("{}PutItemInput", struct_name); + let item_input_builder_name = format_ident!("{}PutItemInputBuilder", struct_name); + let item_output_name = format_ident!("{}PutItemOutput", struct_name); + let trait_name = format_ident!("{}PutItem", struct_name); + let client_name = format_ident!("{}Client", struct_name); + let builder_name = format_ident!("{}PutItemBuilder", struct_name); + let condition_token_name = format_ident!("{}ConditionToken", struct_name); + + let input_fields = fields + .named + .iter() + .filter(|f| !crate::finder::include_unary_attr(&f.attrs, "uuid")) + .map(|f| { + let ident = &f.ident.clone().unwrap(); + let ty = &f.ty; + quote! { + pub #ident: #ty, + } + }); + + let output_fields = fields.named.iter().map(|f| { + let ident = &f.ident.clone().unwrap(); + let ty = &f.ty; + quote! { + pub #ident: #ty, + } + }); + + let output_values = fields.named.iter().map(|f| { + let ident = &f.ident.clone().unwrap(); + let renamed = crate::finder::find_rename_value(&f.attrs); + let attr_key = create_renamed(ident.to_string(), renamed, rename_all_type); + if crate::finder::include_unary_attr(&f.attrs, "uuid") { + quote! { + #ident: uuid_map.get(#attr_key).cloned().unwrap().into(), + } + } else { + quote! { + #ident: item.#ident, + } + } + }); + + let input_items = { + let insertion = fields.named.iter().map(|f| { + let ident = &f.ident.clone().unwrap(); + let renamed = crate::finder::find_rename_value(&f.attrs); + let attr_key = create_renamed(ident.to_string(), renamed, rename_all_type); + if crate::finder::include_unary_attr(&f.attrs, "uuid") { + quote! { + let id = #struct_name::gen(); + input_item.insert( + #attr_key.to_string(), + id.clone().into_attr(), + ); + uuid_map.insert( + #attr_key.to_string(), + id, + ); + } + } else { + quote! { + let value = item.#ident.clone().into_attr(); + if !::raiden::is_attr_value_empty(&value) { + input_item.insert( + #attr_key.to_string(), + value, + ); + } + } + } + }); + + quote! { + let mut input_item: std::collections::HashMap = std::collections::HashMap::new(); + #(#insertion)* + } + }; + + // Create default type variables for PutItemBuilder, i.e. XXXPutItemBuilder<(), (), ()> + let required_field_idents: Vec = fields + .named + .iter() + .filter(|f| !crate::finder::include_unary_attr(&f.attrs, "uuid")) + .filter(|f| !crate::finder::is_option(&f.ty)) + .map(|f| f.ident.clone().unwrap()) + .collect(); + let default_types = expand_default_type_variables(&required_field_idents); + + let api_call_token = super::api_call_token!("put_item"); + let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { + ( + quote! { + let table_name = builder + .get_table_name() + .clone() + .expect("table name should be set"); + + #builder_name::inner_run(table_name, client, builder).await + }, + quote! { table_name: String, }, + ) + } else { + ( + quote! { #builder_name::inner_run(client, builder).await }, + quote! {}, + ) + }; + + quote! { + #[derive(Debug, Clone, PartialEq, ::raiden::Builder)] + pub struct #item_input_name { + #(#input_fields)* + } + + impl #struct_name { + pub fn put_item_builder() -> #item_input_builder_name<#(#default_types)*> { + #item_input_name::builder() + } + } + + #[derive(Debug, Clone, PartialEq)] + pub struct #item_output_name { + #(#output_fields)* + } + + pub trait #trait_name { + fn put(&self, item: #item_input_name) -> #builder_name; + } + + impl #trait_name for #client_name { + fn put(&self, item: #item_input_name) -> #builder_name{ + let mut uuid_map: std::collections::HashMap = std::collections::HashMap::new(); + + #input_items + + let output_item = #item_output_name { + #(#output_values)* + }; + + let builder = ::raiden::PutItemInput::builder() + .set_item(Some(input_item)) + .table_name(self.table_name()); + + #builder_name { + client: &self.client, + builder, + item: output_item, + policy: self.retry_condition.strategy.policy(), + condition: &self.retry_condition, + } + } + } + + pub struct #builder_name<'a> { + pub client: &'a ::raiden::Client, + pub builder: ::raiden::PutItemInputBuilder, + pub item: #item_output_name, + pub policy: ::raiden::Policy, + pub condition: &'a ::raiden::retry::RetryCondition, + } + + impl<'a> #builder_name<'a> { + + pub fn raw_input(mut self, builder: ::raiden::PutItemInputBuilder) -> Self { + self.builder = builder; + self + } + + pub fn condition(mut self, cond: impl ::raiden::condition::ConditionBuilder<#condition_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_names.is_empty() { + self.builder = self.builder + .set_expression_attribute_names(Some(attr_names)); + } + + if !attr_values.is_empty() { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } + + self.builder = self.builder.condition_expression(cond_str); + self + } + + pub async fn run(self) -> Result<::raiden::put::PutOutput<#item_output_name>, ::raiden::RaidenError> { + let builder = self.builder.clone(); + let client = self.client.clone(); + let policy: ::raiden::RetryPolicy = self.policy.into(); + + let res = policy.retry_if(move || { + let builder = builder.clone(); + let client = client.clone(); + async { #call_inner_run } + }, self.condition).await?; + + Ok(::raiden::put::PutOutput { + item: self.item, + consumed_capacity: res.consumed_capacity, + }) + } + + async fn inner_run( + #inner_run_args + client: ::raiden::Client, + builder: ::raiden::PutItemInputBuilder, + ) -> Result<::raiden::PutItemOutput, ::raiden::RaidenError> { + Ok(#api_call_token?) + } + } + } +} + +#[allow(clippy::ptr_arg)] +fn expand_default_type_variables(idents: &Vec) -> impl Iterator { + idents.clone().into_iter().map(|_ident| { + quote! { (), } + }) +} diff --git a/raiden-derive/src/aws_sdk/ops/query.rs b/raiden-derive/src/aws_sdk/ops/query.rs new file mode 100644 index 00000000..2b9c6227 --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/query.rs @@ -0,0 +1,223 @@ +use quote::*; + +pub(crate) fn expand_query( + struct_name: &proc_macro2::Ident, + fields: &syn::FieldsNamed, + rename_all_type: crate::rename::RenameAllType, +) -> proc_macro2::TokenStream { + let trait_name = format_ident!("{}Query", struct_name); + let client_name = format_ident!("{}Client", struct_name); + let builder_name = format_ident!("{}QueryBuilder", struct_name); + let query_output_item = format_ident!("{}QueryOutput", struct_name); + + let filter_expression_token_name = format_ident!("{}FilterExpressionToken", struct_name); + let key_condition_token_name = format_ident!("{}KeyConditionToken", struct_name); + + let from_item = super::expand_attr_to_item(format_ident!("res_item"), fields, rename_all_type); + let api_call_token = super::api_call_token!("query"); + let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { + ( + quote! { + let table_name = builder + .get_table_name() + .clone() + .expect("table name should be set"); + + #builder_name::inner_run(table_name, client, builder).await + }, + quote! { table_name: String, }, + ) + } else { + ( + quote! { #builder_name::inner_run(client, builder).await }, + quote! {}, + ) + }; + + quote! { + pub trait #trait_name { + fn query(&self) -> #builder_name; + } + + pub struct #builder_name<'a> { + pub client: &'a ::raiden::Client, + pub builder: ::raiden::QueryInputBuilder, + pub next_token: Option<::raiden::NextToken>, + pub limit: Option, + pub policy: ::raiden::Policy, + pub condition: &'a ::raiden::retry::RetryCondition, + } + + struct #query_output_item { + consumed_capacity: Option<::raiden::ConsumedCapacity>, + count: Option, + items: Option>>, + last_evaluated_key: Option<::std::collections::HashMap>, + scanned_count: Option, + } + + impl #trait_name for #client_name { + + #![allow(clippy::field_reassign_with_default)] + fn query(&self) -> #builder_name { + let builder = ::raiden::QueryInput::builder() + .table_name(self.table_name()) + .set_projection_expression(self.projection_expression.clone()) + .set_expression_attribute_names(self.attribute_names.clone()); + + #builder_name { + client: &self.client, + builder, + next_token: None, + limit: None, + policy: self.retry_condition.strategy.policy(), + condition: &self.retry_condition, + } + } + } + + impl<'a> #builder_name<'a> { + pub fn index(mut self, index: impl Into) -> Self { + self.builder = self.builder.index_name(index.into()); + self + } + + pub fn consistent(mut self) -> Self { + self.builder = self.builder.consistent_read(true); + self + } + + pub fn next_token(mut self, token: ::raiden::NextToken) -> Self { + self.next_token = Some(token); + self + } + + pub fn desc(mut self) -> Self { + self.builder = self.builder.scan_index_forward(false); + self + } + + pub fn asc(mut self) -> Self { + self.builder = self.builder.scan_index_forward(true); + self + } + + pub fn limit(mut self, limit: usize) -> Self { + self.limit = Some(limit as i64); + self + } + + pub fn filter(mut self, cond: impl ::raiden::filter_expression::FilterExpressionBuilder<#filter_expression_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_values.is_empty() { + if let Some(v) = self.builder.get_expression_attribute_values().clone() { + self.builder = self.builder + .set_expression_attribute_values(Some(::raiden::merge_map(attr_values, v))); + } else { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } + } + + self.builder = self.builder.filter_expression(cond_str); + self + } + + pub fn key_condition(mut self, cond: impl ::raiden::key_condition::KeyConditionBuilder<#key_condition_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_values.is_empty() { + if let Some(v) = self.builder.get_expression_attribute_values().clone() { + self.builder = self + .builder + .set_expression_attribute_values(Some(::raiden::merge_map(attr_values, v))); + } else { + self.builder = self + .builder + .set_expression_attribute_values(Some(attr_values)); + } + } + + self.builder = self.builder.key_condition_expression(cond_str); + self + } + + pub async fn run(mut self) -> Result<::raiden::query::QueryOutput<#struct_name>, ::raiden::RaidenError> { + if let Some(token) = self.next_token { + self.builder = self.builder + .set_exclusive_start_key(Some(token.into_attr_values()?)); + } + + let mut items: Vec<#struct_name> = vec![]; + let policy: ::raiden::RetryPolicy = self.policy.into(); + let client = self.client; + + loop { + if let Some(limit) = self.limit { + self.builder = self.builder.limit(limit as i32); + } + + let builder = self.builder.clone(); + let client = self.client.clone(); + + let res: #query_output_item = policy.retry_if(move || { + let builder = builder.clone(); + let client = client.clone(); + async { #call_inner_run } + }, self.condition).await?; + + if let Some(res_items) = res.items { + for res_item in res_items.into_iter() { + let mut res_item = res_item; + items.push(#struct_name { + #(#from_item)* + }) + } + }; + + let scanned = res.scanned_count.unwrap_or(0); + + let mut has_next = true; + if let Some(limit) = self.limit { + has_next = limit - scanned > 0; + self.limit = Some(limit - scanned); + } + + if res.last_evaluated_key.is_none() || !has_next { + let next_token = if res.last_evaluated_key.is_some() { + Some(::raiden::NextToken::from_attr(&res.last_evaluated_key.unwrap())) + } else { + None + }; + return Ok(::raiden::query::QueryOutput { + consumed_capacity: res.consumed_capacity, + count: res.count, + items, + next_token, + scanned_count: res.scanned_count, + }) + } + + self.builder = self.builder + .set_exclusive_start_key(res.last_evaluated_key); + } + } + + async fn inner_run( + #inner_run_args + client: ::raiden::Client, + builder: ::raiden::QueryInputBuilder, + ) -> Result<#query_output_item, ::raiden::RaidenError> { + let res = #api_call_token?; + Ok(#query_output_item { + consumed_capacity: res.consumed_capacity, + count: Some(res.count as i64), + items: res.items, + last_evaluated_key: res.last_evaluated_key, + scanned_count: Some(res.scanned_count as i64), + }) + } + } + } +} diff --git a/raiden-derive/src/aws_sdk/ops/scan.rs b/raiden-derive/src/aws_sdk/ops/scan.rs new file mode 100644 index 00000000..eccab50f --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/scan.rs @@ -0,0 +1,152 @@ +use quote::*; + +pub(crate) fn expand_scan( + struct_name: &proc_macro2::Ident, + fields: &syn::FieldsNamed, + rename_all_type: crate::rename::RenameAllType, +) -> proc_macro2::TokenStream { + let trait_name = format_ident!("{}Scan", struct_name); + let client_name = format_ident!("{}Client", struct_name); + let builder_name = format_ident!("{}ScanBuilder", struct_name); + + let filter_expression_token_name = format_ident!("{}FilterExpressionToken", struct_name); + let from_item = super::expand_attr_to_item(format_ident!("res_item"), fields, rename_all_type); + let api_call_token = super::api_call_token!("scan"); + let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { + ( + quote! { + let table_name = self.builder.get_table_name().clone().expect("table name should be set"); + #builder_name::inner_run(&table_name, &self.client, self.builder.clone()).await? + }, + quote! { table_name: &str, }, + ) + } else { + ( + quote! { #builder_name::inner_run(&self.client, self.builder.clone()).await? }, + quote! {}, + ) + }; + + quote! { + pub trait #trait_name { + fn scan(&self) -> #builder_name; + } + + pub struct #builder_name<'a> { + pub client: &'a ::raiden::Client, + pub builder: ::raiden::ScanInputBuilder, + pub next_token: Option<::raiden::NextToken>, + pub limit: Option + } + + impl #trait_name for #client_name { + #![allow(clippy::field_reassign_with_default)] + fn scan(&self) -> #builder_name { + let builder = ::raiden::ScanInput::builder() + .table_name(self.table_name()) + .set_projection_expression(self.projection_expression.clone()) + .set_expression_attribute_names(self.attribute_names.clone()); + + #builder_name { + client: &self.client, + builder, + next_token: None, + limit: None, + } + } + } + + impl<'a> #builder_name<'a> { + pub fn index(mut self, index: impl Into) -> Self { + self.builder = self.builder.index_name(index.into()); + self + } + + pub fn consistent(mut self) -> Self { + self.builder = self.builder.consistent_read(true); + self + } + + pub fn filter(mut self, cond: impl ::raiden::filter_expression::FilterExpressionBuilder<#filter_expression_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_values.is_empty() { + if let Some(v) = self.builder.get_expression_attribute_values().clone() { + self.builder = self.builder + .set_expression_attribute_values(Some(::raiden::merge_map(attr_values, v))); + } else { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } + } + + self.builder = self.builder.filter_expression(cond_str); + self + } + + pub fn next_token(mut self, token: ::raiden::NextToken) -> Self { + self.next_token = Some(token); + self + } + + pub fn limit(mut self, limit: usize) -> Self { + self.limit = Some(limit as i64); + self + } + + pub async fn run(mut self) -> Result<::raiden::scan::ScanOutput<#struct_name>, ::raiden::RaidenError> { + if let Some(token) = self.next_token { + self.builder = self.builder + .set_exclusive_start_key(Some(token.into_attr_values()?)); + } + + let mut items: Vec<#struct_name> = vec![]; + + loop { + if let Some(limit) = self.limit { + self.builder = self.builder.limit(limit as i32); + } + + let res = { #call_inner_run }; + + if let Some(res_items) = res.items { + for res_item in res_items.into_iter() { + let mut res_item = res_item; + items.push(#struct_name { + #(#from_item)* + }) + } + }; + + let scanned = res.scanned_count as i64; + + let mut has_next = true; + if let Some(limit) = self.limit { + has_next = limit - scanned > 0; + self.limit = Some(limit - scanned); + } + if res.last_evaluated_key.is_none() || !has_next { + return Ok(::raiden::scan::ScanOutput { + consumed_capacity: res.consumed_capacity, + count: Some(res.count as i64), + items, + last_evaluated_key: res.last_evaluated_key, + scanned_count: Some(res.scanned_count as i64), + }) + } + + self.builder = self.builder + .set_exclusive_start_key(res.last_evaluated_key); + } + } + + async fn inner_run( + #inner_run_args + client: &::raiden::Client, + builder: ::raiden::ScanInputBuilder, + ) -> Result<::raiden::ScanOutput, ::raiden::RaidenError> { + Ok(#api_call_token?) + } + } + } +} diff --git a/raiden-derive/src/aws_sdk/ops/shared.rs b/raiden-derive/src/aws_sdk/ops/shared.rs new file mode 100644 index 00000000..11df1e21 --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/shared.rs @@ -0,0 +1,110 @@ +use quote::*; + +pub(crate) fn expand_attr_to_item( + item_ident: proc_macro2::Ident, + fields: &syn::FieldsNamed, + rename_all_type: crate::rename::RenameAllType, +) -> Vec { + fields.named.iter().map(|f| { + let ident = &f.ident.clone().unwrap(); + let use_default = crate::finder::include_unary_attr(&f.attrs, "use_default"); + let renamed = crate::finder::find_rename_value(&f.attrs); + let attr_key = if let Some(renamed) = renamed { + renamed + } else if rename_all_type != crate::rename::RenameAllType::None { + crate::rename::rename(rename_all_type, ident.to_string()) + } else { + ident.to_string() + }; + let ty = &f.ty; + + let item = quote! { + let item = <#ty as ResolveAttribute>::resolve_attr(&#attr_key, &mut #item_ident); + }; + if crate::finder::is_option(ty) { + quote! { + #ident: { + #item + if item.is_none() { + None + } else { + let converted = ::raiden::FromAttribute::from_attr(item); + if converted.is_err() { + return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + } + converted.unwrap() + } + }, + } + } else if use_default { + quote! { + #ident: { + #item + if item.is_none() { + #ty::default() + } else { + let item = item.unwrap(); + // If null is true, use default value. + if let Some(true) = item.null { + #ty::default() + } else { + let converted = ::raiden::FromAttribute::from_attr(Some(item)); + if converted.is_err() { + // TODO: improve error handling. + return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + } + converted.unwrap() + } + } + }, + } + } else { + quote! { + #ident: { + #item + let converted = ::raiden::FromAttribute::from_attr(item); + if converted.is_err() { + // TODO: improve error handling. + return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + } + converted.unwrap() + }, + } + } + }).collect() +} + +macro_rules! api_call_token { + ($operation: literal) => { + $crate::ops::api_call_token!("table_name", "client", $operation, "builder") + }; + ($table_name: literal, $client: literal, $operation: literal, $builder: literal) => {{ + let table_name = ::quote::format_ident!($table_name); + let client = ::quote::format_ident!($client); + let operation = ::quote::format_ident!($operation); + let builder = ::quote::format_ident!($builder); + + let span_token = if cfg!(feature = "tracing") { + ::quote::quote! { + use tracing::Instrument; + let fut = fut.instrument(::tracing::debug_span!( + "dynamodb::action", + table = #table_name, + api = std::stringify!(#operation), + )); + } + } else { + ::quote::quote! {} + }; + + ::quote::quote! {{ + let fut = #builder.send_with(&#client); + + #span_token + + fut.await + }} + }}; +} + +pub(super) use api_call_token; diff --git a/raiden-derive/src/aws_sdk/ops/transact_write.rs b/raiden-derive/src/aws_sdk/ops/transact_write.rs new file mode 100644 index 00000000..239b4944 --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/transact_write.rs @@ -0,0 +1,434 @@ +use proc_macro2::*; +use quote::*; +use syn::*; + +use crate::rename::*; + +pub(crate) fn expand_transact_write( + struct_name: &Ident, + partition_key: &(Ident, Type), + _sort_key: &Option<(Ident, Type)>, // TODO: Support sort key + fields: &FieldsNamed, + attr_enum_name: &Ident, + rename_all_type: RenameAllType, + table_name: &str, +) -> TokenStream { + let item_input_name = format_ident!("{}PutItemInput", struct_name); + let put_builder = format_ident!("{}TransactPutItemBuilder", struct_name); + let update_builder = format_ident!("{}TransactUpdateItemBuilder", struct_name); + let delete_builder = format_ident!("{}TransactDeleteItemBuilder", struct_name); + let condition_check_builder = format_ident!("{}TransactConditionCheckBuilder", struct_name); + let condition_token_name = format_ident!("{}ConditionToken", struct_name); + let (partition_key_ident, partition_key_type) = partition_key; + + let input_items = { + let insertion = fields.named.iter().map(|f| { + let ident = &f.ident.clone().unwrap(); + let renamed = crate::finder::find_rename_value(&f.attrs); + let attr_key = create_renamed(ident.to_string(), renamed, rename_all_type); + if crate::finder::include_unary_attr(&f.attrs, "uuid") { + quote! { + let id = #struct_name::gen(); + input_item.insert( + #attr_key.to_string(), + id.clone().into_attr(), + ); + uuid_map.insert( + #attr_key.to_string(), + id, + ); + } + } else { + quote! { + let value = item.#ident.into_attr(); + if !::raiden::is_attr_value_empty(&value) { + input_item.insert( + #attr_key.to_string(), + value, + ); + } + } + } + }); + + quote! { + let mut input_item: std::collections::HashMap = std::collections::HashMap::new(); + #(#insertion)* + } + }; + + quote! { + impl #struct_name { + pub fn put(item: #item_input_name) -> #put_builder { + let mut attribute_names: std::collections::HashMap = std::collections::HashMap::new(); + let mut attribute_values: std::collections::HashMap = std::collections::HashMap::new(); + let mut uuid_map: std::collections::HashMap = std::collections::HashMap::new(); + + #input_items + + let builder = ::raiden::Put::builder().set_item(Some(input_item)); + + #put_builder { + builder, + table_name: #table_name.to_owned(), + table_prefix: "".to_owned(), + table_suffix: "".to_owned(), + } + } + + // TODO: Support sort key + pub fn condition_check(key: impl Into<#partition_key_type>) -> #condition_check_builder { + use std::iter::FromIterator; + + let key_attr: ::raiden::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), key_attr), + ]); + let builder = ::raiden::ConditionCheck::builder() + .set_key(Some(key_set)); + + #condition_check_builder { + builder, + table_name: #table_name.to_owned(), + table_prefix: "".to_owned(), + table_suffix: "".to_owned(), + } + } + + // TODO: Support sort key + pub fn delete(key: impl Into<#partition_key_type>) -> #delete_builder { + use std::iter::FromIterator; + + let key_attr: ::raiden::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), key_attr), + ]); + let builder = ::raiden::Delete::builder().set_key(Some(key_set)); + + #delete_builder { + builder, + table_name: #table_name.to_owned(), + table_prefix: "".to_owned(), + table_suffix: "".to_owned(), + } + } + + // TODO: Support sort key + pub fn update(key: impl Into<#partition_key_type>) -> #update_builder { + use std::iter::FromIterator; + + let key_attr: ::raiden::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), key_attr), + ]); + let builder = ::raiden::Update::builder().set_key(Some(key_set)); + + #update_builder { + builder, + table_name: #table_name.to_owned(), + table_prefix: "".to_owned(), + table_suffix: "".to_owned(), + // item: output_item, + add_items: vec![], + set_items: vec![], + remove_items: vec![], + delete_items: vec![], + } + } + } + + pub struct #put_builder { + pub table_name: String, + pub table_prefix: String, + pub table_suffix: String, + pub builder: ::raiden::PutBuilder, + } + + impl ::raiden::TransactWritePutBuilder for #put_builder { + fn build(self) -> ::raiden::Put { + self.builder + .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)) + .build() + } + } + + impl #put_builder { + + pub fn table_prefix(mut self, s: impl Into) -> Self { + self.table_prefix = s.into(); + self + } + + pub fn table_suffix(mut self, s: impl Into) -> Self { + self.table_suffix = s.into(); + self + } + + pub fn condition(mut self, cond: impl ::raiden::condition::ConditionBuilder<#condition_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_names.is_empty() { + self.builder = self.builder + .set_expression_attribute_names(Some(attr_names)); + } + + if !attr_values.is_empty() { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } + + self.builder = self.builder.condition_expression(cond_str); + self + } + } + + pub struct #update_builder { + pub table_name: String, + pub table_prefix: String, + pub table_suffix: String, + pub builder: ::raiden::UpdateBuilder, + + pub add_items: Vec<(String, ::raiden::AttributeNames, ::raiden::AttributeValues)>, + pub set_items: Vec<::raiden::update_expression::SetOrRemove>, + pub remove_items: Vec<#attr_enum_name>, + pub delete_items: Vec<(#attr_enum_name, ::raiden::AttributeValue)>, + } + + impl ::raiden::TransactWriteUpdateBuilder for #update_builder { + fn build(mut self) -> ::raiden::Update { + // TODO: Refactor later + let mut attr_names: ::raiden::AttributeNames = std::collections::HashMap::new(); + let mut attr_values: ::raiden::AttributeValues = std::collections::HashMap::new(); + + let add_items = std::mem::replace(&mut self.add_items, vec![]); + let set_items = std::mem::replace(&mut self.set_items, vec![]); + let remove_items = std::mem::replace(&mut self.remove_items, vec![]); + let delete_items = std::mem::replace(&mut self.delete_items, vec![]); + + let mut remove_expressions = remove_items.into_iter().map(|name| { + let placeholder = format!(":value{}", ::raiden::generate_value_id()); + let attr_name = format!("#{}", name.into_attr_name()); + let val = format!("{}", attr_name); + attr_names.insert(attr_name, name.into_attr_name()); + val + }).collect::>(); + + let mut set_expressions = vec![]; + for set_item in set_items { + match set_item { + raiden::update_expression::SetOrRemove::Set(expression, names, values) => { + attr_names = ::raiden::merge_map(attr_names, names); + attr_values = ::raiden::merge_map(attr_values, values); + set_expressions.push(expression); + } + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + // If empty set detected, replace it to remove expression. + raiden::update_expression::SetOrRemove::Remove(expression, names) => { + attr_names = ::raiden::merge_map(attr_names, names); + remove_expressions.push(expression); + } + } + } + + let set_expression = set_expressions.join(", "); + let remove_expression = remove_expressions.join(", "); + + let mut add_expressions = vec![]; + for add_item in add_items { + let (expression, names, values) = add_item; + attr_names = ::raiden::merge_map(attr_names, names); + attr_values = ::raiden::merge_map(attr_values, values); + add_expressions.push(expression); + } + let add_expression = add_expressions.join(", "); + + let delete_expression = delete_items.into_iter().map(|(name, value)| { + let placeholder = format!(":value{}", ::raiden::generate_value_id()); + let attr_name = format!("#{}", name.into_attr_name()); + let val = format!("{} {}", attr_name, placeholder); + attr_names.insert(attr_name, name.into_attr_name()); + attr_values.insert(placeholder, value); + val + }).collect::>().join(", "); + + let mut update_expressions: Vec = vec![]; + if !add_expression.is_empty() { + update_expressions.push(format!("ADD {}", add_expression)); + } + if !set_expression.is_empty() { + update_expressions.push(format!("SET {}", set_expression)); + } + if !remove_expression.is_empty() { + update_expressions.push(format!("REMOVE {}", remove_expression)); + } + if !delete_expression.is_empty() { + update_expressions.push(format!("DELETE {}", delete_expression)); + } + let update_expression = update_expressions.join(" "); + + if self.builder.get_expression_attribute_names().is_none() { + self.builder = self.builder + .set_expression_attribute_names(Some(attr_names)); + } else { + let v = self.builder.get_expression_attribute_names().clone().unwrap(); + self.builder = self.builder + .set_expression_attribute_names(Some(::raiden::merge_map(v, attr_names))); + } + + if self.builder.get_expression_attribute_values().is_none() { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } else { + let v = self.builder.get_expression_attribute_values().clone().unwrap(); + self.builder = self.builder + .set_expression_attribute_values(Some(::raiden::merge_map(v, attr_values))); + } + + self.builder = self.builder.update_expression(update_expression); + self.builder = self.builder + .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)); + + self.builder.build() + } + } + + impl #update_builder { + + pub fn table_prefix(mut self, s: impl Into) -> Self { + self.table_prefix = s.into(); + self + } + + pub fn table_suffix(mut self, s: impl Into) -> Self { + self.table_suffix = s.into(); + self + } + + pub fn add(mut self, add: impl ::raiden::update_expression::UpdateAddExpressionBuilder) -> Self { + self.add_items.push(add.build()); + self + } + + pub fn set(mut self, set: impl ::raiden::update_expression::UpdateSetExpressionBuilder) -> Self { + self.set_items.push(set.build()); + self + } + + pub fn remove(mut self, attr: #attr_enum_name) -> Self { + self.remove_items.push(attr); + self + } + + pub fn delete(mut self, attr: #attr_enum_name, value: impl ::raiden::IntoAttribute) -> Self { + self.delete_items.push((attr, value.into_attr())); + self + } + + pub fn condition(mut self, cond: impl ::raiden::condition::ConditionBuilder<#condition_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_names.is_empty() { + self.builder = self.builder + .set_expression_attribute_names(Some(attr_names)); + } + + if !attr_values.is_empty() { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } + + self.builder = self.builder.condition_expression(cond_str); + self + } + } + + pub struct #delete_builder { + pub table_name: String, + pub table_prefix: String, + pub table_suffix: String, + pub builder: ::raiden::DeleteBuilder, + } + + impl ::raiden::TransactWriteDeleteBuilder for #delete_builder { + fn build(self) -> ::raiden::Delete { + self.builder + .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)) + .build() + } + } + + impl #delete_builder { + pub fn table_prefix(mut self, s: impl Into) -> Self { + self.table_prefix = s.into(); + self + } + + pub fn table_suffix(mut self, s: impl Into) -> Self { + self.table_suffix = s.into(); + self + } + + pub fn condition(mut self, cond: impl ::raiden::condition::ConditionBuilder<#condition_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_names.is_empty() { + self.builder = self.builder + .set_expression_attribute_names(Some(attr_names)); + } + + if !attr_values.is_empty() { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } + + self.builder = self.builder.condition_expression(cond_str); + self + } + } + + pub struct #condition_check_builder { + pub table_name: String, + pub table_prefix: String, + pub table_suffix: String, + pub builder: ::raiden::ConditionCheckBuilder, + } + + impl ::raiden::TransactWriteConditionCheckBuilder for #condition_check_builder { + fn build(self) -> ::raiden::ConditionCheck { + self.builder + .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)) + .build() + } + } + + impl #condition_check_builder { + pub fn table_prefix(mut self, s: impl Into) -> Self { + self.table_prefix = s.into(); + self + } + + pub fn table_suffix(mut self, s: impl Into) -> Self { + self.table_suffix = s.into(); + self + } + + pub fn condition(mut self, cond: impl ::raiden::condition::ConditionBuilder<#condition_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_names.is_empty() { + self.builder = self.builder + .set_expression_attribute_names(Some(attr_names)); + } + + if !attr_values.is_empty() { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } + + self.builder = self.builder.condition_expression(cond_str); + self + } + } + + } +} diff --git a/raiden-derive/src/aws_sdk/ops/update.rs b/raiden-derive/src/aws_sdk/ops/update.rs new file mode 100644 index 00000000..6126c746 --- /dev/null +++ b/raiden-derive/src/aws_sdk/ops/update.rs @@ -0,0 +1,360 @@ +use proc_macro2::*; +use quote::*; +use syn::*; + +pub(crate) fn expand_update_item( + partition_key: &(Ident, Type), + sort_key: &Option<(Ident, Type)>, + fields: &FieldsNamed, + attr_enum_name: &Ident, + struct_name: &Ident, + rename_all_type: crate::rename::RenameAllType, +) -> TokenStream { + let item_output_name = format_ident!("{}UpdateItemOutput", struct_name); + let trait_name = format_ident!("{}UpdateItem", struct_name); + let update_expression_name = format_ident!("{}UpdateExpression", struct_name); + let client_name = format_ident!("{}Client", struct_name); + let builder_name = format_ident!("{}UpdateItemBuilder", struct_name); + let from_item = super::expand_attr_to_item(format_ident!("res_item"), fields, rename_all_type); + let condition_token_name = format_ident!("{}ConditionToken", struct_name); + let (partition_key_ident, partition_key_type) = partition_key; + + let client_trait = if let Some(sort_key) = sort_key { + let (sort_key_ident, sort_key_type) = sort_key; + quote! { + pub trait #trait_name { + fn update(&self, pk: impl Into<#partition_key_type>, sk: impl Into<#sort_key_type>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn update(&self, pk: impl Into<#partition_key_type>, sk: impl Into<#sort_key_type>) -> #builder_name { + use std::iter::FromIterator; + + let pk_attr: ::raiden::AttributeValue = pk.into().into_attr(); + let sk_attr: ::raiden::AttributeValue = sk.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), pk_attr), + (stringify!(#sort_key_ident).to_owned(), sk_attr), + ]); + + let builder = ::raiden::UpdateItemInput::builder() + .set_key(Some(key_set)) + .table_name(self.table_name()); + + #builder_name { + client: &self.client, + builder, + set_items: vec![], + add_items: vec![], + remove_items: vec![], + delete_items: vec![], + policy: self.retry_condition.strategy.policy(), + condition: &self.retry_condition, + } + } + } + } + } else { + quote! { + pub trait #trait_name { + fn update(&self, key: impl Into<#partition_key_type>) -> #builder_name; + } + + impl #trait_name for #client_name { + fn update(&self, key: impl Into<#partition_key_type>) -> #builder_name { + use std::iter::FromIterator; + + let key_attr: ::raiden::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + (stringify!(#partition_key_ident).to_owned(), key_attr), + ]); + + let builder = ::raiden::UpdateItemInput::builder() + .set_key(Some(key_set)) + .table_name(self.table_name()); + + #builder_name { + client: &self.client, + builder, + set_items: vec![], + add_items: vec![], + remove_items: vec![], + delete_items: vec![], + policy: self.retry_condition.strategy.policy(), + condition: &self.retry_condition, + } + } + } + } + }; + + let api_call_token = super::api_call_token!("update_item"); + let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { + ( + quote! { + let table_name = builder.get_table_name().clone().expect("table name should be set"); + #builder_name::inner_run(table_name, client, builder).await + }, + quote! { table_name: String, }, + ) + } else { + ( + quote! { #builder_name::inner_run(client, builder).await }, + quote! {}, + ) + }; + + quote! { + #[derive(Debug, Clone, PartialEq)] + pub struct #item_output_name { + // #(#output_fields)* + } + + struct #update_expression_name; + + impl #struct_name { + fn update_expression() -> #update_expression_name { + #update_expression_name + } + } + + impl #update_expression_name { + fn set(&self, attr: #attr_enum_name) -> ::raiden::update_expression::Set<#attr_enum_name> { + ::raiden::update_expression::Set::new(attr) + } + + fn add(&self, attr: #attr_enum_name) -> ::raiden::update_expression::Add<#attr_enum_name> { + ::raiden::update_expression::Add::new(attr) + } + + fn delete(&self, attr: #attr_enum_name) -> ::raiden::update_expression::Delete<#attr_enum_name> { + ::raiden::update_expression::Delete::new(attr) + } + } + + #client_trait + + pub struct #builder_name<'a> { + pub client: &'a ::raiden::Client, + pub builder: ::raiden::UpdateItemInputBuilder, + pub add_items: Vec<(String, ::raiden::AttributeNames, ::raiden::AttributeValues)>, + pub set_items: Vec<::raiden::update_expression::SetOrRemove>, + pub remove_items: Vec<#attr_enum_name>, + pub delete_items: Vec<(String, ::raiden::AttributeNames, ::raiden::AttributeValues)>, + pub policy: ::raiden::Policy, + pub condition: &'a ::raiden::retry::RetryCondition, + } + + impl<'a> #builder_name<'a> { + pub fn raw_input(mut self, builder: ::raiden::UpdateItemInputBuilder) -> Self { + self.builder = builder; + self + } + + pub fn add(mut self, add: impl ::raiden::update_expression::UpdateAddExpressionBuilder) -> Self { + self.add_items.push(add.build()); + self + } + + pub fn set(mut self, set: impl ::raiden::update_expression::UpdateSetExpressionBuilder) -> Self { + self.set_items.push(set.build()); + self + } + + pub fn remove(mut self, attr: #attr_enum_name) -> Self { + self.remove_items.push(attr); + self + } + + pub fn delete(mut self, set: impl ::raiden::update_expression::UpdateDeleteExpressionBuilder) -> Self { + self.delete_items.push(set.build()); + self + } + + // INFO: raiden supports only none, all_old and all_new to map response to struct. + pub fn return_all_old(mut self) -> Self { + self.builder = self.builder.return_values(::raiden::ReturnValue::AllOld); + self + } + + // INFO: raiden supports only none, all_old and all_new to map response to struct. + pub fn return_all_new(mut self) -> Self { + self.builder = self.builder.return_values(::raiden::ReturnValue::AllNew); + self + } + + pub fn condition(mut self, cond: impl ::raiden::condition::ConditionBuilder<#condition_token_name>) -> Self { + let (cond_str, attr_names, attr_values) = cond.build(); + + if !attr_names.is_empty() { + self.builder = self.builder + .set_expression_attribute_names(Some(attr_names)); + } + + if !attr_values.is_empty() { + self.builder = self.builder + .set_expression_attribute_values(Some(attr_values)); + } + + self.builder = self.builder.condition_expression(cond_str); + self + } + + fn build_expression(&mut self) -> (String, ::raiden::AttributeNames , ::raiden::AttributeValues) { + let mut attr_names: ::raiden::AttributeNames = std::collections::HashMap::new(); + let mut attr_values: ::raiden::AttributeValues = std::collections::HashMap::new(); + + let add_items = std::mem::replace(&mut self.add_items, vec![]); + let set_items = std::mem::replace(&mut self.set_items, vec![]); + let remove_items = std::mem::replace(&mut self.remove_items, vec![]); + let delete_items = std::mem::replace(&mut self.delete_items, vec![]); + + let mut remove_expressions = remove_items.into_iter().map(|name| { + let placeholder = format!(":value{}", ::raiden::generate_value_id()); + let attr_name = format!("#{}", name.into_attr_name()); + let val = format!("{}", attr_name); + attr_names.insert(attr_name, name.into_attr_name()); + val + }).collect::>(); + + let mut set_expressions = vec![]; + for set_item in set_items { + match set_item { + raiden::update_expression::SetOrRemove::Set(expression, names, values) => { + attr_names = ::raiden::merge_map(attr_names, names); + attr_values = ::raiden::merge_map(attr_values, values); + set_expressions.push(expression); + } + // https://github.com/raiden-rs/raiden-dynamo/issues/64 + // If empty set detected, replace it to remove expression. + raiden::update_expression::SetOrRemove::Remove(expression, names) => { + attr_names = ::raiden::merge_map(attr_names, names); + remove_expressions.push(expression); + } + } + } + let set_expression = set_expressions.join(", "); + + let mut add_expressions = vec![]; + for add_item in add_items { + let (expression, names, values) = add_item; + if expression != "" { + attr_names = ::raiden::merge_map(attr_names, names); + attr_values = ::raiden::merge_map(attr_values, values); + add_expressions.push(expression); + } + } + let add_expression = add_expressions.join(", "); + + let remove_expression = remove_expressions.join(", "); + + let mut delete_expressions = vec![]; + for delete_item in delete_items { + let (expression, names, values) = delete_item; + if expression != "" { + attr_names = ::raiden::merge_map(attr_names, names); + attr_values = ::raiden::merge_map(attr_values, values); + delete_expressions.push(expression); + } + } + let delete_expression = delete_expressions.join(", "); + + let mut update_expressions: Vec = vec![]; + if !add_expression.is_empty() { + update_expressions.push(format!("ADD {}", add_expression)); + } + if !set_expression.is_empty() { + update_expressions.push(format!("SET {}", set_expression)); + } + if !remove_expression.is_empty() { + update_expressions.push(format!("REMOVE {}", remove_expression)); + } + if !delete_expression.is_empty() { + update_expressions.push(format!("DELETE {}", delete_expression)); + } + let update_expression = update_expressions.join(" "); + (update_expression, attr_names, attr_values) + } + + pub async fn run(mut self) -> Result<::raiden::update::UpdateOutput<#struct_name>, ::raiden::RaidenError> { + let (expression, names, values) = self.build_expression(); + + if self.builder.get_expression_attribute_names().is_none() { + if names.is_empty() { + self.builder = self.builder + .set_expression_attribute_names(None); + } else { + self.builder = self.builder + .set_expression_attribute_names(Some(names)); + } + } else { + let v = self + .builder + .get_expression_attribute_names() + .clone() + .unwrap(); + self.builder = self.builder + .set_expression_attribute_names(Some(::raiden::merge_map(v, names))); + } + + if self.builder.get_expression_attribute_values().is_none() { + if values.is_empty() { + self.builder = self.builder + .set_expression_attribute_values(None); + } else { + self.builder = self.builder + .set_expression_attribute_values(Some(values)); + } + } else { + let v = self + .builder + .get_expression_attribute_values() + .clone() + .unwrap(); + self.builder = self.builder + .set_expression_attribute_values(Some(::raiden::merge_map(v, values))); + } + + if expression != "" { + self.builder = self.builder.update_expression(expression); + } + + let has_return_values = self.builder.get_return_values().is_some(); + let builder = self.builder.clone(); + let client = self.client.clone(); + let policy: ::raiden::RetryPolicy = self.policy.into(); + + let res = policy.retry_if(move || { + let builder = builder.clone(); + let client = client.clone(); + async { #call_inner_run } + }, self.condition).await?; + + + let item = if has_return_values { + let mut res_item = res.attributes.unwrap(); + Some(#struct_name { + #(#from_item)* + }) + } else { + None + }; + + Ok(::raiden::update::UpdateOutput { + item, + consumed_capacity: res.consumed_capacity, + item_collection_metrics: res.item_collection_metrics, + }) + } + + async fn inner_run( + #inner_run_args + client: ::raiden::Client, + builder: ::raiden::UpdateItemInputBuilder, + ) -> Result<::raiden::UpdateItemOutput, ::raiden::RaidenError> { + Ok(#api_call_token?) + } + } + + } +} diff --git a/raiden-derive/src/lib.rs b/raiden-derive/src/lib.rs index 99cdce53..001abbc2 100644 --- a/raiden-derive/src/lib.rs +++ b/raiden-derive/src/lib.rs @@ -1,3 +1,6 @@ +#[cfg(all(feature = "aws-sdk", feature = "rusoto"))] +compile_error!("feature \"aws-sdk\" and \"rusoto\" cannot be enabled at the same time."); + use proc_macro::TokenStream; use quote::*; @@ -10,9 +13,18 @@ mod finder; mod helpers; mod key; mod key_condition; -mod ops; mod rename; +#[cfg(feature = "rusoto")] +mod rusoto; +#[cfg(feature = "rusoto")] +use rusoto::{client, ops}; + +#[cfg(feature = "aws-sdk")] +mod aws_sdk; +#[cfg(feature = "aws-sdk")] +use aws_sdk::{client, ops}; + use crate::rename::*; use std::str::FromStr; @@ -20,6 +32,17 @@ use std::str::FromStr; pub fn derive_raiden(input: TokenStream) -> TokenStream { let input = syn::parse_macro_input!(input as DeriveInput); + let (dynamodb_client_name, use_dynamodb_trait) = if cfg!(feature = "rusoto") { + ( + format_ident!("DynamoDbClient"), + Some(quote! { use ::raiden::DynamoDb as _; }), + ) + } else if cfg!(feature = "aws-sdk") { + (format_ident!("Client"), None) + } else { + unreachable!(); + }; + let struct_name = input.ident; let client_name = format_ident!("{}Client", struct_name); @@ -56,7 +79,7 @@ pub fn derive_raiden(input: TokenStream) -> TokenStream { let client_field = format_ident!("client"); let n = vec![ quote! { #table_name_field: &'static str }, - quote! { #client_field: ::raiden::DynamoDbClient }, + quote! { #client_field: ::raiden::#dynamodb_client_name }, ]; // let struct_fields = fields.named.iter().map(|f| { @@ -125,22 +148,19 @@ pub fn derive_raiden(input: TokenStream) -> TokenStream { &table_name, ); - let insertion_attribute_name = fields.named.iter().map(|f| { - let ident = &f.ident.clone().unwrap(); - let renamed = crate::finder::find_rename_value(&f.attrs); - let result = create_renamed(ident.to_string(), renamed, rename_all_type); - quote! { - names.insert( - format!("#{}", #result.clone()), - #result.to_string(), - ); - } - }); + let client_constructor = client::expand_client_constructor( + &struct_name, + &client_name, + &dynamodb_client_name, + &table_name, + &fields, + &rename_all_type, + ); let expanded = quote! { use ::raiden::IntoAttribute as _; use ::raiden::IntoAttrName as _; - use ::raiden::DynamoDb as _; + #use_dynamodb_trait pub struct #client_name { #( @@ -179,103 +199,10 @@ pub fn derive_raiden(input: TokenStream) -> TokenStream { #transact_write - impl #client_name { - - pub fn new(region: ::raiden::Region) -> Self { - let client = ::raiden::DynamoDbClient::new(region); - Self::new_with_dynamo_db_client(client) - } - - pub fn new_with_client(client: ::raiden::Client, region: ::raiden::Region) -> Self { - let client = ::raiden::DynamoDbClient::new_with_client(client, region); - Self::new_with_dynamo_db_client(client) - } - - fn new_with_dynamo_db_client(client: ::raiden::DynamoDbClient) -> Self { - let names = { - let mut names: ::raiden::AttributeNames = std::collections::HashMap::new(); - #(#insertion_attribute_name)* - names - }; - let projection_expression = Some(names.keys().map(|v| v.to_string()).collect::>().join(", ")); - - Self { - table_name: #table_name, - table_prefix: "".to_owned(), - table_suffix: "".to_owned(), - client, - retry_condition: ::raiden::RetryCondition::new(), - attribute_names: Some(names), - projection_expression - } - } - - pub fn with_retries(mut self, s: Box) -> Self { - self.retry_condition.strategy = s; - self - } - - pub fn table_prefix(mut self, prefix: impl Into) -> Self { - self.table_prefix = prefix.into(); - self - } - - pub fn table_suffix(mut self, suffix: impl Into) -> Self { - self.table_suffix = suffix.into(); - self - } - - pub fn table_name(&self) -> String { - format!("{}{}{}", self.table_prefix, self.table_name.to_string(), self.table_suffix) - } - } - - impl #struct_name { - pub fn client(region: ::raiden::Region) -> #client_name { - #client_name::new(region) - } - pub fn client_with(client: ::raiden::Client, region: ::raiden::Region) -> #client_name { - #client_name::new_with_client(client, region) - } - } + #client_constructor impl ::raiden::IdGenerator for #struct_name {} }; // Hand the output tokens back to the compiler. proc_macro::TokenStream::from(expanded) } - -// fn fetch_raiden_field(fields: &syn::FieldsNamed) -> Vec { -// let fields: Vec = fields -// .named -// .iter() -// .cloned() -// .filter(|f| { -// f.attrs.len() > 0 -// && f.attrs -// .iter() -// .any(|attr| attr.path.segments[0].ident == "raiden") -// }) -// .collect(); -// dbg!(&fields.len()); -// fields -// } - -// fn check_attr_of( -// name: &str, -// tokens: &mut proc_macro2::token_stream::IntoIter, -// ) -> Option { -// dbg!(&name); -// let mut tokens = match tokens.next() { -// Some(proc_macro2::TokenTree::Group(g)) => g.stream().into_iter(), -// _ => return None, -// }; -// dbg!(&name); -// -// match tokens.next() { -// Some(proc_macro2::TokenTree::Ident(ref ident)) if *ident == name => { -// return Some(tokens); -// } -// _ => return None, -// }; -// } diff --git a/raiden-derive/src/rusoto/client.rs b/raiden-derive/src/rusoto/client.rs new file mode 100644 index 00000000..a9caa1e0 --- /dev/null +++ b/raiden-derive/src/rusoto/client.rs @@ -0,0 +1,85 @@ +use quote::*; +use syn::*; + +pub(crate) fn expand_client_constructor( + struct_name: &Ident, + client_name: &Ident, + dynamodb_client_name: &Ident, + table_name: &str, + fields: &FieldsNamed, + rename_all_type: &crate::rename::RenameAllType, +) -> proc_macro2::TokenStream { + let insertion_attribute_name = fields.named.iter().map(|f| { + let ident = &f.ident.clone().unwrap(); + let renamed = crate::finder::find_rename_value(&f.attrs); + let result = crate::create_renamed(ident.to_string(), renamed, *rename_all_type); + quote! { + names.insert( + format!("#{}", #result.clone()), + #result.to_string(), + ); + } + }); + + quote! { + impl #client_name { + + pub fn new(region: ::raiden::Region) -> Self { + let client = ::raiden::#dynamodb_client_name::new(region); + Self::new_with_dynamo_db_client(client) + } + + pub fn new_with_client(client: ::raiden::Client, region: ::raiden::Region) -> Self { + let client = ::raiden::#dynamodb_client_name::new_with_client(client, region); + Self::new_with_dynamo_db_client(client) + } + + fn new_with_dynamo_db_client(client: ::raiden::#dynamodb_client_name) -> Self { + let names = { + let mut names: ::raiden::AttributeNames = std::collections::HashMap::new(); + #(#insertion_attribute_name)* + names + }; + let projection_expression = Some(names.keys().map(|v| v.to_string()).collect::>().join(", ")); + + Self { + table_name: #table_name, + table_prefix: "".to_owned(), + table_suffix: "".to_owned(), + client, + retry_condition: ::raiden::RetryCondition::new(), + attribute_names: Some(names), + projection_expression + } + } + + pub fn with_retries(mut self, s: Box) -> Self { + self.retry_condition.strategy = s; + self + } + + pub fn table_prefix(mut self, prefix: impl Into) -> Self { + self.table_prefix = prefix.into(); + self + } + + pub fn table_suffix(mut self, suffix: impl Into) -> Self { + self.table_suffix = suffix.into(); + self + } + + pub fn table_name(&self) -> String { + format!("{}{}{}", self.table_prefix, self.table_name.to_string(), self.table_suffix) + } + } + + impl #struct_name { + pub fn client(region: ::raiden::Region) -> #client_name { + #client_name::new(region) + } + pub fn client_with(client: ::raiden::Client, region: ::raiden::Region) -> #client_name { + #client_name::new_with_client(client, region) + } + } + } +} diff --git a/raiden-derive/src/rusoto/mod.rs b/raiden-derive/src/rusoto/mod.rs new file mode 100644 index 00000000..c5a66c24 --- /dev/null +++ b/raiden-derive/src/rusoto/mod.rs @@ -0,0 +1,2 @@ +pub mod client; +pub mod ops; diff --git a/raiden-derive/src/ops/batch_delete.rs b/raiden-derive/src/rusoto/ops/batch_delete.rs similarity index 100% rename from raiden-derive/src/ops/batch_delete.rs rename to raiden-derive/src/rusoto/ops/batch_delete.rs diff --git a/raiden-derive/src/ops/batch_get.rs b/raiden-derive/src/rusoto/ops/batch_get.rs similarity index 100% rename from raiden-derive/src/ops/batch_get.rs rename to raiden-derive/src/rusoto/ops/batch_get.rs diff --git a/raiden-derive/src/ops/delete.rs b/raiden-derive/src/rusoto/ops/delete.rs similarity index 100% rename from raiden-derive/src/ops/delete.rs rename to raiden-derive/src/rusoto/ops/delete.rs diff --git a/raiden-derive/src/ops/get.rs b/raiden-derive/src/rusoto/ops/get.rs similarity index 100% rename from raiden-derive/src/ops/get.rs rename to raiden-derive/src/rusoto/ops/get.rs diff --git a/raiden-derive/src/rusoto/ops/mod.rs b/raiden-derive/src/rusoto/ops/mod.rs new file mode 100644 index 00000000..f05976c0 --- /dev/null +++ b/raiden-derive/src/rusoto/ops/mod.rs @@ -0,0 +1,21 @@ +mod batch_delete; +mod batch_get; +mod delete; +mod get; +mod put; +mod query; +mod scan; +mod shared; +mod transact_write; +mod update; + +pub(crate) use batch_delete::*; +pub(crate) use batch_get::*; +pub(crate) use delete::*; +pub(crate) use get::*; +pub(crate) use put::*; +pub(crate) use query::*; +pub(crate) use scan::*; +pub(crate) use shared::*; +pub(crate) use transact_write::*; +pub(crate) use update::*; diff --git a/raiden-derive/src/ops/put.rs b/raiden-derive/src/rusoto/ops/put.rs similarity index 100% rename from raiden-derive/src/ops/put.rs rename to raiden-derive/src/rusoto/ops/put.rs diff --git a/raiden-derive/src/ops/query.rs b/raiden-derive/src/rusoto/ops/query.rs similarity index 100% rename from raiden-derive/src/ops/query.rs rename to raiden-derive/src/rusoto/ops/query.rs diff --git a/raiden-derive/src/ops/scan.rs b/raiden-derive/src/rusoto/ops/scan.rs similarity index 100% rename from raiden-derive/src/ops/scan.rs rename to raiden-derive/src/rusoto/ops/scan.rs diff --git a/raiden-derive/src/ops/shared.rs b/raiden-derive/src/rusoto/ops/shared.rs similarity index 100% rename from raiden-derive/src/ops/shared.rs rename to raiden-derive/src/rusoto/ops/shared.rs diff --git a/raiden-derive/src/ops/transact_write.rs b/raiden-derive/src/rusoto/ops/transact_write.rs similarity index 100% rename from raiden-derive/src/ops/transact_write.rs rename to raiden-derive/src/rusoto/ops/transact_write.rs diff --git a/raiden-derive/src/ops/update.rs b/raiden-derive/src/rusoto/ops/update.rs similarity index 100% rename from raiden-derive/src/ops/update.rs rename to raiden-derive/src/rusoto/ops/update.rs diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index b44ba891..c201f9d3 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -15,7 +15,7 @@ aws-smithy-runtime-api = { version = "0.56.1", optional = true } aws-smithy-types = { version = "0.56.1", optional = true } base64 = "^0.21" paste = "1.0.14" -raiden-derive = { version = "*", path = "../raiden-derive" } +raiden-derive = { version = "*", path = "../raiden-derive", default_features = false } rusoto_core_default = { package = "rusoto_core", version = "0.48", optional = true } rusoto_core_rustls = { package = "rusoto_core", version = "0.48", default_features = false, features = [ "rustls", @@ -38,14 +38,20 @@ tracing = { version = "0.1", optional = true } uuid = { version = "^1.4.1", features = ["v4"] } [dev-dependencies] +aws-credential-types = "0.56.1" +aws-smithy-client = "0.56.1" +hyper-rustls = { version = "0.24.2", default-features = false, features = [ + "http1", + "http2", + "native-tokio", +] } pretty_assertions = "1.4.0" raiden = { path = "./", features = ["tracing"], default_features = false } time = "0.3.30" -tokio = "1.33.0" +tokio = { version = "1.33.0", features = ["rt-multi-thread"] } tracing-subscriber = { version = "0.3.17", features = ["env-filter", "time"] } [features] -# default = ["aws-sdk"] default = ["rusoto"] aws-sdk = [ "dep:aws-config", @@ -53,8 +59,17 @@ aws-sdk = [ "dep:aws-smithy-http", "dep:aws-smithy-runtime-api", "dep:aws-smithy-types", + "raiden-derive/aws-sdk", +] +rusoto = [ + "dep:rusoto_core_default", + "dep:rusoto_dynamodb_default", + "raiden-derive/rusoto", +] +rusoto_rustls = [ + "dep:rusoto_core_rustls", + "dep:rusoto_dynamodb_rustls", + "raiden-derive/rusoto", ] -rusoto = ["dep:rusoto_core_default", "dep:rusoto_dynamodb_default"] -rusoto_rustls = ["dep:rusoto_core_rustls", "dep:rusoto_dynamodb_rustls"] rustls = ["rusoto_rustls"] tracing = ["dep:tracing", "raiden-derive/tracing"] diff --git a/raiden/examples/delete.rs b/raiden/examples/delete.rs index 65d2bdf4..f309290a 100644 --- a/raiden/examples/delete.rs +++ b/raiden/examples/delete.rs @@ -16,6 +16,35 @@ pub struct Test { year: usize, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = Test::client(raiden::Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + + let res = client.delete("id1", 2003_usize).run().await; + dbg!(&res); +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = Test::client_with(sdk_client); + let res = client.delete("id1", 2003_usize).run().await; + dbg!(&res); +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("delete=debug,info")) @@ -26,15 +55,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - - let res = client.delete("id1", 2003_usize).run().await; - dbg!(&res); - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/get_with_reserved.rs b/raiden/examples/get_with_reserved.rs index 53228283..84d1673b 100644 --- a/raiden/examples/get_with_reserved.rs +++ b/raiden/examples/get_with_reserved.rs @@ -12,6 +12,33 @@ pub struct Reserved { pub r#type: String, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = Reserved::client(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + + let _ = client.get("id0").run().await; +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = Reserved::client_with(sdk_client); + let _ = client.get("id0").run().await; +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("get_with_reserved=debug,info")) @@ -22,13 +49,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let client = Reserved::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let _ = client.get("id0").run().await; - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/get_with_retries.rs b/raiden/examples/get_with_retries.rs index 370e8714..d4a0b176 100644 --- a/raiden/examples/get_with_retries.rs +++ b/raiden/examples/get_with_retries.rs @@ -23,6 +23,41 @@ impl RetryStrategy for MyRetryStrategy { } } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = User::client(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + + let _ = client + .with_retries(Box::new(MyRetryStrategy)) + .get("anonymous") + .run() + .await; +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = User::client_with(sdk_client); + let _ = client + .with_retries(Box::new(MyRetryStrategy)) + .get("anonymous") + .run() + .await; +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("get_with_retries=debug,info")) @@ -33,17 +68,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let _ = client - .with_retries(Box::new(MyRetryStrategy)) - .get("anonymous") - .run() - .await; - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/hello.rs b/raiden/examples/hello.rs index d7cbba29..7ac9f506 100644 --- a/raiden/examples/hello.rs +++ b/raiden/examples/hello.rs @@ -16,6 +16,45 @@ pub struct User { pub name: String, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = User::client(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + //let user = UserPutItemInput { + // id: "a".to_owned(), + // name: "bokuweb".to_owned(), + // // uuid: "aa".to_owned(), + //}; + //let cond = User::condition() + // .attr(User::name()) + // .eq_attr(User::name()); + // + //// let cond = User::condition().not().attr_type(User::name(), AttributeType::N); + //// .and(User::condition().not().attribute_exists(User::id())); + let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; + let _ = client.batch_get(keys).run().await; +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = User::client_with(sdk_client); + let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; + let _ = client.batch_get(keys).run().await; +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("hello=debug,info")) @@ -26,25 +65,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - //let user = UserPutItemInput { - // id: "a".to_owned(), - // name: "bokuweb".to_owned(), - // // uuid: "aa".to_owned(), - //}; - //let cond = User::condition() - // .attr(User::name()) - // .eq_attr(User::name()); - // - //// let cond = User::condition().not().attr_type(User::name(), AttributeType::N); - //// .and(User::condition().not().attribute_exists(User::id())); - let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; - let _ = client.batch_get(keys).run().await; - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/last_key.rs b/raiden/examples/last_key.rs index 94a15872..a33961b4 100644 --- a/raiden/examples/last_key.rs +++ b/raiden/examples/last_key.rs @@ -13,6 +13,49 @@ pub struct Test { pub long_text: String, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = Test::client(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + let cond = Test::key_condition(Test::ref_id()).eq("id0"); + + let res = client + .query() + .index("testGSI") + .limit(5) + .key_condition(cond) + .run() + .await; + dbg!(&res.unwrap().items.len()); +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = Test::client_with(sdk_client); + let cond = Test::key_condition(Test::ref_id()).eq("id0"); + let res = client + .query() + .index("testGSI") + .limit(5) + .key_condition(cond) + .run() + .await; + dbg!(&res.unwrap().items.len()); +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("last_key=debug,info")) @@ -23,21 +66,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = Test::key_condition(Test::ref_id()).eq("id0"); - let res = client - .query() - .index("testGSI") - .limit(5) - .key_condition(cond) - .run() - .await; - dbg!(&res.unwrap().items.len()); - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/put.rs b/raiden/examples/put.rs index 8fde2ac7..2216bcba 100644 --- a/raiden/examples/put.rs +++ b/raiden/examples/put.rs @@ -13,6 +13,7 @@ impl From for CustomId { } } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] impl raiden::IntoAttribute for CustomId { fn into_attr(self) -> raiden::AttributeValue { raiden::AttributeValue { @@ -22,12 +23,31 @@ impl raiden::IntoAttribute for CustomId { } } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] impl raiden::FromAttribute for CustomId { fn from_attr(value: Option) -> Result { Ok(CustomId(value.unwrap().s.unwrap())) } } +#[cfg(feature = "aws-sdk")] +impl raiden::IntoAttribute for CustomId { + fn into_attr(self) -> raiden::AttributeValue { + raiden::AttributeValue::S(self.0) + } +} + +#[cfg(feature = "aws-sdk")] +impl raiden::FromAttribute for CustomId { + fn from_attr(value: Option) -> Result { + if let Some(raiden::AttributeValue::S(v)) = value { + Ok(CustomId(v)) + } else { + unimplemented!(); + } + } +} + #[derive(Raiden)] #[raiden(table_name = "user")] pub struct User { @@ -38,6 +58,41 @@ pub struct User { pub name: String, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = User::client(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let _ = client.put(input).run().await; +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = User::client_with(sdk_client); + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let _ = client.put(input).run().await; +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("put=debug,info")) @@ -48,17 +103,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let input = User::put_item_builder() - .id("testId".to_owned()) - .name("bokuweb".to_owned()) - .build(); - let _ = client.put(input).run().await; - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/query.rs b/raiden/examples/query.rs index ac3826d8..2e57fd32 100644 --- a/raiden/examples/query.rs +++ b/raiden/examples/query.rs @@ -15,17 +15,8 @@ pub struct QueryTestData0 { num: usize, } -#[tokio::main] -async fn main() { - tracing_subscriber::fmt() - .with_env_filter(EnvFilter::new("query=debug,info")) - .with_file(true) - .with_line_number(true) - .with_span_events(FmtSpan::CLOSE) - .with_target(true) - .with_timer(UtcTime::rfc_3339()) - .init(); - +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { let client = QueryTestData0::client(Region::Custom { endpoint: "http://localhost:8000".into(), name: "ap-northeast-1".into(), @@ -52,3 +43,53 @@ async fn main() { .await; dbg!(&res); } + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = QueryTestData0::client_with(sdk_client); + let cond = QueryTestData0::key_condition(QueryTestData0::id()) + .eq("id0") + .and(QueryTestData0::key_condition(QueryTestData0::year()).eq(1999)); + let res = client.query().key_condition(cond).run().await; + dbg!(&res); + + let cond = QueryTestData0::key_condition(QueryTestData0::id()) + .eq("id0") + .and(QueryTestData0::key_condition(QueryTestData0::year()).eq(1999)); + let res = client.query().key_condition(cond).run().await; + dbg!(&res); + + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id0"); + let filter = QueryTestData0::filter_expression(QueryTestData0::num()).eq(1000); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await; + dbg!(&res); +} + +fn main() { + tracing_subscriber::fmt() + .with_env_filter(EnvFilter::new("query=debug,info")) + .with_file(true) + .with_line_number(true) + .with_span_events(FmtSpan::CLOSE) + .with_target(true) + .with_timer(UtcTime::rfc_3339()) + .init(); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); +} diff --git a/raiden/examples/query_rename.rs b/raiden/examples/query_rename.rs index 43c22ef1..2a7fe39d 100644 --- a/raiden/examples/query_rename.rs +++ b/raiden/examples/query_rename.rs @@ -14,6 +14,46 @@ pub struct Project { pub updated_at: String, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = Project::client(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + let cond = Project::key_condition(Project::org_id()).eq("myOrg"); + let _res = client + .query() + .index("orgIndex") + .limit(11) + .key_condition(cond) + .run() + .await; +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = Project::client_with(sdk_client); + let cond = Project::key_condition(Project::org_id()).eq("myOrg"); + let _res = client + .query() + .index("orgIndex") + .limit(11) + .key_condition(cond) + .run() + .await; +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("query_rename=debug,info")) @@ -24,20 +64,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let client = Project::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = Project::key_condition(Project::org_id()).eq("myOrg"); - let _res = client - .query() - .index("orgIndex") - .limit(11) - .key_condition(cond) - .run() - .await; - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/scan.rs b/raiden/examples/scan.rs index b31fccc3..8e549db9 100644 --- a/raiden/examples/scan.rs +++ b/raiden/examples/scan.rs @@ -15,8 +15,35 @@ pub struct ScanTestData0 { num: usize, } -#[tokio::main] -async fn main() { +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = ScanTestData0::client(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + let res = client.scan().run().await; + dbg!(&res); +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = ScanTestData0::client_with(sdk_client); + let res = client.scan().run().await; + dbg!(&res); +} + +fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("scan=debug,info")) .with_file(true) @@ -26,10 +53,5 @@ async fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let client = ScanTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let res = client.scan().run().await; - dbg!(&res); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/scan_with_filter.rs b/raiden/examples/scan_with_filter.rs index 83f92ba8..b3986bf3 100644 --- a/raiden/examples/scan_with_filter.rs +++ b/raiden/examples/scan_with_filter.rs @@ -15,8 +15,37 @@ pub struct Scan { num: usize, } -#[tokio::main] -async fn main() { +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = Scan::client(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + let filter = Scan::filter_expression(Scan::num()).eq(1000); + let res = client.scan().filter(filter).run().await.unwrap(); + assert_eq!(res.items.len(), 50); +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = Scan::client_with(sdk_client); + let filter = Scan::filter_expression(Scan::num()).eq(1000); + let res = client.scan().filter(filter).run().await.unwrap(); + assert_eq!(res.items.len(), 50); +} + +fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("scan_with_filter=debug,info")) .with_file(true) @@ -26,11 +55,5 @@ async fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let client = Scan::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let filter = Scan::filter_expression(Scan::num()).eq(1000); - let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 50); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/transact_write.rs b/raiden/examples/transact_write.rs index c435ef75..5be3f3eb 100644 --- a/raiden/examples/transact_write.rs +++ b/raiden/examples/transact_write.rs @@ -12,6 +12,58 @@ pub struct User { pub name: String, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let tx = ::raiden::WriteTx::new(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + let cond = User::condition().attr_not_exists(User::id()); + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let input2 = User::put_item_builder() + .id("testId2".to_owned()) + .name("bokuweb".to_owned()) + .build(); + tx.put(User::put(input).condition(cond)) + .put(User::put(input2)) + .run() + .await + .unwrap(); +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let tx = ::raiden::WriteTx::new_with_client(sdk_client); + let cond = User::condition().attr_not_exists(User::id()); + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let input2 = User::put_item_builder() + .id("testId2".to_owned()) + .name("bokuweb".to_owned()) + .build(); + tx.put(User::put(input).condition(cond)) + .put(User::put(input2)) + .run() + .await + .unwrap(); +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("raiden=debug,info")) @@ -22,26 +74,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let tx = ::raiden::WriteTx::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = User::condition().attr_not_exists(User::id()); - let input = User::put_item_builder() - .id("testId".to_owned()) - .name("bokuweb".to_owned()) - .build(); - let input2 = User::put_item_builder() - .id("testId2".to_owned()) - .name("bokuweb".to_owned()) - .build(); - tx.put(User::put(input).condition(cond)) - .put(User::put(input2)) - .run() - .await - .unwrap(); - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/transact_write_with_http_client.rs b/raiden/examples/transact_write_with_http_client.rs index 2a79bc45..690e0939 100644 --- a/raiden/examples/transact_write_with_http_client.rs +++ b/raiden/examples/transact_write_with_http_client.rs @@ -12,6 +12,84 @@ pub struct User { pub name: String, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let dispatcher = + raiden::request::HttpClient::new().expect("failed to create request dispatcher"); + let credentials_provider = raiden::credential::DefaultCredentialsProvider::new() + .expect("failed to create credentials provider"); + let core_client = raiden::Client::new_with(credentials_provider, dispatcher); + + let tx = ::raiden::WriteTx::new_with_client( + core_client, + Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }, + ); + let cond = User::condition().attr_not_exists(User::id()); + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let input2 = User::put_item_builder() + .id("testId2".to_owned()) + .name("bokuweb".to_owned()) + .build(); + tx.put(User::put(input).condition(cond)) + .put(User::put(input2)) + .run() + .await + .unwrap(); +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + use aws_smithy_client::{http_connector::ConnectorSettings, hyper_ext}; + + let https_connector = hyper_rustls::HttpsConnectorBuilder::new() + .with_native_roots() + .https_or_http() + .enable_http1() + .enable_http2() + .build(); + let smithy_connector = hyper_ext::Adapter::builder() + .connector_settings( + ConnectorSettings::builder() + .connect_timeout(std::time::Duration::from_secs(5)) + .build(), + ) + .build(https_connector); + + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .http_connector(smithy_connector) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let tx = ::raiden::WriteTx::new_with_client(sdk_client); + let cond = User::condition().attr_not_exists(User::id()); + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let input2 = User::put_item_builder() + .id("testId2".to_owned()) + .name("bokuweb".to_owned()) + .build(); + tx.put(User::put(input).condition(cond)) + .put(User::put(input2)) + .run() + .await + .unwrap(); +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("raiden=debug,info")) @@ -22,35 +100,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let dispatcher = - raiden::request::HttpClient::new().expect("failed to create request dispatcher"); - let credentials_provider = raiden::credential::DefaultCredentialsProvider::new() - .expect("failed to create credentials provider"); - let core_client = raiden::Client::new_with(credentials_provider, dispatcher); - - let tx = ::raiden::WriteTx::new_with_client( - core_client, - Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }, - ); - let cond = User::condition().attr_not_exists(User::id()); - let input = User::put_item_builder() - .id("testId".to_owned()) - .name("bokuweb".to_owned()) - .build(); - let input2 = User::put_item_builder() - .id("testId2".to_owned()) - .name("bokuweb".to_owned()) - .build(); - tx.put(User::put(input).condition(cond)) - .put(User::put(input2)) - .run() - .await - .unwrap(); - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/update.rs b/raiden/examples/update.rs index 9197d371..46a379a0 100644 --- a/raiden/examples/update.rs +++ b/raiden/examples/update.rs @@ -14,6 +14,50 @@ pub struct Example { age: u8, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let client = Example::client(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }); + let set_expression = Example::update_expression() + .set(Example::name()) + .value("updated!!"); + let res = client + .update("id0") + .set(set_expression) + .run() + .await + .unwrap(); + dbg!(res.item); +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = Example::client_with(sdk_client); + let set_expression = Example::update_expression() + .set(Example::name()) + .value("updated!!"); + let res = client + .update("id0") + .set(set_expression) + .run() + .await + .unwrap(); + dbg!(res.item); +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("update=debug,info")) @@ -24,22 +68,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let client = Example::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let set_expression = Example::update_expression() - .set(Example::name()) - .value("updated!!"); - let res = client - .update("id0") - .set(set_expression) - .run() - .await - .unwrap(); - dbg!(res.item); - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/examples/with_http_client.rs b/raiden/examples/with_http_client.rs index 7380acc1..0b878a7c 100644 --- a/raiden/examples/with_http_client.rs +++ b/raiden/examples/with_http_client.rs @@ -16,6 +16,61 @@ pub struct User { pub name: String, } +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +async fn example() { + let dispatcher = + raiden::request::HttpClient::new().expect("failed to create request dispatcher"); + let credentials_provider = raiden::credential::DefaultCredentialsProvider::new() + .expect("failed to create credentials provider"); + let core_client = raiden::Client::new_with(credentials_provider, dispatcher); + + let client = User::client_with( + core_client, + Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }, + ); + + let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; + let _ = client.batch_get(keys).run().await; +} + +#[cfg(feature = "aws-sdk")] +async fn example() { + use aws_smithy_client::{http_connector::ConnectorSettings, hyper_ext}; + + let https_connector = hyper_rustls::HttpsConnectorBuilder::new() + .with_native_roots() + .https_or_http() + .enable_http1() + .enable_http2() + .build(); + let smithy_connector = hyper_ext::Adapter::builder() + .connector_settings( + ConnectorSettings::builder() + .connect_timeout(std::time::Duration::from_secs(5)) + .build(), + ) + .build(https_connector); + + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .http_connector(smithy_connector) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + let client = User::client_with(sdk_client); + let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; + let _ = client.batch_get(keys).run().await; +} + fn main() { tracing_subscriber::fmt() .with_env_filter(EnvFilter::new("with_http_client=debug,info")) @@ -26,24 +81,5 @@ fn main() { .with_timer(UtcTime::rfc_3339()) .init(); - let rt = tokio::runtime::Runtime::new().unwrap(); - async fn example() { - let dispatcher = - raiden::request::HttpClient::new().expect("failed to create request dispatcher"); - let credentials_provider = raiden::credential::DefaultCredentialsProvider::new() - .expect("failed to create credentials provider"); - let core_client = raiden::Client::new_with(credentials_provider, dispatcher); - - let client = User::client_with( - core_client, - Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }, - ); - - let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; - let _ = client.batch_get(keys).run().await; - } - rt.block_on(example()); + tokio::runtime::Runtime::new().unwrap().block_on(example()); } diff --git a/raiden/src/aws_sdk/errors.rs b/raiden/src/aws_sdk/errors.rs index 35dd1c1a..47db1495 100644 --- a/raiden/src/aws_sdk/errors.rs +++ b/raiden/src/aws_sdk/errors.rs @@ -2,13 +2,9 @@ use aws_smithy_http::result::SdkError; use aws_smithy_runtime_api::client::orchestrator::HttpResponse; use crate::{ - aws_sdk::{ - batch_get_item::BatchGetItemError, batch_write_item::BatchWriteItemError, - delete_item::DeleteItemError, get_item::GetItemError, put_item::PutItemError, - query::QueryError, scan::ScanError, transact_write_items::TransactWriteItemsError, - update_item::UpdateItemError, - }, - RaidenError, RaidenTransactionCancellationReasons, + BatchGetItemError, BatchWriteItemError, DeleteItemError, GetItemError, PutItemError, + QueryError, RaidenError, RaidenTransactionCancellationReasons, ScanError, + TransactWriteItemsError, UpdateItemError, }; type AwsSdkError = SdkError; diff --git a/raiden/src/aws_sdk/mod.rs b/raiden/src/aws_sdk/mod.rs index aa6bd4aa..ef263d0b 100644 --- a/raiden/src/aws_sdk/mod.rs +++ b/raiden/src/aws_sdk/mod.rs @@ -1,13 +1,29 @@ mod errors; -pub(crate) mod ops; +mod ops; pub(crate) mod serialize; use std::collections::{BTreeSet, HashMap, HashSet}; +pub use self::{errors::*, ops::*}; pub use aws_sdk_dynamodb::{ - client::*, config::*, error::*, meta::*, operation::*, primitives::*, types::*, + client::*, + config::*, + error::*, + meta::*, + operation::{ + batch_get_item::{builders::*, *}, + batch_write_item::{builders::*, *}, + delete_item::{builders::*, *}, + get_item::{builders::*, *}, + put_item::{builders::*, *}, + query::{builders::*, *}, + scan::{builders::*, *}, + transact_write_items::{builders::*, *}, + update_item::{builders::*, *}, + }, + primitives::*, + types::{builders::*, *}, }; -pub use errors::*; use crate::{ AttributeType, AttributeValues, ConversionError, FromAttribute, FromStringSetItem, diff --git a/raiden/src/aws_sdk/ops/mod.rs b/raiden/src/aws_sdk/ops/mod.rs index 7f7dabba..d24fe9fb 100644 --- a/raiden/src/aws_sdk/ops/mod.rs +++ b/raiden/src/aws_sdk/ops/mod.rs @@ -1,8 +1,17 @@ -pub mod batch_delete; -pub mod batch_get; -pub mod get; -pub mod put; -pub mod query; -pub mod scan; -pub mod transact_write; -pub mod update; +mod batch_delete; +mod batch_get; +mod get; +mod put; +mod query; +mod scan; +mod transact_write; +mod update; + +pub use batch_delete::*; +pub use batch_get::*; +pub use get::*; +pub use put::*; +pub use query::*; +pub use scan::*; +pub use transact_write::*; +pub use update::*; diff --git a/raiden/src/aws_sdk/ops/transact_write.rs b/raiden/src/aws_sdk/ops/transact_write.rs index 367e4292..0a0b41aa 100644 --- a/raiden/src/aws_sdk/ops/transact_write.rs +++ b/raiden/src/aws_sdk/ops/transact_write.rs @@ -1,11 +1,8 @@ // DynamoDb, DynamoDbClient, TransactWriteItem, TransactWriteItemsInput use crate::{ - aws_sdk::{ - transact_write_items::builders::TransactWriteItemsFluentBuilder, Client, Config, Region, - TransactWriteItem, - }, - RaidenError, RetryCondition, RetryStrategy, TransactWriteConditionCheckBuilder, - TransactWriteDeleteBuilder, TransactWritePutBuilder, TransactWriteUpdateBuilder, + Client, Config, RaidenError, Region, RetryCondition, RetryStrategy, + TransactWriteConditionCheckBuilder, TransactWriteDeleteBuilder, TransactWriteItem, + TransactWriteItemsFluentBuilder, TransactWritePutBuilder, TransactWriteUpdateBuilder, }; pub struct WriteTx { diff --git a/raiden/src/condition/mod.rs b/raiden/src/condition/mod.rs index b191e0e1..15690ea9 100644 --- a/raiden/src/condition/mod.rs +++ b/raiden/src/condition/mod.rs @@ -151,7 +151,7 @@ impl super::IntoAttrValues for ConditionFunctionExpression { use crypto::md5::Md5; let mut m: super::AttributeValues = std::collections::HashMap::new(); - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] match self { Self::AttributeType(_path, t) => { m.insert( diff --git a/raiden/src/errors/mod.rs b/raiden/src/errors/mod.rs index 96fed7c3..7e60365e 100644 --- a/raiden/src/errors/mod.rs +++ b/raiden/src/errors/mod.rs @@ -24,12 +24,6 @@ pub enum RaidenError { ResourceNotFound(String), #[error("`{0}`")] SizeLimitExceeded(String), - #[error("`transaction canceled error {reasons}`")] - TransactionCanceled { - reasons: RaidenTransactionCancellationReasons, - #[cfg(feature = "aws-sdk")] - raw_reasons: Vec, - }, #[error("`{0}`")] TransactionConflict(String), #[error("`{0}`")] @@ -37,22 +31,27 @@ pub enum RaidenError { // // Next errors returns only using rusoto. // - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] #[error("blocking error")] Blocking, - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] #[error("`{0}`")] Credentials(crate::CredentialsError), - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] #[error("`{0}`")] HttpDispatch(crate::HttpDispatchError), - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] #[error("`{0}`")] ParseError(String), - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] + #[error("`transaction canceled error {reasons}`")] + TransactionCanceled { + reasons: RaidenTransactionCancellationReasons, + }, + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] #[error("unknown error")] Unknown(crate::request::BufferedHttpResponse), - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] #[error("`{0}`")] Validation(String), // @@ -68,6 +67,12 @@ pub enum RaidenError { #[error("`{0:?}`")] Timeout(aws_smithy_http::result::TimeoutError), #[cfg(feature = "aws-sdk")] + #[error("`transaction canceled error {reasons}: {raw_reasons:?}`")] + TransactionCanceled { + reasons: RaidenTransactionCancellationReasons, + raw_reasons: Vec, + }, + #[cfg(feature = "aws-sdk")] #[error("unknown error")] Unknown(aws_smithy_runtime_api::client::orchestrator::HttpResponse), // diff --git a/raiden/src/lib.rs b/raiden/src/lib.rs index bd6c6326..daf44876 100644 --- a/raiden/src/lib.rs +++ b/raiden/src/lib.rs @@ -1,3 +1,14 @@ +#[cfg(all(feature = "rusoto", feature = "rusoto_rustls"))] +compile_error!("feature \"rusoto\" and \"rusoto_rustls\" cannot be enabled at the same time."); + +#[cfg(any( + all(feature = "aws-sdk", feature = "rusoto"), + all(feature = "aws-sdk", feature = "rusoto_rustls") +))] +compile_error!( + "feature \"aws-sdk\" and \"rusoto\" or \"rusoto_rustls\" cannot be enabled at the same time." +); + #[macro_use] extern crate serde_derive; @@ -13,21 +24,10 @@ pub mod types; pub mod update_expression; pub mod value_id; -#[cfg(all(feature = "rusoto", feature = "rusoto_rustls"))] -compile_error!("feature \"rusoto\" and \"rusoto_rustls\" cannot be enabled at the same time."); - -#[cfg(any( - all(feature = "aws-sdk", feature = "rusoto"), - all(feature = "aws-sdk", feature = "rusoto_rustls") -))] -compile_error!( - "feature \"aws-sdk\" and \"rusoto\" or \"rusoto_rustls\" cannot be enabled at the same time." -); - -#[cfg(any(feature = "rusoto", feature = "rustls"))] +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] mod rusoto; -#[cfg(any(feature = "rusoto", feature = "rustls"))] +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] pub use rusoto::*; #[cfg(feature = "aws-sdk")] @@ -46,10 +46,9 @@ pub use retry::*; pub use id_generator::*; pub use raiden_derive::*; +pub use types::*; pub use value_id::*; -pub type Placeholder = String; - pub use safe_builder::Builder; #[derive(Debug, Clone, PartialEq)] diff --git a/raiden/src/retry/mod.rs b/raiden/src/retry/mod.rs index 465694e0..ad1ddd87 100644 --- a/raiden/src/retry/mod.rs +++ b/raiden/src/retry/mod.rs @@ -69,7 +69,7 @@ pub struct DefaultRetryStrategy; impl RetryStrategy for DefaultRetryStrategy { fn should_retry(&self, error: &RaidenError) -> bool { - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] return matches!( error, RaidenError::InternalServerError(_) diff --git a/raiden/src/rusoto/mod.rs b/raiden/src/rusoto/mod.rs index ebbdaaa5..d736bf52 100644 --- a/raiden/src/rusoto/mod.rs +++ b/raiden/src/rusoto/mod.rs @@ -7,10 +7,10 @@ pub use rusoto_dynamodb_default::*; #[cfg(feature = "rusoto")] pub use rusoto_core_default::*; -#[cfg(feature = "rustls")] +#[cfg(feature = "rusoto_rustls")] pub use rusoto_dynamodb_rustls::*; -#[cfg(feature = "rustls")] +#[cfg(feature = "rusoto_rustls")] pub use rusoto_core_rustls::*; pub use self::{errors::*, ops::*}; diff --git a/raiden/src/update_expression/add.rs b/raiden/src/update_expression/add.rs index 1210a768..04a3baee 100644 --- a/raiden/src/update_expression/add.rs +++ b/raiden/src/update_expression/add.rs @@ -33,7 +33,7 @@ impl UpdateAddExpressionBuilder for AddExpressionFilled< // See. https://github.com/raiden-rs/raiden/issues/57 // https://github.com/raiden-rs/raiden/issues/58 - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] let is_null = value.null.is_some(); #[cfg(feature = "aws-sdk")] let is_null = value.is_null(); diff --git a/raiden/src/update_expression/delete.rs b/raiden/src/update_expression/delete.rs index ed8fa10d..4ce14018 100644 --- a/raiden/src/update_expression/delete.rs +++ b/raiden/src/update_expression/delete.rs @@ -33,7 +33,7 @@ impl UpdateDeleteExpressionBuilder for DeleteExpressionF // See. https://github.com/raiden-rs/raiden/issues/57 // https://github.com/raiden-rs/raiden/issues/58 - #[cfg(any(feature = "rusoto", feature = "rustls"))] + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] let is_null = value.null.is_some(); #[cfg(feature = "aws-sdk")] let is_null = value.is_null(); diff --git a/raiden/tests/all/get.rs b/raiden/tests/all/get.rs index 9b22732a..7b60dfc6 100644 --- a/raiden/tests/all/get.rs +++ b/raiden/tests/all/get.rs @@ -85,12 +85,13 @@ mod tests { name: "ap-northeast-1".into(), }); let res = client.get("not_exist_key").consistent().run().await; - assert_eq!( - res, - Err(RaidenError::ResourceNotFound( - "resource not found".to_owned() - )), - ); + assert!(res.is_err()); + + if let RaidenError::ResourceNotFound(msg) = res.unwrap_err() { + assert_eq!("resource not found", msg); + } else { + panic!("err should be RaidenError::ResourceNotFound"); + } } rt.block_on(example()); } @@ -114,15 +115,13 @@ mod tests { name: "ap-northeast-1".into(), }); let res = client.get("user_primary_key").consistent().run().await; - assert_eq!( - res, - // Err(RaidenError::AttributeValueNotFoundError { - // attr_name: "unstored".to_owned(), - // }), - Err(RaidenError::AttributeConvertError { - attr_name: "unstored".to_owned(), - }), - ); + assert!(res.is_err()); + + if let RaidenError::AttributeConvertError { attr_name } = res.unwrap_err() { + assert_eq!("unstored", attr_name); + } else { + panic!("err should be RaidenError::AttributeConvertError"); + } } rt.block_on(example()); } diff --git a/raiden/tests/all/put.rs b/raiden/tests/all/put.rs index 89711371..790c771f 100644 --- a/raiden/tests/all/put.rs +++ b/raiden/tests/all/put.rs @@ -148,12 +148,13 @@ mod tests { }; let cond = User::condition().value("bokuweb_").eq_attr(User::name()); let res = client.put(user).condition(cond).run().await; - assert_eq!( - Err(::raiden::RaidenError::ConditionalCheckFailed( - "The conditional request failed".to_owned() - )), - res - ); + assert!(res.is_err()); + + if let RaidenError::ConditionalCheckFailed(msg) = res.unwrap_err() { + assert_eq!("The conditional request failed", msg); + } else { + panic!("err should be RaidenError::ConditionalCheckFailed"); + } } rt.block_on(example()); } @@ -173,12 +174,13 @@ mod tests { }; let cond = User::condition().attr_not_exists(User::id()); let res = client.put(user).condition(cond).run().await; - assert_eq!( - Err(::raiden::RaidenError::ConditionalCheckFailed( - "The conditional request failed".to_owned() - )), - res - ); + assert!(res.is_err()); + + if let RaidenError::ConditionalCheckFailed(msg) = res.unwrap_err() { + assert_eq!("The conditional request failed", msg); + } else { + panic!("err should be RaidenError::ConditionalCheckFailed"); + } } rt.block_on(example()); } diff --git a/raiden/tests/all/transact_write.rs b/raiden/tests/all/transact_write.rs index 8f02c90d..bb5fe7a7 100644 --- a/raiden/tests/all/transact_write.rs +++ b/raiden/tests/all/transact_write.rs @@ -171,10 +171,14 @@ mod tests { name: "ap-northeast-1".into(), }); let res = client.get("id0").run().await; - assert_eq!( - res.unwrap_err(), - RaidenError::ResourceNotFound("resource not found".to_owned()) - ); + assert!(res.is_err()); + + if let RaidenError::ResourceNotFound(msg) = res.unwrap_err() { + assert_eq!("resource not found", msg); + } else { + panic!("err should be RaidenError::ResourceNotFound"); + } + let res = client.get("testId").run().await; assert_eq!( res.unwrap().item, @@ -264,16 +268,19 @@ mod tests { ) .run() .await; - assert_eq!(res.is_err(), true,); - assert_eq!( - res.unwrap_err(), - RaidenError::TransactionCanceled { - reasons: RaidenTransactionCancellationReasons(vec![ + assert!(res.is_err()); + + if let RaidenError::TransactionCanceled { reasons, .. } = res.unwrap_err() { + assert_eq!( + RaidenTransactionCancellationReasons(vec![ None, Some(RaidenTransactionCancellationReason::ConditionalCheckFailed), ]), - } - ); + reasons + ); + } else { + panic!("err should be RaidenError::TransactionCanceled"); + } } rt.block_on(example()); } From 34c635dfaa12f62a03391b812992b8812fe2a19a Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Tue, 31 Oct 2023 22:27:40 +0900 Subject: [PATCH 04/22] chore: impl tests for aws-sdk feature --- Cargo.lock | 4 +- makefile | 1 + raiden-derive/src/aws_sdk/client.rs | 4 +- raiden-derive/src/aws_sdk/ops/shared.rs | 88 +++--- raiden-derive/src/rusoto/ops/shared.rs | 89 +++--- raiden/Cargo.toml | 2 +- raiden/src/aws_sdk/mod.rs | 14 +- raiden/src/update_expression/add.rs | 2 +- raiden/src/update_expression/set.rs | 4 +- raiden/tests/all/batch_delete.rs | 88 ++---- raiden/tests/all/batch_get.rs | 124 ++------ raiden/tests/all/condition.rs | 31 +- raiden/tests/all/delete.rs | 42 +-- raiden/tests/all/filter_expression.rs | 14 +- raiden/tests/all/get.rs | 221 ++++++-------- raiden/tests/all/key_condition.rs | 4 +- raiden/tests/all/mod.rs | 74 +++++ raiden/tests/all/put.rs | 184 +++++------ raiden/tests/all/query.rs | 387 +++++++++++------------- raiden/tests/all/rename.rs | 32 +- raiden/tests/all/rename_all.rs | 22 +- raiden/tests/all/scan.rs | 204 ++++++------- raiden/tests/all/transact_write.rs | 102 +++---- raiden/tests/all/update.rs | 293 ++++++++---------- 24 files changed, 918 insertions(+), 1112 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 4111c0cd..2d2f45ac 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -155,9 +155,9 @@ dependencies = [ [[package]] name = "aws-sdk-dynamodb" -version = "0.33.0" +version = "0.34.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c6c39120bb76fe32e13d4c0e9be67f3732f80ee63faee2c74ebf9ade4705b106" +checksum = "10aef6843bfc2dabfccad27f7e1ab303942bbda19f7ea7777d0d74388d073db4" dependencies = [ "aws-credential-types", "aws-http", diff --git a/makefile b/makefile index 2c3d307f..6400ff22 100644 --- a/makefile +++ b/makefile @@ -9,6 +9,7 @@ dynamo: test: make dynamo cargo test -- --test-threads=1 + make dynamo cargo test --no-default-features --features aws-sdk -- --test-threads=1 .PHONY: lint diff --git a/raiden-derive/src/aws_sdk/client.rs b/raiden-derive/src/aws_sdk/client.rs index 1331d21f..77ee235a 100644 --- a/raiden-derive/src/aws_sdk/client.rs +++ b/raiden-derive/src/aws_sdk/client.rs @@ -30,7 +30,7 @@ pub(crate) fn expand_client_constructor( Self::new_with_dynamo_db_client(client) } - pub fn new_with_client(client: ::raiden::Client) -> Self { + pub fn new_with_client(client: ::raiden::#dynamodb_client_name) -> Self { Self::new_with_dynamo_db_client(client) } @@ -78,7 +78,7 @@ pub(crate) fn expand_client_constructor( #client_name::new(region) } - pub fn client_with(client: ::raiden::Client) -> #client_name { + pub fn client_with(client: ::raiden::#dynamodb_client_name) -> #client_name { #client_name::new_with_client(client) } } diff --git a/raiden-derive/src/aws_sdk/ops/shared.rs b/raiden-derive/src/aws_sdk/ops/shared.rs index 11df1e21..fa531226 100644 --- a/raiden-derive/src/aws_sdk/ops/shared.rs +++ b/raiden-derive/src/aws_sdk/ops/shared.rs @@ -19,57 +19,57 @@ pub(crate) fn expand_attr_to_item( let ty = &f.ty; let item = quote! { - let item = <#ty as ResolveAttribute>::resolve_attr(&#attr_key, &mut #item_ident); + let item = <#ty as ResolveAttribute>::resolve_attr(&#attr_key, &mut #item_ident); }; if crate::finder::is_option(ty) { quote! { - #ident: { - #item - if item.is_none() { - None - } else { - let converted = ::raiden::FromAttribute::from_attr(item); - if converted.is_err() { - return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + #ident: { + #item + if item.is_none() { + None + } else { + let converted = ::raiden::FromAttribute::from_attr(item); + if converted.is_err() { + return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + } + converted.unwrap() } - converted.unwrap() - } - }, + }, } } else if use_default { quote! { - #ident: { - #item - if item.is_none() { - #ty::default() - } else { - let item = item.unwrap(); - // If null is true, use default value. - if let Some(true) = item.null { - #ty::default() - } else { - let converted = ::raiden::FromAttribute::from_attr(Some(item)); - if converted.is_err() { - // TODO: improve error handling. - return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + #ident: { + #item + if item.is_none() { + #ty::default() + } else { + let item = item.unwrap(); + // If null is true, use default value. + if item.is_null() { + #ty::default() + } else { + let converted = ::raiden::FromAttribute::from_attr(Some(item)); + if converted.is_err() { + // TODO: improve error handling. + return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + } + converted.unwrap() + } } - converted.unwrap() - } - } - }, + }, } } else { quote! { #ident: { - #item - let converted = ::raiden::FromAttribute::from_attr(item); - if converted.is_err() { - // TODO: improve error handling. - return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); - } - converted.unwrap() + #item + let converted = ::raiden::FromAttribute::from_attr(item); + if converted.is_err() { + // TODO: improve error handling. + return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + } + converted.unwrap() }, - } + } } }).collect() } @@ -86,12 +86,12 @@ macro_rules! api_call_token { let span_token = if cfg!(feature = "tracing") { ::quote::quote! { - use tracing::Instrument; - let fut = fut.instrument(::tracing::debug_span!( - "dynamodb::action", - table = #table_name, - api = std::stringify!(#operation), - )); + use tracing::Instrument; + let fut = fut.instrument(::tracing::debug_span!( + "dynamodb::action", + table = #table_name, + api = std::stringify!(#operation), + )); } } else { ::quote::quote! {} diff --git a/raiden-derive/src/rusoto/ops/shared.rs b/raiden-derive/src/rusoto/ops/shared.rs index 015034e6..2b926f81 100644 --- a/raiden-derive/src/rusoto/ops/shared.rs +++ b/raiden-derive/src/rusoto/ops/shared.rs @@ -19,57 +19,58 @@ pub(crate) fn expand_attr_to_item( let ty = &f.ty; let item = quote! { - let item = <#ty as ResolveAttribute>::resolve_attr(&#attr_key, &mut #item_ident); + let item = <#ty as ResolveAttribute>::resolve_attr(&#attr_key, &mut #item_ident); }; + if crate::finder::is_option(ty) { quote! { - #ident: { - #item - if item.is_none() { - None - } else { - let converted = ::raiden::FromAttribute::from_attr(item); - if converted.is_err() { - return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + #ident: { + #item + if item.is_none() { + None + } else { + let converted = ::raiden::FromAttribute::from_attr(item); + if converted.is_err() { + return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + } + converted.unwrap() } - converted.unwrap() - } - }, + }, } } else if use_default { quote! { - #ident: { - #item - if item.is_none() { - #ty::default() - } else { - let item = item.unwrap(); - // If null is true, use default value. - if let Some(true) = item.null { - #ty::default() - } else { - let converted = ::raiden::FromAttribute::from_attr(Some(item)); - if converted.is_err() { - // TODO: improve error handling. - return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + #ident: { + #item + if item.is_none() { + #ty::default() + } else { + let item = item.unwrap(); + // If null is true, use default value. + if let Some(true) = item.null { + #ty::default() + } else { + let converted = ::raiden::FromAttribute::from_attr(Some(item)); + if converted.is_err() { + // TODO: improve error handling. + return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + } + converted.unwrap() + } } - converted.unwrap() - } - } - }, + }, } } else { quote! { #ident: { - #item - let converted = ::raiden::FromAttribute::from_attr(item); - if converted.is_err() { - // TODO: improve error handling. - return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); - } - converted.unwrap() + #item + let converted = ::raiden::FromAttribute::from_attr(item); + if converted.is_err() { + // TODO: improve error handling. + return Err(::raiden::RaidenError::AttributeConvertError{ attr_name: #attr_key.to_string() }); + } + converted.unwrap() }, - } + } } }).collect() } @@ -86,12 +87,12 @@ macro_rules! api_call_token { let span_token = if cfg!(feature = "tracing") { ::quote::quote! { - use tracing::Instrument; - let fut = fut.instrument(::tracing::debug_span!( - "dynamodb::action", - table = #table_name, - api = std::stringify!(#operation), - )); + use tracing::Instrument; + let fut = fut.instrument(::tracing::debug_span!( + "dynamodb::action", + table = #table_name, + api = std::stringify!(#operation), + )); } } else { ::quote::quote! {} diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index c201f9d3..9859d8d6 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -9,7 +9,7 @@ edition = "2018" [dependencies] again = "0.1" aws-config = { version = "0.56.1", optional = true } -aws-sdk-dynamodb = { version = "0.33.0", optional = true } +aws-sdk-dynamodb = { version = "0.34.0", optional = true } aws-smithy-http = { version = "0.56.1", optional = true } aws-smithy-runtime-api = { version = "0.56.1", optional = true } aws-smithy-types = { version = "0.56.1", optional = true } diff --git a/raiden/src/aws_sdk/mod.rs b/raiden/src/aws_sdk/mod.rs index ef263d0b..544c7c76 100644 --- a/raiden/src/aws_sdk/mod.rs +++ b/raiden/src/aws_sdk/mod.rs @@ -294,17 +294,17 @@ impl FromAttribute for BTreeSet { pub fn is_attr_value_empty(a: &AttributeValue) -> bool { match &a { - &AttributeValue::B(v) => v == &aws_smithy_types::Blob::new(vec![]), - &AttributeValue::Bool(v) => *v == false, + &AttributeValue::B(_) + | &AttributeValue::Bool(_) + | &AttributeValue::M(_) + | &AttributeValue::N(_) + | &AttributeValue::Null(_) + | &AttributeValue::S(_) => false, &AttributeValue::Bs(v) => v.is_empty(), &AttributeValue::L(v) => v.is_empty(), - &AttributeValue::M(v) => v.is_empty(), - &AttributeValue::N(v) => v.is_empty(), &AttributeValue::Ns(v) => v.is_empty(), - &AttributeValue::Null(_) => a.is_null(), - &AttributeValue::S(v) => v.is_empty(), &AttributeValue::Ss(v) => v.is_empty(), - _ => false, + _ => true, } } diff --git a/raiden/src/update_expression/add.rs b/raiden/src/update_expression/add.rs index 04a3baee..21c4dd14 100644 --- a/raiden/src/update_expression/add.rs +++ b/raiden/src/update_expression/add.rs @@ -79,7 +79,7 @@ mod tests { let mut expected_values = std::collections::HashMap::new(); expected_names.insert("#age".to_owned(), "age".to_owned()); expected_values.insert(":value0".to_owned(), 42.into_attr()); - assert_eq!(expression, "#age :value0".to_owned(),); + assert_eq!(expression, "#age :value0".to_owned()); assert_eq!(names, expected_names); assert_eq!(values, expected_values); } diff --git a/raiden/src/update_expression/set.rs b/raiden/src/update_expression/set.rs index 07c60dde..89f8d606 100644 --- a/raiden/src/update_expression/set.rs +++ b/raiden/src/update_expression/set.rs @@ -229,7 +229,7 @@ mod tests { let mut expected_values = std::collections::HashMap::new(); expected_names.insert("#name".to_owned(), "name".to_owned()); expected_values.insert(":value0".to_owned(), "updated!!".into_attr()); - assert_eq!(expression, "#name = :value0".to_owned(),); + assert_eq!(expression, "#name = :value0".to_owned()); assert_eq!(names, expected_names); assert_eq!(values, expected_values); return; @@ -272,7 +272,7 @@ mod tests { let mut expected_values = std::collections::HashMap::new(); expected_names.insert("#age".to_owned(), "age".to_owned()); expected_values.insert(":value0".to_owned(), 10.into_attr()); - assert_eq!(expression, "#age = #age + :value0".to_owned(),); + assert_eq!(expression, "#age = #age + :value0".to_owned()); assert_eq!(names, expected_names); assert_eq!(values, expected_values); return; diff --git a/raiden/tests/all/batch_delete.rs b/raiden/tests/all/batch_delete.rs index d6b06892..84323938 100644 --- a/raiden/tests/all/batch_delete.rs +++ b/raiden/tests/all/batch_delete.rs @@ -14,18 +14,14 @@ mod partition_key_tests { #[test] fn test_batch_delete_item() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchDeleteTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchDeleteTest0); let res: batch_delete::BatchDeleteOutput = client .batch_delete(vec!["id0", "id1", "id2"]) .run() .await .unwrap(); + assert_eq!( res, batch_delete::BatchDeleteOutput { @@ -34,58 +30,50 @@ mod partition_key_tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_batch_delete_item_for_stored_and_unstored_keys() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchDeleteTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchDeleteTest0); let res = client.batch_delete(vec!["id3", "unstored"]).run().await; + assert!(res.is_ok()); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_batch_delete_item_for_unstored_keys() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchDeleteTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchDeleteTest0); let res = client .batch_delete(vec!["unstored0", "unstored1", "unstored2"]) .run() .await; + assert!(res.is_ok()); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_batch_delete_over_25_items() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchDeleteTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchDeleteTest0); let res = client .batch_delete((4..=100).map(|i| format!("id{i}")).collect()) .run() .await; + assert!(res.is_ok()); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } @@ -105,13 +93,8 @@ mod partition_key_and_sort_key_tests { #[test] fn test_batch_delete_item_with_sort_key() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchDeleteTest1::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchDeleteTest1); let res = client .batch_delete(vec![ ("id0", 1999_usize), @@ -120,38 +103,32 @@ mod partition_key_and_sort_key_tests { ]) .run() .await; + assert!(res.is_ok()); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_batch_delete_item_with_sort_key_for_stored_and_unstored_keys() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchDeleteTest1::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchDeleteTest1); let res = client .batch_delete(vec![("id3", 2002_usize), ("unstored", 2000_usize)]) .run() .await; + assert!(res.is_ok()); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_batch_delete_item_with_sort_key_for_unstored_keys() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchDeleteTest1::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchDeleteTest1); let res = client .batch_delete(vec![ ("unstored0", 1999_usize), @@ -160,20 +137,17 @@ mod partition_key_and_sort_key_tests { ]) .run() .await; + assert!(res.is_ok()); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_batch_delete_with_sort_key_over_25_items() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchDeleteTest1::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchDeleteTest1); let res = client .batch_delete( (4..=100) @@ -182,8 +156,10 @@ mod partition_key_and_sort_key_tests { ) .run() .await; + assert!(res.is_ok()); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/batch_get.rs b/raiden/tests/all/batch_get.rs index 0a18952c..64000712 100644 --- a/raiden/tests/all/batch_get.rs +++ b/raiden/tests/all/batch_get.rs @@ -25,18 +25,14 @@ mod tests { #[test] fn test_batch_get_item() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchTest0); let res: batch_get::BatchGetOutput = client .batch_get(vec!["id0", "id1", "id2"]) .run() .await .unwrap(); + assert_eq!( sort_by_id_0(res), batch_get::BatchGetOutput { @@ -55,28 +51,18 @@ mod tests { }, ], consumed_capacity: None, - unprocessed_keys: Some(KeysAndAttributes { - attributes_to_get: None, - consistent_read: None, - expression_attribute_names: None, - keys: vec![], - projection_expression: None, - }), + unprocessed_keys: Some(crate::all::default_key_and_attributes()), } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_batch_get_item_extended() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchTest0); let keys: Vec = (0..101).into_iter().map(|n| format!("id{n}")).collect(); let expected_items = (0..101) .map(|n| BatchTest0 { @@ -86,40 +72,32 @@ mod tests { .collect(); let res: batch_get::BatchGetOutput = client.batch_get(keys).run().await.unwrap(); + assert_eq!( sort_by_id_0(res), batch_get::BatchGetOutput { items: expected_items, consumed_capacity: None, - unprocessed_keys: Some(KeysAndAttributes { - attributes_to_get: None, - consistent_read: None, - expression_attribute_names: None, - keys: vec![], - projection_expression: None, - }), + unprocessed_keys: Some(crate::all::default_key_and_attributes()), } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } // NOTE: Same behavior with original SDK, but we're planning to improve this. // ref. https://github.com/raiden-rs/raiden/issues/44 #[test] fn test_batch_get_item_partial_missing() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchTest0); let res: batch_get::BatchGetOutput = client .batch_get(vec!["id100", "id101", "id102"]) .run() .await .unwrap(); + assert_eq!( sort_by_id_0(res), batch_get::BatchGetOutput { @@ -128,17 +106,12 @@ mod tests { name: "bob".to_owned(), },], consumed_capacity: None, - unprocessed_keys: Some(KeysAndAttributes { - attributes_to_get: None, - consistent_read: None, - expression_attribute_names: None, - keys: vec![], - projection_expression: None, - }), + unprocessed_keys: Some(crate::all::default_key_and_attributes()), } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, PartialEq)] @@ -164,13 +137,8 @@ mod tests { #[test] fn test_batch_get_item_sort_key() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchTest1::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchTest1); let keys: Vec<(String, usize)> = (0..250) .into_iter() .map(|n| (format!("id{n}"), (2000 + n) as usize)) @@ -185,22 +153,18 @@ mod tests { .collect(); let res: batch_get::BatchGetOutput = client.batch_get(keys).run().await.unwrap(); + assert_eq!( sort_by_id_1(res), batch_get::BatchGetOutput { items: expected_items, consumed_capacity: None, - unprocessed_keys: Some(KeysAndAttributes { - attributes_to_get: None, - consistent_read: None, - expression_attribute_names: None, - keys: vec![], - projection_expression: None, - }), + unprocessed_keys: Some(crate::all::default_key_and_attributes()), } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, PartialEq)] @@ -215,13 +179,8 @@ mod tests { #[test] fn test_batch_get_item_for_projection_expression() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchTest1a::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchTest1a); let keys: Vec<(String, usize)> = (0..250) .into_iter() .map(|n| (format!("id{n}"), (2000 + n) as usize)) @@ -233,7 +192,6 @@ mod tests { year: 2000 + n as usize, }) .collect(); - let mut res: batch_get::BatchGetOutput = client.batch_get(keys).run().await.unwrap(); res.items.sort_by_key(|i| { @@ -247,28 +205,18 @@ mod tests { batch_get::BatchGetOutput { items: expected_items, consumed_capacity: None, - unprocessed_keys: Some(KeysAndAttributes { - attributes_to_get: None, - consistent_read: None, - expression_attribute_names: None, - keys: vec![], - projection_expression: None, - }), + unprocessed_keys: Some(crate::all::default_key_and_attributes()), } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_batch_get_item_missing_all() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchTest1::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchTest1); let res: batch_get::BatchGetOutput = client .batch_get(vec![ ("id300", 2300_usize), @@ -278,22 +226,18 @@ mod tests { .run() .await .unwrap(); + assert_eq!( sort_by_id_1(res), batch_get::BatchGetOutput { items: vec![], consumed_capacity: None, - unprocessed_keys: Some(KeysAndAttributes { - attributes_to_get: None, - consistent_read: None, - expression_attribute_names: None, - keys: vec![], - projection_expression: None, - }), + unprocessed_keys: Some(crate::all::default_key_and_attributes()), } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -304,13 +248,8 @@ mod tests { } #[test] fn test_batch_get_item_with_16mb_limitation() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = BatchTest2::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(BatchTest2); let res: batch_get::BatchGetOutput = client .batch_get(vec![ "id0", "id1", "id2", "id3", "id4", "id5", "id6", "id7", "id8", "id9", "id10", @@ -324,6 +263,7 @@ mod tests { .unwrap(); assert_eq!(res.items.len(), 51); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/condition.rs b/raiden/tests/all/condition.rs index d945b24d..caef5c42 100644 --- a/raiden/tests/all/condition.rs +++ b/raiden/tests/all/condition.rs @@ -23,7 +23,7 @@ mod tests { let mut expected_names: std::collections::HashMap = std::collections::HashMap::new(); expected_names.insert("#name".to_owned(), "name".to_owned()); - assert_eq!(condition_expression, "attribute_exists(#name)".to_owned(),); + assert_eq!(condition_expression, "attribute_exists(#name)".to_owned()); assert_eq!(attribute_names, expected_names); } @@ -80,13 +80,8 @@ mod tests { std::collections::HashMap::new(); expected_names.insert("#id".to_owned(), "id".to_owned()); let mut expected_values: raiden::AttributeValues = std::collections::HashMap::new(); - expected_values.insert( - ":typeS".to_owned(), - raiden::AttributeValue { - s: Some("S".to_string()), - ..raiden::AttributeValue::default() - }, - ); + let attr_value: raiden::AttributeValue = "S".into_attr(); + expected_values.insert(":typeS".to_owned(), attr_value); assert_eq!( condition_expression, @@ -103,12 +98,10 @@ mod tests { let mut expected_names: raiden::AttributeNames = std::collections::HashMap::new(); expected_names.insert("#name".to_owned(), "name".to_owned()); let mut expected_values: raiden::AttributeValues = std::collections::HashMap::new(); + let attr_value: raiden::AttributeValue = "boku".into_attr(); expected_values.insert( ":begins_with_17d8e2e8233d9a6ae428061cb2cdf226".to_owned(), - raiden::AttributeValue { - s: Some("boku".to_string()), - ..raiden::AttributeValue::default() - }, + attr_value, ); assert_eq!( @@ -202,7 +195,7 @@ mod tests { let mut expected_names: std::collections::HashMap = std::collections::HashMap::new(); expected_names.insert("#name".to_owned(), "name".to_owned()); - assert_eq!(condition_expression, "#name = #name".to_owned(),); + assert_eq!(condition_expression, "#name = #name".to_owned()); assert_eq!(attribute_names, expected_names); } @@ -215,14 +208,10 @@ mod tests { std::collections::HashMap::new(); expected_names.insert("#name".to_owned(), "name".to_owned()); let mut expected_values: raiden::AttributeValues = std::collections::HashMap::new(); - expected_values.insert( - ":value0".to_owned(), - raiden::AttributeValue { - s: Some("bokuweb".to_string()), - ..raiden::AttributeValue::default() - }, - ); - assert_eq!(condition_expression, ":value0 = #name".to_owned(),); + let attr_value: raiden::AttributeValue = "bokuweb".into_attr(); + expected_values.insert(":value0".to_owned(), attr_value); + + assert_eq!(condition_expression, ":value0 = #name".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } diff --git a/raiden/tests/all/delete.rs b/raiden/tests/all/delete.rs index bc3c46e7..8af25539 100644 --- a/raiden/tests/all/delete.rs +++ b/raiden/tests/all/delete.rs @@ -16,42 +16,32 @@ mod tests { #[test] fn test_delete_item() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = DeleteTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(DeleteTest0); let res = client.delete("id0").run().await; + assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_delete_item_with_unstored_key() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = DeleteTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(DeleteTest0); let res = client.delete("unstored").run().await; + assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_delete_item_with_condition() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = DeleteTest0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(DeleteTest0); let cond = DeleteTest0::condition() .attr(DeleteTest0::removable()) .eq_value(true); @@ -60,7 +50,8 @@ mod tests { let res = client.delete("id1").condition(cond).run().await; assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[allow(dead_code)] @@ -75,16 +66,13 @@ mod tests { #[test] fn test_delete_item_with_sort_key() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = DeleteTest1::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(DeleteTest1); let res = client.delete("id0", 1999_usize).run().await; + assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/filter_expression.rs b/raiden/tests/all/filter_expression.rs index 3f11a290..3cb1dc75 100644 --- a/raiden/tests/all/filter_expression.rs +++ b/raiden/tests/all/filter_expression.rs @@ -30,7 +30,7 @@ mod tests { let mut expected_values: std::collections::HashMap = std::collections::HashMap::new(); expected_values.insert(":value0".to_owned(), "bokuweb".into_attr()); - assert_eq!(filter_expression, "#name = :value0".to_owned(),); + assert_eq!(filter_expression, "#name = :value0".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } @@ -46,7 +46,7 @@ mod tests { let mut expected_values: std::collections::HashMap = std::collections::HashMap::new(); expected_values.insert(":value0".to_owned(), 7.into_attr()); - assert_eq!(filter_expression, "size(#name) = :value0".to_owned(),); + assert_eq!(filter_expression, "size(#name) = :value0".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } @@ -63,7 +63,7 @@ mod tests { std::collections::HashMap::new(); expected_values.insert(":value0".to_owned(), "raiden".into_attr()); - assert_eq!(filter_expression, "#name <> :value0".to_owned(),); + assert_eq!(filter_expression, "#name <> :value0".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } @@ -158,7 +158,7 @@ mod tests { let mut expected_values: std::collections::HashMap = std::collections::HashMap::new(); expected_values.insert(":value0".to_owned(), "bokuweb".into_attr()); - assert_eq!(filter_expression, "begins_with(#name, :value0)".to_owned(),); + assert_eq!(filter_expression, "begins_with(#name, :value0)".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } @@ -188,7 +188,7 @@ mod tests { expected_names.insert("#name".to_owned(), "name".to_owned()); let expected_values: std::collections::HashMap = std::collections::HashMap::new(); - assert_eq!(filter_expression, "attribute_exists(#name)".to_owned(),); + assert_eq!(filter_expression, "attribute_exists(#name)".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } @@ -204,7 +204,7 @@ mod tests { expected_names.insert("#name".to_owned(), "name".to_owned()); let expected_values: std::collections::HashMap = std::collections::HashMap::new(); - assert_eq!(filter_expression, "attribute_not_exists(#name)".to_owned(),); + assert_eq!(filter_expression, "attribute_not_exists(#name)".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } @@ -241,7 +241,7 @@ mod tests { let mut expected_values: std::collections::HashMap = std::collections::HashMap::new(); expected_values.insert(":value0".to_owned(), "boku".into_attr()); - assert_eq!(filter_expression, "contains(#name, :value0)".to_owned(),); + assert_eq!(filter_expression, "contains(#name, :value0)".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } diff --git a/raiden/tests/all/get.rs b/raiden/tests/all/get.rs index 7b60dfc6..673c55c8 100644 --- a/raiden/tests/all/get.rs +++ b/raiden/tests/all/get.rs @@ -21,14 +21,10 @@ mod tests { #[test] fn test_user_get_item() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(User); let res = client.get("user_primary_key").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -45,18 +41,16 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_user_get_item_with_consistent_read() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserClient::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client!(UserClient); let res = client.get("user_primary_key").consistent().run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -73,18 +67,16 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_user_get_item_with_not_found_error() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserClient::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client!(UserClient); let res = client.get("not_exist_key").consistent().run().await; + assert!(res.is_err()); if let RaidenError::ResourceNotFound(msg) = res.unwrap_err() { @@ -93,7 +85,8 @@ mod tests { panic!("err should be RaidenError::ResourceNotFound"); } } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -108,13 +101,10 @@ mod tests { #[test] fn test_get_unstored_value() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserWithUnStored::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserWithUnStored); let res = client.get("user_primary_key").consistent().run().await; + assert!(res.is_err()); if let RaidenError::AttributeConvertError { attr_name } = res.unwrap_err() { @@ -123,7 +113,8 @@ mod tests { panic!("err should be RaidenError::AttributeConvertError"); } } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -138,13 +129,10 @@ mod tests { #[test] fn test_get_empty_hashset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserWithEmptyHashSet::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserWithEmptyHashSet); let res = client.get("user_primary_key").consistent().run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -157,7 +145,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -172,13 +161,10 @@ mod tests { #[test] fn test_get_empty_vec() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserWithEmptyVec::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserWithEmptyVec); let res = client.get("user_primary_key").consistent().run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -191,7 +177,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -206,15 +193,12 @@ mod tests { #[test] fn test_get_stringset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserWithStringSet::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserWithStringSet); let res = client.get("user_primary_key").consistent().run().await; let mut set = std::collections::HashSet::new(); set.insert("Hello".to_owned()); + assert_eq!( res.unwrap(), get::GetOutput { @@ -227,7 +211,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -242,15 +227,12 @@ mod tests { #[test] fn test_get_btree_stringset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserWithStringBTreeSet::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserWithStringBTreeSet); let res = client.get("user_primary_key").consistent().run().await; let mut set = std::collections::BTreeSet::new(); set.insert("Hello".to_owned()); + assert_eq!( res.unwrap(), get::GetOutput { @@ -263,7 +245,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Debug, Clone, PartialEq, Eq, Hash)] @@ -293,15 +276,12 @@ mod tests { #[test] fn test_get_custom_stringset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserWithCustomStringSet::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserWithCustomStringSet); let res = client.get("user_primary_key").consistent().run().await; let mut set = std::collections::HashSet::new(); set.insert(CustomSSItem("Hello".to_owned())); + assert_eq!( res.unwrap(), get::GetOutput { @@ -314,7 +294,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, PartialEq)] @@ -330,14 +311,10 @@ mod tests { #[test] fn test_user_get_item_with_sort_key() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserWithSortKey::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(UserWithSortKey); let res = client.get("id1", 2003_usize).run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -351,7 +328,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -364,14 +342,10 @@ mod tests { #[test] fn test_get_empty_string() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = EmptyStringTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(EmptyStringTestData0); let res = client.get("id0").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -383,7 +357,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -395,24 +370,25 @@ mod tests { flag: bool, } - #[tokio::test] - async fn test_use_default_for_null() { - let client = UseDefaultForNull::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - - let res = client.get("id0").run().await; - assert_eq!( - res.unwrap(), - get::GetOutput { - item: UseDefaultForNull { - id: "id0".to_owned(), - flag: false, - }, - consumed_capacity: None, - } - ); + #[test] + fn test_use_default_for_null() { + async fn example() { + let client = crate::all::create_client_from_struct!(UseDefaultForNull); + let res = client.get("id0").run().await; + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: UseDefaultForNull { + id: "id0".to_owned(), + flag: false, + }, + consumed_capacity: None, + } + ); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } use std::sync::atomic::{AtomicUsize, Ordering}; @@ -433,35 +409,29 @@ mod tests { #[test] fn test_retry() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let _ = client .with_retries(Box::new(MyRetryStrategy)) .get("anonymous") .run() .await; } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); assert_eq!(RETRY_COUNT.load(Ordering::Relaxed), 4) } #[test] fn test_should_build_with_twice_retry() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }) - .with_retries(Box::new(MyRetryStrategy)); + let client = crate::all::create_client_from_struct!(User) + .with_retries(Box::new(MyRetryStrategy)); let _ = client.get("anonymous").run().await; let _ = client.get("anonymous").run().await; } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -476,14 +446,10 @@ mod tests { #[test] fn test_user_get_item_for_projection_expression() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = PartialUser::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(PartialUser); let res = client.get("user_primary_key").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -496,7 +462,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -511,13 +478,10 @@ mod tests { #[test] fn test_reserved_keyword() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Reserved::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Reserved); let res = client.get("id0").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -529,7 +493,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -544,13 +509,10 @@ mod tests { #[test] fn test_rename_with_reserved() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = ReservedWithRename::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(ReservedWithRename); let res = client.get("id0").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -562,7 +524,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -577,13 +540,10 @@ mod tests { #[test] fn test_use_default() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UseDefault::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UseDefault); let res = client.get("id0").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -595,7 +555,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -610,13 +571,10 @@ mod tests { #[test] fn test_float() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = FloatTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(FloatTest); let res = client.get("primary_key").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -629,6 +587,7 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/key_condition.rs b/raiden/tests/all/key_condition.rs index c86a119f..d3a0e054 100644 --- a/raiden/tests/all/key_condition.rs +++ b/raiden/tests/all/key_condition.rs @@ -30,7 +30,7 @@ mod tests { let mut expected_values: std::collections::HashMap = std::collections::HashMap::new(); expected_values.insert(":value0".to_owned(), "bokuweb".into_attr()); - assert_eq!(key_condition, "#name = :value0".to_owned(),); + assert_eq!(key_condition, "#name = :value0".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } @@ -77,7 +77,7 @@ mod tests { let mut expected_values: std::collections::HashMap = std::collections::HashMap::new(); expected_values.insert(":value0".to_owned(), "bokuweb".into_attr()); - assert_eq!(key_condition, "begins_with(#name, :value0)".to_owned(),); + assert_eq!(key_condition, "begins_with(#name, :value0)".to_owned()); assert_eq!(attribute_names, expected_names); assert_eq!(attribute_values, expected_values); } diff --git a/raiden/tests/all/mod.rs b/raiden/tests/all/mod.rs index ebc4839f..1f9c4b0f 100644 --- a/raiden/tests/all/mod.rs +++ b/raiden/tests/all/mod.rs @@ -12,3 +12,77 @@ mod rename_all; mod scan; mod transact_write; mod update; + +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +macro_rules! create_client { + ($ty: ty) => { + <$ty>::new(raiden::Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }) + }; +} + +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +macro_rules! create_client_from_struct { + ($ty: ty) => { + <$ty>::client(raiden::Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }) + }; +} + +#[cfg(feature = "aws-sdk")] +macro_rules! create_client { + ($ty: ty) => {{ + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + <$ty>::new_with_client(sdk_client) + }}; +} + +#[cfg(feature = "aws-sdk")] +macro_rules! create_client_from_struct { + ($ty: ty) => {{ + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + <$ty>::client_with(sdk_client) + }}; +} + +use {create_client, create_client_from_struct}; + +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +fn default_key_and_attributes() -> raiden::KeysAndAttributes { + raiden::KeysAndAttributes { + attributes_to_get: None, + consistent_read: None, + expression_attribute_names: None, + keys: vec![], + projection_expression: None, + } +} + +#[cfg(feature = "aws-sdk")] +fn default_key_and_attributes() -> raiden::KeysAndAttributes { + raiden::KeysAndAttributes::builder().build() +} diff --git a/raiden/tests/all/put.rs b/raiden/tests/all/put.rs index 790c771f..956464f0 100644 --- a/raiden/tests/all/put.rs +++ b/raiden/tests/all/put.rs @@ -28,82 +28,79 @@ mod tests { #[test] fn test_put_user_with_attribute_not_exists_condition_input() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let user = UserPutItemInput { id: "mock_id".to_owned(), name: "bokuweb".to_owned(), }; let cond = User::condition().attr_not_exists(User::name()); + + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] let input = client.put(user).condition(cond).input; + #[cfg(feature = "aws-sdk")] + let input = client.put(user).condition(cond).builder.build().unwrap(); + let mut attribute_names: std::collections::HashMap = std::collections::HashMap::new(); let mut item: std::collections::HashMap = std::collections::HashMap::new(); - item.insert( - "name".to_owned(), - raiden::AttributeValue { - s: Some("bokuweb".to_owned()), - ..raiden::AttributeValue::default() - }, - ); - item.insert( - "id".to_owned(), - raiden::AttributeValue { - s: Some("mock_id".to_owned()), - ..raiden::AttributeValue::default() - }, - ); + let attr_value: raiden::AttributeValue = "bokuweb".into_attr(); + item.insert("name".to_owned(), attr_value); + let attr_value: raiden::AttributeValue = "mock_id".into_attr(); + item.insert("id".to_owned(), attr_value); + attribute_names.insert("#name".to_owned(), "name".to_owned()); - assert_eq!( - input, - ::raiden::PutItemInput { - condition_expression: Some("attribute_not_exists(#name)".to_owned()), - expression_attribute_names: Some(attribute_names), - expression_attribute_values: None, - item, - table_name: "user".to_owned(), - ..::raiden::PutItemInput::default() - }, - ); + + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] + let expected = ::raiden::PutItemInput { + condition_expression: Some("attribute_not_exists(#name)".to_owned()), + expression_attribute_names: Some(attribute_names), + expression_attribute_values: None, + item, + table_name: "user".to_owned(), + ..::raiden::PutItemInput::default() + }; + + #[cfg(feature = "aws-sdk")] + let expected = ::raiden::PutItemInput::builder() + .condition_expression("attribute_not_exists(#name)") + .set_expression_attribute_names(Some(attribute_names)) + .set_item(Some(item)) + .table_name("user") + .build() + .unwrap(); + + assert_eq!(input, expected); } #[test] fn test_put_user() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let user = UserPutItemInput { id: "mock_id".to_owned(), name: "bokuweb".to_owned(), }; let _res = client.put(user).run().await; } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_put_user_with_builder() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let user = User::put_item_builder() .id("mock_id".to_owned()) .name("bokuweb".to_owned()) .build(); let _res = client.put(user).run().await; } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone)] @@ -116,12 +113,8 @@ mod tests { #[test] fn test_put_user_eq_op_condition_expression() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let user = UserPutItemInput { id: "id0".to_owned(), name: "bokuweb".to_owned(), @@ -130,18 +123,15 @@ mod tests { let res = client.put(user).condition(cond).run().await; assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] #[allow(dead_code)] fn test_put_user_eq_op_condition_expression_with_not_exist_name() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let user = UserPutItemInput { id: "id0".to_owned(), name: "bokuweb".to_owned(), @@ -151,23 +141,20 @@ mod tests { assert!(res.is_err()); if let RaidenError::ConditionalCheckFailed(msg) = res.unwrap_err() { - assert_eq!("The conditional request failed", msg); + assert!(msg.contains("The conditional request failed")); } else { panic!("err should be RaidenError::ConditionalCheckFailed"); } } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] #[allow(dead_code)] fn test_put_user_id_not_exists_expression() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let user = UserPutItemInput { id: "id0".to_owned(), name: "bokuweb".to_owned(), @@ -177,23 +164,20 @@ mod tests { assert!(res.is_err()); if let RaidenError::ConditionalCheckFailed(msg) = res.unwrap_err() { - assert_eq!("The conditional request failed", msg); + assert!(msg.contains("The conditional request failed")); } else { panic!("err should be RaidenError::ConditionalCheckFailed"); } } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] #[allow(dead_code)] fn test_put_user_id_exists_expression() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let user = UserPutItemInput { id: "id0".to_owned(), name: "bokuweb".to_owned(), @@ -202,25 +186,23 @@ mod tests { let res = client.put(user).condition(cond).run().await; assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] #[allow(dead_code)] fn test_put_user_with_uuid() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserWithUuid::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserWithUuid); let item = UserWithUuid::put_item_builder() .name("bokuweb".to_owned()) .build(); let res = client.put(item).run().await; assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -237,12 +219,8 @@ mod tests { #[test] fn test_put_user_with_number_vec() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserVecTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserVecTest); let item = UserVecTest::put_item_builder() .name("bokuweb".to_owned()) .nums(vec![0, 1, 2]) @@ -250,7 +228,8 @@ mod tests { let res = client.put(item).run().await; assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -267,12 +246,8 @@ mod tests { #[test] fn test_put_user_with_number_set() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserSetTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserSetTest); let mut nums: std::collections::HashSet = std::collections::HashSet::new(); nums.insert(1); @@ -283,7 +258,8 @@ mod tests { let res = client.put(item).run().await; assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Debug, Clone, Hash, PartialEq, Eq)] @@ -315,12 +291,8 @@ mod tests { #[test] fn test_put_user_with_user_defined_set() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserSetTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserSetTest); let mut nums: std::collections::HashSet = std::collections::HashSet::new(); nums.insert(1); @@ -331,7 +303,8 @@ mod tests { let res = client.put(item).run().await; assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -347,19 +320,16 @@ mod tests { #[test] fn test_put_user_with_empty_set() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserEmptySetTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserEmptySetTest); let set: std::collections::HashSet = std::collections::HashSet::new(); - let item = UserEmptySetTest::put_item_builder().set(set).build(); let res = client.put(item).run().await; + assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone)] @@ -373,19 +343,16 @@ mod tests { #[test] fn test_put_with_empty_string() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = EmptyStringTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(EmptyStringTestData0); let item = EmptyStringTestData0::put_item_builder() .name("".to_owned()) .build(); let res = client.put(item).run().await; assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -398,12 +365,8 @@ mod tests { #[test] fn test_put_with_empty_sset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = EmptyPutTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(EmptyPutTestData0); let set: std::collections::HashSet = std::collections::HashSet::new(); let expected_set: std::collections::HashSet = std::collections::HashSet::new(); let item = EmptyPutTestData0::put_item_builder() @@ -421,6 +384,7 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/query.rs b/raiden/tests/all/query.rs index f81aea72..70648b12 100644 --- a/raiden/tests/all/query.rs +++ b/raiden/tests/all/query.rs @@ -17,12 +17,8 @@ mod tests { #[test] fn test_query() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(QueryTestData0); let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id0"); let res = client.query().key_condition(cond).run().await; @@ -52,17 +48,14 @@ mod tests { } ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_query_with_and_key_condition() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(QueryTestData0); let cond = QueryTestData0::key_condition(QueryTestData0::id()) .eq("id0") .and(QueryTestData0::key_condition(QueryTestData0::year()).eq(1999)); @@ -85,158 +78,168 @@ mod tests { } ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_query_with_simple_filter() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id3"); - let filter = QueryTestData0::filter_expression(QueryTestData0::num()).eq(4000); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 3); + #[test] + fn test_query_with_simple_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id3"); + let filter = QueryTestData0::filter_expression(QueryTestData0::num()).eq(4000); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 3); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_query_with_size_filter() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id5"); - let filter = QueryTestData0::filter_expression(QueryTestData0::name()) - .size() - .ge(4); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); + #[test] + fn test_query_with_size_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id5"); + let filter = QueryTestData0::filter_expression(QueryTestData0::name()) + .size() + .ge(4); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_query_with_or_filter() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id3"); - let filter = QueryTestData0::filter_expression(QueryTestData0::name()) - .eq("bar0") - .or(QueryTestData0::filter_expression(QueryTestData0::name()).eq("bar1")); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); + #[test] + fn test_query_with_or_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id3"); + let filter = QueryTestData0::filter_expression(QueryTestData0::name()) + .eq("bar0") + .or(QueryTestData0::filter_expression(QueryTestData0::name()).eq("bar1")); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_query_with_attribute_exists_filter() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = QueryTestData0::filter_expression(QueryTestData0::option()).attribute_exists(); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); + #[test] + fn test_query_with_attribute_exists_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = + QueryTestData0::filter_expression(QueryTestData0::option()).attribute_exists(); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_query_with_attribute_not_exists_filter() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = - QueryTestData0::filter_expression(QueryTestData0::option()).attribute_not_exists(); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 1); + #[test] + fn test_query_with_attribute_not_exists_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = + QueryTestData0::filter_expression(QueryTestData0::option()).attribute_not_exists(); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 1); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_query_with_attribute_type_filter() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = QueryTestData0::filter_expression(QueryTestData0::option()) - .attribute_type(raiden::AttributeType::S); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); + #[test] + fn test_query_with_attribute_type_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = QueryTestData0::filter_expression(QueryTestData0::option()) + .attribute_type(raiden::AttributeType::S); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_query_with_contains_filter() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = QueryTestData0::filter_expression(QueryTestData0::name()).contains("bar"); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); + #[test] + fn test_query_with_contains_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = QueryTestData0::filter_expression(QueryTestData0::name()).contains("bar"); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_query_in_filter() { - let client = QueryTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = - QueryTestData0::filter_expression(QueryTestData0::name()).r#in(vec!["bar0", "bar1"]); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); + #[test] + fn test_query_in_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = QueryTestData0::filter_expression(QueryTestData0::name()) + .r#in(vec!["bar0", "bar1"]); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -251,12 +254,8 @@ mod tests { #[test] fn test_query_limit_1() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Test); let cond = Test::key_condition(Test::ref_id()).eq("id0"); let res = client .query() @@ -267,17 +266,14 @@ mod tests { .await; assert_eq!(res.unwrap().items.len(), 1); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_query_limit_5() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Test); let cond = Test::key_condition(Test::ref_id()).eq("id0"); let res = client .query() @@ -288,17 +284,14 @@ mod tests { .await; assert_eq!(res.unwrap().items.len(), 5); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_query_no_limit() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Test); let cond = Test::key_condition(Test::ref_id()).eq("id0"); let res = client .query() @@ -308,17 +301,14 @@ mod tests { .await; assert_eq!(res.unwrap().items.len(), 10); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_query_over_limit() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Test); let cond = Test::key_condition(Test::ref_id()).eq("id0"); let res = client .query() @@ -329,17 +319,14 @@ mod tests { .await; assert_eq!(res.unwrap().items.len(), 10); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_query_over_limit_with_next_token() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Test); let cond = Test::key_condition(Test::ref_id()).eq("id0"); let res = client .query() @@ -363,7 +350,8 @@ mod tests { .unwrap(); assert_eq!(res.items.len(), 1); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -379,12 +367,8 @@ mod tests { #[test] fn test_query_with_renamed() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Project::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Project); let cond = Project::key_condition(Project::org_id()).eq("myOrg"); let res = client .query() @@ -395,7 +379,8 @@ mod tests { .await; assert_eq!(res.unwrap().items.len(), 10); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, PartialEq)] @@ -408,12 +393,8 @@ mod tests { } #[test] fn test_query_for_projection_expression() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = QueryTestData0a::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(QueryTestData0a); let cond = QueryTestData0a::key_condition(QueryTestData0a::id()).eq("id0"); let res = client.query().key_condition(cond).run().await; @@ -439,7 +420,8 @@ mod tests { } ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, PartialEq)] @@ -453,12 +435,8 @@ mod tests { #[test] fn test_query_with_begins_with_key_condition() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = QueryTestData1::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(QueryTestData1); let cond = QueryTestData1::key_condition(QueryTestData1::id()) .eq("id0") .and(QueryTestData1::key_condition(QueryTestData1::name()).begins_with("j")); @@ -484,7 +462,8 @@ mod tests { } ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, PartialEq)] @@ -498,12 +477,8 @@ mod tests { #[test] fn should_be_obtainable_when_the_size_is_1mb_or_larger() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = QueryLargeDataTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(QueryLargeDataTest); let cond = QueryLargeDataTest::key_condition(QueryLargeDataTest::ref_id()).eq("ref"); let res = client .query() @@ -514,17 +489,14 @@ mod tests { assert_eq!(res.unwrap().items.len(), 100) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn should_be_obtainable_specified_limit_items_when_the_size_is_1mb_or_larger() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = QueryLargeDataTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(QueryLargeDataTest); let cond = QueryLargeDataTest::key_condition(QueryLargeDataTest::ref_id()).eq("ref"); let res = client .query() @@ -551,6 +523,7 @@ mod tests { assert_eq!(res.items.len(), 60); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/rename.rs b/raiden/tests/all/rename.rs index 20b6ae8a..207900b0 100644 --- a/raiden/tests/all/rename.rs +++ b/raiden/tests/all/rename.rs @@ -30,14 +30,10 @@ mod tests { #[test] fn test_rename_get_item() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = RenameTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(RenameTest); let res = client.get("id0").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -54,19 +50,16 @@ mod tests { "renamed".to_owned() ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_rename_key_get_item() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = RenameKeyTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(RenameKeyTest); let res = client.get("id0").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -79,18 +72,14 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_rename_query() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = RenameTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(RenameTest); let cond = RenameTest::key_condition(RenameTest::id()).eq("id0"); let res = client.query().key_condition(cond).run().await; @@ -109,6 +98,7 @@ mod tests { } ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/rename_all.rs b/raiden/tests/all/rename_all.rs index 5b2b034d..824ac16a 100644 --- a/raiden/tests/all/rename_all.rs +++ b/raiden/tests/all/rename_all.rs @@ -18,14 +18,10 @@ mod tests { #[test] fn test_rename_all_camelcase_get() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = RenameAllCamelCaseTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(RenameAllCamelCaseTest); let res = client.get("id0").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -38,7 +34,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -54,14 +51,10 @@ mod tests { #[test] fn test_rename_all_pascalcase_get() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = RenameAllPascalCaseTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(RenameAllPascalCaseTest); let res = client.get("id0").run().await; + assert_eq!( res.unwrap(), get::GetOutput { @@ -74,6 +67,7 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/scan.rs b/raiden/tests/all/scan.rs index 6582aed6..fc9d0a0a 100644 --- a/raiden/tests/all/scan.rs +++ b/raiden/tests/all/scan.rs @@ -16,12 +16,8 @@ mod tests { #[test] fn test_scan() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = ScanTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(ScanTestData0); let res = client.scan().run().await; assert_eq!( @@ -40,7 +36,8 @@ mod tests { } ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -55,58 +52,50 @@ mod tests { #[test] fn test_scan_limit_1() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Test); let res = client.scan().limit(1).run().await; + assert_eq!(res.unwrap().items.len(), 1); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_scan_limit_5() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Test); let res = client.scan().limit(5).run().await; + assert_eq!(res.unwrap().items.len(), 5); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_scan_no_limit() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Test); let res = client.scan().run().await; + assert_eq!(res.unwrap().items.len(), 10); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_scan_over_limit() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Test::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Test); let res = client.scan().limit(11).run().await; + assert_eq!(res.unwrap().items.len(), 10); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -122,16 +111,14 @@ mod tests { #[test] fn test_scan_with_renamed() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = Project::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(Project); let res = client.scan().limit(11).run().await; + assert_eq!(res.unwrap().items.len(), 10); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, PartialEq)] @@ -144,12 +131,8 @@ mod tests { #[test] fn test_scan_for_projection_expression() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = ScanTestData0a::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(ScanTestData0a); let res = client.scan().run().await; assert_eq!( @@ -166,7 +149,8 @@ mod tests { } ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, PartialEq)] @@ -180,16 +164,14 @@ mod tests { #[test] fn should_be_scan_when_the_size_is_1mb_or_larger() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = ScanLargeDataTest::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(ScanLargeDataTest); let res = client.scan().run().await; + assert_eq!(res.unwrap().items.len(), 100) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug)] @@ -204,72 +186,84 @@ mod tests { option: Option, } - #[tokio::test] - async fn test_simple_filter() { - let client = Scan::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let filter = Scan::filter_expression(Scan::num()).eq(1000); - let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 50); + #[test] + fn test_simple_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::num()).eq(1000); + let res = client.scan().filter(filter).run().await.unwrap(); + + assert_eq!(res.items.len(), 50); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_size_filter() { - let client = Scan::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let filter = Scan::filter_expression(Scan::name()).size().eq(10); - let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 10); + #[test] + fn test_size_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::name()).size().eq(10); + let res = client.scan().filter(filter).run().await.unwrap(); + + assert_eq!(res.items.len(), 10); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_or_with_contain_filter() { - let client = Scan::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let filter = Scan::filter_expression(Scan::num()) - .eq(1000) - .or(Scan::filter_expression(Scan::id()).contains("scanId50")); - let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 51); + #[test] + fn test_or_with_contain_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::num()) + .eq(1000) + .or(Scan::filter_expression(Scan::id()).contains("scanId50")); + let res = client.scan().filter(filter).run().await.unwrap(); + + assert_eq!(res.items.len(), 51); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_attribute_exists_filter() { - let client = Scan::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let filter = Scan::filter_expression(Scan::option()).attribute_exists(); - let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 50); + #[test] + fn test_attribute_exists_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::option()).attribute_exists(); + let res = client.scan().filter(filter).run().await.unwrap(); + + assert_eq!(res.items.len(), 50); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_attribute_not_exists_filter() { - let client = Scan::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let filter = Scan::filter_expression(Scan::option()).attribute_not_exists(); - let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 50); + #[test] + fn test_attribute_not_exists_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::option()).attribute_not_exists(); + let res = client.scan().filter(filter).run().await.unwrap(); + + assert_eq!(res.items.len(), 50); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn test_attribute_type_filter() { - let client = Scan::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - let filter = - Scan::filter_expression(Scan::option()).attribute_type(raiden::AttributeType::S); - let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 50); + #[test] + fn test_attribute_type_filter() { + async fn example() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = + Scan::filter_expression(Scan::option()).attribute_type(raiden::AttributeType::S); + let res = client.scan().filter(filter).run().await.unwrap(); + + assert_eq!(res.items.len(), 50); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/transact_write.rs b/raiden/tests/all/transact_write.rs index bb5fe7a7..4216e288 100644 --- a/raiden/tests/all/transact_write.rs +++ b/raiden/tests/all/transact_write.rs @@ -1,5 +1,28 @@ #[cfg(test)] mod tests { + #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] + fn create_client() -> ::raiden::WriteTx { + ::raiden::WriteTx::new(Region::Custom { + endpoint: "http://localhost:8000".into(), + name: "ap-northeast-1".into(), + }) + } + + #[cfg(feature = "aws-sdk")] + fn create_client() -> ::raiden::WriteTx { + let sdk_config = aws_config::SdkConfig::builder() + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) + .credentials_provider( + aws_credential_types::provider::SharedCredentialsProvider::new( + aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), + ), + ) + .build(); + let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + + ::raiden::WriteTx::new_with_client(sdk_client) + } #[cfg(test)] use pretty_assertions::assert_eq; @@ -17,12 +40,8 @@ mod tests { #[test] fn test_minimum_transact_write() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let tx = ::raiden::WriteTx::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let tx = create_client(); let cond = User::condition().attr_not_exists(User::id()); let input = User::put_item_builder() .id("testId".to_owned()) @@ -32,6 +51,7 @@ mod tests { .id("testId2".to_owned()) .name("bokuweb".to_owned()) .build(); + assert_eq!( tx.put(User::put(input).condition(cond)) .put(User::put(input2)) @@ -41,17 +61,14 @@ mod tests { true, ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_transact_write_put_and_update() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let tx = ::raiden::WriteTx::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let tx = create_client(); let input = User::put_item_builder() .id("testId".to_owned()) .name("bokuweb".to_owned()) @@ -59,29 +76,27 @@ mod tests { let set_expression = User::update_expression() .set(User::name()) .value("updated!!"); - let res = tx .put(User::put(input)) .update(User::update("testId2").set(set_expression)) .run() .await; + assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_transact_write_with_prefix_suffix() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let tx = ::raiden::WriteTx::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let tx = create_client(); let input = User::put_item_builder() .id("testId".to_owned()) .name("bokuweb".to_owned()) .build(); + assert_eq!( tx.put( User::put(input) @@ -94,7 +109,8 @@ mod tests { true, ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } use std::sync::atomic::{AtomicUsize, Ordering}; @@ -115,16 +131,13 @@ mod tests { #[test] fn test_retry() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let tx = ::raiden::WriteTx::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let tx = create_client(); let input = User::put_item_builder() .id("testId".to_owned()) .name("bokuweb".to_owned()) .build(); + assert_eq!( tx.with_retries(Box::new(MyRetryStrategy)) .put(User::put(input).table_prefix("unknown")) @@ -134,7 +147,8 @@ mod tests { true, ) } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); assert_eq!(RETRY_COUNT.load(Ordering::Relaxed), 4) } @@ -147,16 +161,13 @@ mod tests { #[test] fn test_transact_delete_and_put() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let tx = ::raiden::WriteTx::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let tx = create_client(); let input = TxDeleteTestData0::put_item_builder() .id("testId".to_owned()) .name("bokuweb".to_owned()) .build(); + assert_eq!( tx.put(TxDeleteTestData0::put(input)) .delete(TxDeleteTestData0::delete("id0")) @@ -166,10 +177,7 @@ mod tests { true, ); - let client = TxDeleteTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(TxDeleteTestData0); let res = client.get("id0").run().await; assert!(res.is_err()); @@ -188,7 +196,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -207,12 +216,8 @@ mod tests { #[test] fn should_succeed_to_put_when_condition_check_ok() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let tx = ::raiden::WriteTx::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let tx = create_client(); let input = TxConditionalCheckTestData0::put_item_builder() .id("testId0".to_owned()) .name("bokuweb".to_owned()) @@ -230,10 +235,7 @@ mod tests { true, ); - let client = TxConditionalCheckTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(TxConditionalCheckTestData0); let res = client.get("testId0").run().await; assert_eq!( res.unwrap().item, @@ -243,17 +245,14 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn should_fail_to_put_when_condition_check_ng() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let tx = ::raiden::WriteTx::new(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let tx = create_client(); let input = TxConditionalCheckTestData0::put_item_builder() .id("testId1".to_owned()) .name("bokuweb".to_owned()) @@ -282,6 +281,7 @@ mod tests { panic!("err should be RaidenError::TransactionCanceled"); } } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } diff --git a/raiden/tests/all/update.rs b/raiden/tests/all/update.rs index 9b0f27b2..159f1c36 100644 --- a/raiden/tests/all/update.rs +++ b/raiden/tests/all/update.rs @@ -17,12 +17,8 @@ mod tests { #[test] fn test_update() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let set_name_expression = User::update_expression() .set(User::name()) .value("updated!!"); @@ -35,6 +31,7 @@ mod tests { .run() .await .unwrap(); + assert_eq!( res.item, Some(User { @@ -44,17 +41,14 @@ mod tests { }) ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_update_with_invalid_key_with_condition() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let cond = User::condition().attr_exists(User::id()); let set_expression = User::update_expression() .set(User::name()) @@ -66,9 +60,11 @@ mod tests { .set(set_expression) .run() .await; + assert_eq!(res.is_err(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -83,12 +79,8 @@ mod tests { #[test] fn test_update_with_unstored() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UserWithUnStored::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UserWithUnStored); let set_expression = UserWithUnStored::update_expression() .set(UserWithUnStored::name()) .value("updated!!"); @@ -98,9 +90,11 @@ mod tests { .run() .await .unwrap(); - assert_eq!(res.item, None,); + + assert_eq!(res.item, None); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -114,12 +108,8 @@ mod tests { #[test] fn test_update_with_sort_key() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UpdateTestData1::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UpdateTestData1); let set_expression = UpdateTestData1::update_expression() .set(UpdateTestData1::name()) .value("bob"); @@ -130,6 +120,7 @@ mod tests { .run() .await .unwrap(); + assert_eq!( res.item, Some(UpdateTestData1 { @@ -139,7 +130,8 @@ mod tests { }) ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -151,12 +143,8 @@ mod tests { #[test] fn test_update_with_only_attr() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = EmptySetTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(EmptySetTestData0); let set_expression = EmptySetTestData0::update_expression() .set(EmptySetTestData0::sset()) .attr(EmptySetTestData0::sset()); @@ -166,19 +154,17 @@ mod tests { .return_all_new() .run() .await; + assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_update_empty_set_sort_key() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = EmptySetTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(EmptySetTestData0); let sset: std::collections::HashSet = std::collections::HashSet::new(); let expected_sset: std::collections::HashSet = std::collections::HashSet::new(); let set_expression = EmptySetTestData0::update_expression() @@ -190,20 +176,18 @@ mod tests { .return_all_new() .run() .await; + assert!(res.is_ok()); assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_add_with_empty_hash_set() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = EmptySetTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(EmptySetTestData0); let sset: std::collections::HashSet = std::collections::HashSet::new(); let mut expected_sset: std::collections::HashSet = std::collections::HashSet::new(); @@ -217,10 +201,12 @@ mod tests { .return_all_new() .run() .await; + assert_eq!(res.is_ok(), true); assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -232,12 +218,8 @@ mod tests { #[test] fn test_update_delete_sset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UpdateDeleteTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UpdateDeleteTestData0); let mut delete_sset: std::collections::HashSet = std::collections::HashSet::new(); delete_sset.insert("foo".to_owned()); @@ -254,9 +236,11 @@ mod tests { .return_all_new() .run() .await; + assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -268,12 +252,8 @@ mod tests { #[test] fn test_update_add_sset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UpdateAddTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UpdateAddTestData0); let mut add_sset: std::collections::HashSet = std::collections::HashSet::new(); add_sset.insert("added".to_owned()); let add_expression = UpdateAddTestData0::update_expression() @@ -291,19 +271,17 @@ mod tests { .return_all_new() .run() .await; + assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_update_add_sset_to_empty() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UpdateAddTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UpdateAddTestData0); let mut add_sset: std::collections::HashSet = std::collections::HashSet::new(); add_sset.insert("added".to_owned()); let add_expression = UpdateAddTestData0::update_expression() @@ -319,19 +297,17 @@ mod tests { .return_all_new() .run() .await; + assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn test_update_to_empty_string() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(User); let set_name_expression = User::update_expression().set(User::name()).value(""); let res = client .update("id0") @@ -340,9 +316,11 @@ mod tests { .run() .await .unwrap(); - assert_eq!(res.item.unwrap().name, "".to_owned(),); + + assert_eq!(res.item.unwrap().name, "".to_owned()); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -354,18 +332,15 @@ mod tests { #[test] fn test_update_remove_sset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UpdateRemoveTestData0::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); + let client = crate::all::create_client_from_struct!(UpdateRemoveTestData0); let res = client .update("id1") .remove(UpdateRemoveTestData0::name()) .return_all_new() .run() .await; + assert_eq!( res.unwrap().item.unwrap(), UpdateRemoveTestData0 { @@ -380,6 +355,7 @@ mod tests { .return_all_new() .run() .await; + assert_eq!( res.unwrap().item.unwrap(), UpdateRemoveTestData0 { @@ -388,7 +364,8 @@ mod tests { } ); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -401,17 +378,11 @@ mod tests { #[test] fn should_update_with_contains_condition_in_sset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UpdateWithContainsInSetCondition::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); let set_expression = UpdateWithContainsInSetCondition::update_expression() .set(UpdateWithContainsInSetCondition::name()) .value("Changed"); - let cond = UpdateWithContainsInSetCondition::condition().contains( UpdateWithContainsInSetCondition::sset(), "Hello".to_string(), @@ -424,24 +395,20 @@ mod tests { .return_all_new() .run() .await; + assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn should_not_update_with_contains_condition_in_sset() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UpdateWithContainsInSetCondition::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); let set_expression = UpdateWithContainsInSetCondition::update_expression() .set(UpdateWithContainsInSetCondition::name()) .value("Changed"); - let cond = UpdateWithContainsInSetCondition::condition().contains( UpdateWithContainsInSetCondition::sset(), "World".to_string(), @@ -454,24 +421,20 @@ mod tests { .return_all_new() .run() .await; + assert_eq!(res.is_err(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn should_not_update_with_or_condition_failed() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UpdateWithContainsInSetCondition::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); let set_expression = UpdateWithContainsInSetCondition::update_expression() .set(UpdateWithContainsInSetCondition::name()) .value("Changed"); - let cond = UpdateWithContainsInSetCondition::condition() .contains( UpdateWithContainsInSetCondition::sset(), @@ -489,24 +452,20 @@ mod tests { .return_all_new() .run() .await; + assert_eq!(res.is_err(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[test] fn should_update_with_or_condition() { - let rt = tokio::runtime::Runtime::new().unwrap(); async fn example() { - let client = UpdateWithContainsInSetCondition::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - + let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); let set_expression = UpdateWithContainsInSetCondition::update_expression() .set(UpdateWithContainsInSetCondition::name()) .value("Changed"); - let cond = UpdateWithContainsInSetCondition::condition() .contains( UpdateWithContainsInSetCondition::sset(), @@ -524,71 +483,75 @@ mod tests { .return_all_new() .run() .await; + assert_eq!(res.is_ok(), true); } - rt.block_on(example()); + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn should_set_if_attr_not_exists() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - - let set_name_expression = User::update_expression() - .set(User::name()) - .value("updated") - .if_not_exists(); - let set_age_expression = User::update_expression().set(User::age()).value(12); - - let res = client - .update("if_not_exists#0") - .set(set_name_expression) - .set(set_age_expression) - .return_all_new() - .run() - .await - .unwrap(); - assert_eq!( - res.item, - Some(User { - id: "if_not_exists#0".into(), - name: "updated".into(), - age: 12 - }) - ); + #[test] + fn should_set_if_attr_not_exists() { + async fn example() { + let client = crate::all::create_client_from_struct!(User); + let set_name_expression = User::update_expression() + .set(User::name()) + .value("updated") + .if_not_exists(); + let set_age_expression = User::update_expression().set(User::age()).value(12); + + let res = client + .update("if_not_exists#0") + .set(set_name_expression) + .set(set_age_expression) + .return_all_new() + .run() + .await + .unwrap(); + + assert_eq!( + res.item, + Some(User { + id: "if_not_exists#0".into(), + name: "updated".into(), + age: 12 + }) + ); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[tokio::test] - async fn should_not_set_if_attr_exists() { - let client = User::client(Region::Custom { - endpoint: "http://localhost:8000".into(), - name: "ap-northeast-1".into(), - }); - - let set_name_expression = User::update_expression().set(User::name()).value("created"); - let set_age_expression = User::update_expression().set(User::age()).value(12); - - client - .update("if_not_exists#1") - .set(set_name_expression) - .set(set_age_expression) - .run() - .await - .unwrap(); - - let set_name_expression = User::update_expression() - .set(User::name()) - .value("updated") - .if_not_exists(); // update only if attribute not exists - let res = client - .update("if_not_exists#1") - .set(set_name_expression) - .return_all_new() - .run() - .await - .unwrap(); - assert_eq!(res.item.map(|u| u.name), Some("created".into())); + #[test] + fn should_not_set_if_attr_exists() { + async fn example() { + let client = crate::all::create_client_from_struct!(User); + + let set_name_expression = User::update_expression().set(User::name()).value("created"); + let set_age_expression = User::update_expression().set(User::age()).value(12); + + client + .update("if_not_exists#1") + .set(set_name_expression) + .set(set_age_expression) + .run() + .await + .unwrap(); + + let set_name_expression = User::update_expression() + .set(User::name()) + .value("updated") + .if_not_exists(); // update only if attribute not exists + let res = client + .update("if_not_exists#1") + .set(set_name_expression) + .return_all_new() + .run() + .await + .unwrap(); + assert_eq!(res.item.map(|u| u.name), Some("created".into())); + } + + tokio::runtime::Runtime::new().unwrap().block_on(example()); } } From 4801a64a9c141e036424542745cee780bf5b5b15 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Tue, 31 Oct 2023 23:15:38 +0900 Subject: [PATCH 05/22] fix: clippy warnings --- makefile | 4 ++-- raiden/Cargo.toml | 7 ++++-- raiden/src/aws_sdk/mod.rs | 4 ++-- raiden/src/aws_sdk/ops/batch_delete.rs | 6 ++--- raiden/src/aws_sdk/ops/batch_get.rs | 6 ++--- raiden/src/aws_sdk/ops/get.rs | 4 ++-- raiden/src/aws_sdk/ops/put.rs | 4 ++-- raiden/src/aws_sdk/ops/query.rs | 4 ++-- raiden/src/aws_sdk/ops/scan.rs | 6 ++--- raiden/src/aws_sdk/ops/update.rs | 7 +++--- .../src/aws_sdk/serialize/attribute_value.rs | 22 +++++++++---------- .../aws_sdk/serialize/consumed_capacity.rs | 2 +- raiden/src/rusoto/mod.rs | 2 +- 13 files changed, 40 insertions(+), 38 deletions(-) diff --git a/makefile b/makefile index 6400ff22..c62e76b0 100644 --- a/makefile +++ b/makefile @@ -16,7 +16,7 @@ test: lint: cargo clippy --all-targets -- -D warnings cargo clippy --all-targets --features tracing -- -D warnings - cargo clippy --all-targets --no-default-features --features rustls -- -D warnings + cargo clippy --all-targets --no-default-features --features rusoto_rustls -- -D warnings cargo clippy --all-targets --no-default-features --features aws-sdk -- -D warnings .PHONY: check-deps @@ -24,5 +24,5 @@ check-deps: cargo machete || echo cargo +nightly udeps --all-targets cargo +nightly udeps --all-targets --features tracing - cargo +nightly udeps --all-targets --no-default-features --features rustls + cargo +nightly udeps --all-targets --no-default-features --features rusoto_rustls cargo +nightly udeps --all-targets --no-default-features --features aws-sdk diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index 9859d8d6..47153293 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -14,13 +14,13 @@ aws-smithy-http = { version = "0.56.1", optional = true } aws-smithy-runtime-api = { version = "0.56.1", optional = true } aws-smithy-types = { version = "0.56.1", optional = true } base64 = "^0.21" -paste = "1.0.14" +paste = { version = "1.0.14", optional = true } raiden-derive = { version = "*", path = "../raiden-derive", default_features = false } rusoto_core_default = { package = "rusoto_core", version = "0.48", optional = true } rusoto_core_rustls = { package = "rusoto_core", version = "0.48", default_features = false, features = [ "rustls", ], optional = true } -rusoto_credential = "0.48" +rusoto_credential = { version = "0.48", optional = true } rusoto_dynamodb_default = { package = "rusoto_dynamodb", version = "0.48", features = [ "serialize_structs", ], optional = true } @@ -59,15 +59,18 @@ aws-sdk = [ "dep:aws-smithy-http", "dep:aws-smithy-runtime-api", "dep:aws-smithy-types", + "dep:paste", "raiden-derive/aws-sdk", ] rusoto = [ "dep:rusoto_core_default", + "dep:rusoto_credential", "dep:rusoto_dynamodb_default", "raiden-derive/rusoto", ] rusoto_rustls = [ "dep:rusoto_core_rustls", + "dep:rusoto_credential", "dep:rusoto_dynamodb_rustls", "raiden-derive/rusoto", ] diff --git a/raiden/src/aws_sdk/mod.rs b/raiden/src/aws_sdk/mod.rs index 544c7c76..0d6b510e 100644 --- a/raiden/src/aws_sdk/mod.rs +++ b/raiden/src/aws_sdk/mod.rs @@ -81,7 +81,7 @@ impl<'a> FromAttribute for std::borrow::Cow<'a, str> { fn from_attr(value: Option) -> Result { match value { Some(v) if v.is_null() => Ok(std::borrow::Cow::Owned("".to_owned())), - Some(AttributeValue::S(s)) => Ok(std::borrow::Cow::Owned(s.to_owned())), + Some(AttributeValue::S(s)) => Ok(std::borrow::Cow::Owned(s)), _ => Err(ConversionError::ValueIsNone), } } @@ -328,7 +328,7 @@ pub(crate) fn deserialize_attr_value(s: &str) -> Result String { let m: HashMap = value - .into_iter() + .iter() .map(|(k, v)| { ( k.to_owned(), diff --git a/raiden/src/aws_sdk/ops/batch_delete.rs b/raiden/src/aws_sdk/ops/batch_delete.rs index 4ca217eb..7638a0fb 100644 --- a/raiden/src/aws_sdk/ops/batch_delete.rs +++ b/raiden/src/aws_sdk/ops/batch_delete.rs @@ -13,7 +13,7 @@ impl Serialize for BatchDeleteOutput { "consumed_capacity", &self.consumed_capacity.as_ref().map(|v| { v.iter() - .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)) + .map(crate::aws_sdk::serialize::consumed_capacity_to_value) .collect::>() }), )?; @@ -22,7 +22,7 @@ impl Serialize for BatchDeleteOutput { &self .unprocessed_items .iter() - .map(|v| crate::aws_sdk::serialize::delete_request_to_value(&v)) + .map(crate::aws_sdk::serialize::delete_request_to_value) .collect::>(), )?; state.end() @@ -41,7 +41,7 @@ impl<'de> Deserialize<'de> for BatchDeleteOutput { UnprocessedItems, } - const FIELDS: &'static [&'static str] = &["consumed_capacity", "unprocessed_items"]; + const FIELDS: &[&str] = &["consumed_capacity", "unprocessed_items"]; struct BatchDeleteOutputVisitor; diff --git a/raiden/src/aws_sdk/ops/batch_get.rs b/raiden/src/aws_sdk/ops/batch_get.rs index 4b006707..7de8e8f8 100644 --- a/raiden/src/aws_sdk/ops/batch_get.rs +++ b/raiden/src/aws_sdk/ops/batch_get.rs @@ -16,7 +16,7 @@ where "consumed_capacity", &self.consumed_capacity.as_ref().map(|v| { v.iter() - .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)) + .map(crate::aws_sdk::serialize::consumed_capacity_to_value) .collect::>() }), )?; @@ -26,7 +26,7 @@ where &self .unprocessed_keys .as_ref() - .map(|v| crate::aws_sdk::serialize::keys_and_attributes_to_value(&v)), + .map(crate::aws_sdk::serialize::keys_and_attributes_to_value), )?; state.end() } @@ -48,7 +48,7 @@ where UnprocessedKeys, } - const FIELDS: &'static [&'static str] = &["consumed_capacity", "items", "unprocessed_keys"]; + const FIELDS: &[&str] = &["consumed_capacity", "items", "unprocessed_keys"]; struct BatchGetOutputVisitor<'de, T> where diff --git a/raiden/src/aws_sdk/ops/get.rs b/raiden/src/aws_sdk/ops/get.rs index 77685bc2..99adf48f 100644 --- a/raiden/src/aws_sdk/ops/get.rs +++ b/raiden/src/aws_sdk/ops/get.rs @@ -17,7 +17,7 @@ where &self .consumed_capacity .as_ref() - .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + .map(crate::aws_sdk::serialize::consumed_capacity_to_value), )?; state.serialize_field("item", &self.item)?; state.end() @@ -39,7 +39,7 @@ where Item, } - const FIELDS: &'static [&'static str] = &["consumed_capacity", "item"]; + const FIELDS: &[&str] = &["consumed_capacity", "item"]; struct GetOutputVisitor<'de, T> where diff --git a/raiden/src/aws_sdk/ops/put.rs b/raiden/src/aws_sdk/ops/put.rs index b730f1d7..8026c548 100644 --- a/raiden/src/aws_sdk/ops/put.rs +++ b/raiden/src/aws_sdk/ops/put.rs @@ -17,7 +17,7 @@ where &self .consumed_capacity .as_ref() - .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + .map(crate::aws_sdk::serialize::consumed_capacity_to_value), )?; state.serialize_field("item", &self.item)?; state.end() @@ -39,7 +39,7 @@ where Item, } - const FIELDS: &'static [&'static str] = &["consumed_capacity", "item"]; + const FIELDS: &[&str] = &["consumed_capacity", "item"]; struct PutOutputVisitor<'de, T> where diff --git a/raiden/src/aws_sdk/ops/query.rs b/raiden/src/aws_sdk/ops/query.rs index 781a58ec..641bb29b 100644 --- a/raiden/src/aws_sdk/ops/query.rs +++ b/raiden/src/aws_sdk/ops/query.rs @@ -17,7 +17,7 @@ where &self .consumed_capacity .as_ref() - .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + .map(crate::aws_sdk::serialize::consumed_capacity_to_value), )?; state.serialize_field("items", &self.items)?; state.serialize_field("count", &self.count)?; @@ -45,7 +45,7 @@ where ScannedCount, } - const FIELDS: &'static [&'static str] = &[ + const FIELDS: &[&str] = &[ "consumed_capacity", "items", "count", diff --git a/raiden/src/aws_sdk/ops/scan.rs b/raiden/src/aws_sdk/ops/scan.rs index a94738a4..0bf736aa 100644 --- a/raiden/src/aws_sdk/ops/scan.rs +++ b/raiden/src/aws_sdk/ops/scan.rs @@ -20,7 +20,7 @@ where &self .consumed_capacity .as_ref() - .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + .map(crate::aws_sdk::serialize::consumed_capacity_to_value), )?; state.serialize_field("items", &self.items)?; state.serialize_field("count", &self.count)?; @@ -28,7 +28,7 @@ where "last_evaluated_key", &self.last_evaluated_key.as_ref().map(|v| { v.iter() - .map(|(k, v)| (k, crate::aws_sdk::serialize::attribute_value_to_value(&v))) + .map(|(k, v)| (k, crate::aws_sdk::serialize::attribute_value_to_value(v))) .collect::>() }), )?; @@ -55,7 +55,7 @@ where ScannedCount, } - const FIELDS: &'static [&'static str] = &[ + const FIELDS: &[&str] = &[ "consumed_capacity", "items", "count", diff --git a/raiden/src/aws_sdk/ops/update.rs b/raiden/src/aws_sdk/ops/update.rs index 1fe63712..f5db5a2a 100644 --- a/raiden/src/aws_sdk/ops/update.rs +++ b/raiden/src/aws_sdk/ops/update.rs @@ -17,7 +17,7 @@ where &self .consumed_capacity .as_ref() - .map(|v| crate::aws_sdk::serialize::consumed_capacity_to_value(&v)), + .map(crate::aws_sdk::serialize::consumed_capacity_to_value), )?; state.serialize_field("item", &self.item)?; state.serialize_field( @@ -25,7 +25,7 @@ where &self .item_collection_metrics .as_ref() - .map(|v| crate::aws_sdk::serialize::item_collection_metrics_to_value(&v)), + .map(crate::aws_sdk::serialize::item_collection_metrics_to_value), )?; state.end() } @@ -47,8 +47,7 @@ where ItemCollectionMetrics, } - const FIELDS: &'static [&'static str] = - &["consumed_capacity", "item", "item_collection_metrics"]; + const FIELDS: &[&str] = &["consumed_capacity", "item", "item_collection_metrics"]; struct UpdateOutputVisitor<'de, T> where diff --git a/raiden/src/aws_sdk/serialize/attribute_value.rs b/raiden/src/aws_sdk/serialize/attribute_value.rs index 7a425fed..83f3ae60 100644 --- a/raiden/src/aws_sdk/serialize/attribute_value.rs +++ b/raiden/src/aws_sdk/serialize/attribute_value.rs @@ -8,25 +8,25 @@ use serde_json::{json, Error, Value}; use crate::AttributeValue; pub fn attribute_value_to_value(value: &AttributeValue) -> Value { - match &value { - &AttributeValue::B(v) => json!({ "B": STANDARD.encode(v) }), - &AttributeValue::Bool(v) => json!({ "BOOL": v }), - &AttributeValue::Bs(vs) => json!({ "BS": [ + match value { + AttributeValue::B(v) => json!({ "B": STANDARD.encode(v) }), + AttributeValue::Bool(v) => json!({ "BOOL": v }), + AttributeValue::Bs(vs) => json!({ "BS": [ vs.iter().map(|v| json!({ "B": STANDARD.encode(v) })).collect::>(), ]}), - &AttributeValue::L(vs) => json!({ "L": [ + AttributeValue::L(vs) => json!({ "L": [ vs.iter().map(attribute_value_to_value).collect::>(), ]}), - &AttributeValue::M(vs) => json!({ "M": vs.iter().map(|(k, v)| { + AttributeValue::M(vs) => json!({ "M": vs.iter().map(|(k, v)| { (k.clone(), attribute_value_to_value(v)) }).collect::>() }), - &AttributeValue::N(v) => json!({ "N": v }), - &AttributeValue::Ns(vs) => json!({ "NS": [ + AttributeValue::N(v) => json!({ "N": v }), + AttributeValue::Ns(vs) => json!({ "NS": [ vs.iter().map(|v| json!({ "N": v })).collect::>(), ]}), - &AttributeValue::Null(v) => json!({ "NULL": v }), - &AttributeValue::S(v) => json!({ "S": v }), - &AttributeValue::Ss(vs) => json!({ "SS": [ + AttributeValue::Null(v) => json!({ "NULL": v }), + AttributeValue::S(v) => json!({ "S": v }), + AttributeValue::Ss(vs) => json!({ "SS": [ vs.iter().map(|v| json!({ "S": v })).collect::>(), ]}), _ => { diff --git a/raiden/src/aws_sdk/serialize/consumed_capacity.rs b/raiden/src/aws_sdk/serialize/consumed_capacity.rs index 5d280ee1..a4ead907 100644 --- a/raiden/src/aws_sdk/serialize/consumed_capacity.rs +++ b/raiden/src/aws_sdk/serialize/consumed_capacity.rs @@ -11,7 +11,7 @@ pub fn consumed_capacity_to_value(v: &crate::ConsumedCapacity) -> Value { "capacity_units": v.capacity_units, "read_capacity_units": v.read_capacity_units, "write_capacity_units": v.write_capacity_units, - "table": v.table.as_ref().map(|v| capacity_to_value(&v)), + "table": v.table.as_ref().map(capacity_to_value), "local_secondary_indexes": v.local_secondary_indexes.as_ref() .map(|v| { v diff --git a/raiden/src/rusoto/mod.rs b/raiden/src/rusoto/mod.rs index d736bf52..66749eab 100644 --- a/raiden/src/rusoto/mod.rs +++ b/raiden/src/rusoto/mod.rs @@ -100,7 +100,7 @@ impl<'a> FromAttribute for std::borrow::Cow<'a, str> { Some(AttributeValue { null: Some(v), .. }) if v => { Ok(std::borrow::Cow::Owned("".to_owned())) } - Some(AttributeValue { s: Some(v), .. }) => Ok(std::borrow::Cow::Owned(v.to_owned())), + Some(AttributeValue { s: Some(v), .. }) => Ok(std::borrow::Cow::Owned(v)), _ => Err(ConversionError::ValueIsNone), } } From b027a663855871340562deb2edfd9d16e3080cfb Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Sun, 3 Dec 2023 01:52:19 +0900 Subject: [PATCH 06/22] feat: upgrade aws-sdk-rust v1 --- .github/workflows/ci.yml | 2 +- Cargo.lock | 673 +++++++++--------- makefile | 16 +- raiden-derive/Cargo.toml | 4 +- raiden-derive/src/aws_sdk/client.rs | 5 +- raiden-derive/src/aws_sdk/ops/batch_delete.rs | 6 +- raiden-derive/src/aws_sdk/ops/batch_get.rs | 18 +- .../src/aws_sdk/ops/transact_write.rs | 5 +- raiden/Cargo.toml | 24 +- raiden/examples/delete.rs | 7 +- raiden/examples/get_with_reserved.rs | 7 +- raiden/examples/get_with_retries.rs | 7 +- raiden/examples/hello.rs | 7 +- raiden/examples/last_key.rs | 7 +- raiden/examples/put.rs | 7 +- raiden/examples/query.rs | 7 +- raiden/examples/query_rename.rs | 7 +- raiden/examples/scan.rs | 7 +- raiden/examples/scan_with_filter.rs | 7 +- raiden/examples/transact_write.rs | 7 +- .../transact_write_with_http_client.rs | 24 +- raiden/examples/update.rs | 7 +- raiden/examples/with_http_client.rs | 24 +- raiden/src/aws_sdk/errors.rs | 75 +- raiden/src/aws_sdk/mod.rs | 1 + .../src/aws_sdk/serialize/delete_request.rs | 10 +- .../aws_sdk/serialize/keys_and_attributes.rs | 10 +- raiden/src/errors/mod.rs | 6 +- raiden/tests/all/batch_get.rs | 4 +- raiden/tests/all/mod.rs | 22 +- raiden/tests/all/transact_write.rs | 7 +- rust-toolchain | 2 +- 32 files changed, 532 insertions(+), 490 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 6ff36476..41d573c5 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -16,7 +16,7 @@ jobs: - uses: actions-rs/toolchain@v1 with: profile: minimal - toolchain: 1.67.0 + toolchain: 1.68.0 override: true - name: Install deps run: sudo apt-get install libssl-dev diff --git a/Cargo.lock b/Cargo.lock index 2d2f45ac..494518ff 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -60,7 +60,7 @@ checksum = "a66537f1bb974b254c98ed142ff995236e81b9d0fe4db0575f46612cb15eb0f9" dependencies = [ "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", ] [[package]] @@ -71,19 +71,21 @@ checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" [[package]] name = "aws-config" -version = "0.56.1" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fc6b3804dca60326e07205179847f17a4fce45af3a1106939177ad41ac08a6de" +checksum = "80c950a809d39bc9480207cb1cfc879ace88ea7e3a4392a8e9999e45d6e5692e" dependencies = [ "aws-credential-types", "aws-http", + "aws-runtime", "aws-sdk-sso", + "aws-sdk-ssooidc", "aws-sdk-sts", "aws-smithy-async", - "aws-smithy-client", "aws-smithy-http", - "aws-smithy-http-tower", "aws-smithy-json", + "aws-smithy-runtime", + "aws-smithy-runtime-api", "aws-smithy-types", "aws-types", "bytes", @@ -91,52 +93,46 @@ dependencies = [ "hex", "http", "hyper", - "ring 0.16.20", + "ring 0.17.6", "time 0.3.30", "tokio", - "tower", "tracing", "zeroize", ] [[package]] name = "aws-credential-types" -version = "0.56.1" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "70a66ac8ef5fa9cf01c2d999f39d16812e90ec1467bd382cbbb74ba23ea86201" +checksum = "8c1317e1a3514b103cf7d5828bbab3b4d30f56bd22d684f8568bc51b6cfbbb1c" dependencies = [ "aws-smithy-async", + "aws-smithy-runtime-api", "aws-smithy-types", - "fastrand", - "tokio", - "tracing", "zeroize", ] [[package]] name = "aws-http" -version = "0.56.1" +version = "0.60.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3e626370f9ba806ae4c439e49675fd871f5767b093075cdf4fef16cac42ba900" +checksum = "361c4310fdce94328cc2d1ca0c8a48c13f43009c61d3367585685a50ca8c66b6" dependencies = [ - "aws-credential-types", - "aws-smithy-http", + "aws-smithy-runtime-api", "aws-smithy-types", "aws-types", "bytes", "http", "http-body", - "lazy_static", - "percent-encoding", "pin-project-lite", "tracing", ] [[package]] name = "aws-runtime" -version = "0.56.1" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "07ac5cf0ff19c1bca0cea7932e11b239d1025a45696a4f44f72ea86e2b8bdd07" +checksum = "1ed7ef604a15fd0d4d9e43701295161ea6b504b63c44990ead352afea2bc15e9" dependencies = [ "aws-credential-types", "aws-http", @@ -155,15 +151,14 @@ dependencies = [ [[package]] name = "aws-sdk-dynamodb" -version = "0.34.0" +version = "1.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "10aef6843bfc2dabfccad27f7e1ab303942bbda19f7ea7777d0d74388d073db4" +checksum = "23c4ed3708df2778c0c49b16e8235e52eb8f2133ae6752c40eea1376e2563fec" dependencies = [ "aws-credential-types", "aws-http", "aws-runtime", "aws-smithy-async", - "aws-smithy-client", "aws-smithy-http", "aws-smithy-json", "aws-smithy-runtime", @@ -174,21 +169,41 @@ dependencies = [ "fastrand", "http", "regex", - "tokio-stream", "tracing", ] [[package]] name = "aws-sdk-sso" -version = "0.30.0" +version = "1.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0619ab97a5ca8982e7de073cdc66f93e5f6a1b05afc09e696bec1cb3607cd4df" +dependencies = [ + "aws-credential-types", + "aws-http", + "aws-runtime", + "aws-smithy-async", + "aws-smithy-http", + "aws-smithy-json", + "aws-smithy-runtime", + "aws-smithy-runtime-api", + "aws-smithy-types", + "aws-types", + "bytes", + "http", + "regex", + "tracing", +] + +[[package]] +name = "aws-sdk-ssooidc" +version = "1.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "903f888ff190e64f6f5c83fb0f8d54f9c20481f1dc26359bb8896f5d99908949" +checksum = "f04b9f5474cc0f35d829510b2ec8c21e352309b46bf9633c5a81fb9321e9b1c7" dependencies = [ "aws-credential-types", "aws-http", "aws-runtime", "aws-smithy-async", - "aws-smithy-client", "aws-smithy-http", "aws-smithy-json", "aws-smithy-runtime", @@ -198,21 +213,19 @@ dependencies = [ "bytes", "http", "regex", - "tokio-stream", "tracing", ] [[package]] name = "aws-sdk-sts" -version = "0.30.0" +version = "1.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a47ad6bf01afc00423d781d464220bf69fb6a674ad6629cbbcb06d88cdc2be82" +checksum = "798c8d82203af9e15a8b406574e0b36da91dd6db533028b74676489a1bc8bc7d" dependencies = [ "aws-credential-types", "aws-http", "aws-runtime", "aws-smithy-async", - "aws-smithy-client", "aws-smithy-http", "aws-smithy-json", "aws-smithy-query", @@ -228,11 +241,15 @@ dependencies = [ [[package]] name = "aws-sigv4" -version = "0.56.1" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b7b28f4910bb956b7ab320b62e98096402354eca976c587d1eeccd523d9bac03" +checksum = "380adcc8134ad8bbdfeb2ace7626a869914ee266322965276cbc54066186d236" dependencies = [ + "aws-credential-types", "aws-smithy-http", + "aws-smithy-runtime-api", + "aws-smithy-types", + "bytes", "form_urlencoded", "hex", "hmac 0.12.1", @@ -247,92 +264,49 @@ dependencies = [ [[package]] name = "aws-smithy-async" -version = "0.56.1" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2cdb73f85528b9d19c23a496034ac53703955a59323d581c06aa27b4e4e247af" +checksum = "573441a5a0219e436e86a7f9a20b0f2505c5ae6fe7fe3eba6e3950991c9ad914" dependencies = [ "futures-util", "pin-project-lite", "tokio", - "tokio-stream", -] - -[[package]] -name = "aws-smithy-client" -version = "0.56.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c27b2756264c82f830a91cb4d2d485b2d19ad5bea476d9a966e03d27f27ba59a" -dependencies = [ - "aws-smithy-async", - "aws-smithy-http", - "aws-smithy-http-tower", - "aws-smithy-types", - "bytes", - "fastrand", - "http", - "http-body", - "hyper", - "hyper-rustls 0.24.2", - "lazy_static", - "pin-project-lite", - "rustls 0.21.7", - "tokio", - "tower", - "tracing", ] [[package]] name = "aws-smithy-http" -version = "0.56.1" +version = "0.60.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "54cdcf365d8eee60686885f750a34c190e513677db58bbc466c44c588abf4199" +checksum = "5b1de8aee22f67de467b2e3d0dd0fb30859dc53f579a63bd5381766b987db644" dependencies = [ + "aws-smithy-runtime-api", "aws-smithy-types", "bytes", "bytes-utils", "futures-core", "http", "http-body", - "hyper", "once_cell", "percent-encoding", "pin-project-lite", "pin-utils", - "tokio", - "tokio-util", - "tracing", -] - -[[package]] -name = "aws-smithy-http-tower" -version = "0.56.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "822de399d0ce62829a69dfa8c5cd08efdbe61a7426b953e2268f8b8b52a607bd" -dependencies = [ - "aws-smithy-http", - "aws-smithy-types", - "bytes", - "http", - "http-body", - "pin-project-lite", - "tower", "tracing", ] [[package]] name = "aws-smithy-json" -version = "0.56.1" +version = "0.60.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4fb1e7ab8fa7ad10c193af7ae56d2420989e9f4758bf03601a342573333ea34f" +checksum = "6a46dd338dc9576d6a6a5b5a19bd678dcad018ececee11cf28ecd7588bd1a55c" dependencies = [ "aws-smithy-types", ] [[package]] name = "aws-smithy-query" -version = "0.56.1" +version = "0.60.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "28556a3902091c1f768a34f6c998028921bdab8d47d92586f363f14a4a32d047" +checksum = "feb5b8c7a86d4b6399169670723b7e6f21a39fc833a30f5c5a2f997608178129" dependencies = [ "aws-smithy-types", "urlencoding", @@ -340,74 +314,86 @@ dependencies = [ [[package]] name = "aws-smithy-runtime" -version = "0.56.1" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "745e096b3553e7e0f40622aa04971ce52765af82bebdeeac53aa6fc82fe801e6" +checksum = "c0c628feae802ab1589936e2aaef6f8ab2b8fc1ee1f947c276dd8a7c3cda1904" dependencies = [ "aws-smithy-async", - "aws-smithy-client", "aws-smithy-http", "aws-smithy-runtime-api", "aws-smithy-types", "bytes", "fastrand", + "h2", "http", "http-body", + "hyper", + "hyper-rustls 0.24.2", "once_cell", "pin-project-lite", "pin-utils", + "rustls 0.21.9", "tokio", "tracing", ] [[package]] name = "aws-smithy-runtime-api" -version = "0.56.1" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "93d0ae0c9cfd57944e9711ea610b48a963fb174a53aabacc08c5794a594b1d02" +checksum = "7460e5cc8e6eb0749608535854352f6e121433960ba05daf4dbde0e42c1199a5" dependencies = [ "aws-smithy-async", - "aws-smithy-http", "aws-smithy-types", "bytes", "http", + "pin-project-lite", "tokio", "tracing", + "zeroize", ] [[package]] name = "aws-smithy-types" -version = "0.56.1" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d90dbc8da2f6be461fa3c1906b20af8f79d14968fe47f2b7d29d086f62a51728" +checksum = "8ba838f43d0d72d76918895a93c3ad647f75a058541a60e85beefb6bb0a9bd40" dependencies = [ "base64-simd", + "bytes", + "bytes-utils", + "futures-core", + "http", + "http-body", "itoa", "num-integer", + "pin-project-lite", + "pin-utils", "ryu", "serde", "time 0.3.30", + "tokio", + "tokio-util", ] [[package]] name = "aws-smithy-xml" -version = "0.56.1" +version = "0.60.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e01d2dedcdd8023043716cfeeb3c6c59f2d447fce365d8e194838891794b23b6" +checksum = "0ec40d74a67fd395bc3f6b4ccbdf1543672622d905ef3f979689aea5b730cb95" dependencies = [ "xmlparser", ] [[package]] name = "aws-types" -version = "0.56.1" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "85aa0451bf8af1bf22a4f028d5d28054507a14be43cb8ac0597a8471fba9edfe" +checksum = "8403fc56b1f3761e8efe45771ddc1165e47ec3417c68e68a4519b5cb030159ca" dependencies = [ "aws-credential-types", "aws-smithy-async", - "aws-smithy-client", - "aws-smithy-http", + "aws-smithy-runtime-api", "aws-smithy-types", "http", "rustc_version", @@ -437,9 +423,9 @@ checksum = "9e1b586273c5702936fe7b7d6896644d8be71e6314cfe09d3167c95f712589e8" [[package]] name = "base64" -version = "0.21.4" +version = "0.21.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9ba43ea6f343b788c8764558649e08df62f86c6ef251fdaeb1ffd010a9ae50a2" +checksum = "35636a1494ede3b646cc98f74f8e62c773a38a659ebc777a2cf26b9b74171df9" [[package]] name = "base64-simd" @@ -498,9 +484,9 @@ dependencies = [ [[package]] name = "bytes-utils" -version = "0.1.3" +version = "0.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e47d3a8076e283f3acd27400535992edb3ba4b5bb72f8891ad8fbe7932a7d4b9" +checksum = "7dafe3a8757b027e2be6e4e5601ed563c55989fcf1546e933c66c8eb3a058d35" dependencies = [ "bytes", "either", @@ -531,7 +517,7 @@ dependencies = [ "iana-time-zone", "num-traits", "serde", - "windows-targets", + "windows-targets 0.48.5", ] [[package]] @@ -551,9 +537,9 @@ dependencies = [ [[package]] name = "core-foundation" -version = "0.9.3" +version = "0.9.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "194a7a9e6de53fa55116934067c844d9d749312f75c6f6d0980e8c252f8c2146" +checksum = "91e195e091a93c46f7102ec7818a2aa394e1e1771c3ab4825963fa03e45afb8f" dependencies = [ "core-foundation-sys", "libc", @@ -561,15 +547,15 @@ dependencies = [ [[package]] name = "core-foundation-sys" -version = "0.8.4" +version = "0.8.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e496a50fda8aacccc86d7529e2c1e0892dbd0f898a6b5645b5561b89c3210efa" +checksum = "06ea2b9bc92be3c2baa9334a323ebca2d6f074ff852cd1d7b11064035cd3868f" [[package]] name = "cpufeatures" -version = "0.2.9" +version = "0.2.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a17b76ff3a4162b0b27f354a0c87015ddad39d35f9c0c36607a3bdd175dde1f1" +checksum = "ce420fe07aecd3e67c5f910618fe65e94158f6dcc0adf44e00d69ce2bdfe0fd0" dependencies = [ "libc", ] @@ -665,14 +651,20 @@ version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a26ae43d7bcc3b814de94796a5e736d4029efb0ee900c12e2d54c993ad1a1e07" +[[package]] +name = "equivalent" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" + [[package]] name = "errno" -version = "0.3.5" +version = "0.3.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ac3e13f66a2f95e32a39eaa81f6b95d42878ca0e1db0c7543723dfe12557e860" +checksum = "a258e46cdc063eb8519c00b9fc845fc47bcfca4130e2f08e88665ceda8474245" dependencies = [ "libc", - "windows-sys", + "windows-sys 0.52.0", ] [[package]] @@ -704,9 +696,9 @@ checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" [[package]] name = "form_urlencoded" -version = "1.2.0" +version = "1.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a62bc1cf6f830c2ec14a513a9fb124d0a213a629668a4186f329db21fe045652" +checksum = "e13624c2627564efccf4934284bdd98cbaa14e79b0b5a141218e507b3a823456" dependencies = [ "percent-encoding", ] @@ -719,9 +711,9 @@ checksum = "a06f77d526c1a601b7c4cdd98f54b5eaabffc14d5f2f0296febdc7f357c6d3ba" [[package]] name = "futures" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "23342abe12aba583913b2e62f22225ff9c950774065e4bfb61a19cd9770fec40" +checksum = "da0290714b38af9b4a7b094b8a37086d1b4e61f2df9122c3cad2577669145335" dependencies = [ "futures-channel", "futures-core", @@ -734,9 +726,9 @@ dependencies = [ [[package]] name = "futures-channel" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "955518d47e09b25bbebc7a18df10b81f0c766eaf4c4f1cccef2fca5f2a4fb5f2" +checksum = "ff4dd66668b557604244583e3e1e1eada8c5c2e96a6d0d6653ede395b78bbacb" dependencies = [ "futures-core", "futures-sink", @@ -744,15 +736,15 @@ dependencies = [ [[package]] name = "futures-core" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4bca583b7e26f571124fe5b7561d49cb2868d79116cfa0eefce955557c6fee8c" +checksum = "eb1d22c66e66d9d72e1758f0bd7d4fd0bee04cad842ee34587d68c07e45d088c" [[package]] name = "futures-executor" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ccecee823288125bd88b4d7f565c9e58e41858e47ab72e8ea2d64e93624386e0" +checksum = "0f4fb8693db0cf099eadcca0efe2a5a22e4550f98ed16aba6c48700da29597bc" dependencies = [ "futures-core", "futures-task", @@ -761,38 +753,38 @@ dependencies = [ [[package]] name = "futures-io" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4fff74096e71ed47f8e023204cfd0aa1289cd54ae5430a9523be060cdb849964" +checksum = "8bf34a163b5c4c52d0478a4d757da8fb65cabef42ba90515efee0f6f9fa45aaa" [[package]] name = "futures-macro" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "89ca545a94061b6365f2c7355b4b32bd20df3ff95f02da9329b34ccc3bd6ee72" +checksum = "53b153fd91e4b0147f4aced87be237c98248656bb01050b96bf3ee89220a8ddb" dependencies = [ "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", ] [[package]] name = "futures-sink" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f43be4fe21a13b9781a69afa4985b0f6ee0e1afab2c6f454a8cf30e2b2237b6e" +checksum = "e36d3378ee38c2a36ad710c5d30c2911d752cb941c00c72dbabfb786a7970817" [[package]] name = "futures-task" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "76d3d132be6c0e6aa1534069c705a74a5997a356c0dc2f86a47765e5617c5b65" +checksum = "efd193069b0ddadc69c46389b740bbccdd97203899b48d09c5f7969591d6bae2" [[package]] name = "futures-util" -version = "0.3.28" +version = "0.3.29" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26b01e40b772d54cf6c6d721c1d1abd0647a0106a12ecaa1c186273392a69533" +checksum = "a19526d624e703a3179b3d322efec918b6246ea0fa51d41124525f00f1cc8104" dependencies = [ "futures-channel", "futures-core", @@ -835,9 +827,9 @@ dependencies = [ [[package]] name = "getrandom" -version = "0.2.10" +version = "0.2.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "be4136b2a15dd319360be1c07d9933517ccf0be8f16bf62a3bee4f0d618df427" +checksum = "fe9006bed769170c11f845cf00c7c1e9092aeb3f268e007c3e760ac68008070f" dependencies = [ "cfg-if", "libc", @@ -846,15 +838,15 @@ dependencies = [ [[package]] name = "gimli" -version = "0.28.0" +version = "0.28.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6fb8d784f27acf97159b40fc4db5ecd8aa23b9ad5ef69cdd136d3bc80665f0c0" +checksum = "4271d37baee1b8c7e4b708028c57d816cf9d2434acb33a549475f78c181f6253" [[package]] name = "h2" -version = "0.3.21" +version = "0.3.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "91fc23aa11be92976ef4729127f1a74adf36d8436f7816b185d18df956790833" +checksum = "4d6250322ef6e60f93f9a2162799302cd6f68f79f6e5d85c8c16f14d1d958178" dependencies = [ "bytes", "fnv", @@ -871,9 +863,9 @@ dependencies = [ [[package]] name = "hashbrown" -version = "0.12.3" +version = "0.14.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888" +checksum = "290f1a1d9242c78d09ce40a5e87e7554ee637af1351968159f4952f028f75604" [[package]] name = "hermit-abi" @@ -908,9 +900,9 @@ dependencies = [ [[package]] name = "http" -version = "0.2.9" +version = "0.2.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bd6effc99afb63425aff9b05836f029929e345a6148a14b7ecd5ab67af944482" +checksum = "8947b1a6fad4393052c7ba1f4cd97bed3e953a95c79c92ad9b051a04611d9fbb" dependencies = [ "bytes", "fnv", @@ -957,7 +949,7 @@ dependencies = [ "httpdate", "itoa", "pin-project-lite", - "socket2 0.4.9", + "socket2 0.4.10", "tokio", "tower-service", "tracing", @@ -989,7 +981,7 @@ dependencies = [ "http", "hyper", "log", - "rustls 0.21.7", + "rustls 0.21.9", "rustls-native-certs", "tokio", "tokio-rustls 0.24.1", @@ -1039,11 +1031,11 @@ checksum = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39" [[package]] name = "indexmap" -version = "1.9.3" +version = "2.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bd070e393353796e801d209ad339e89596eb4c8d430d18ede6a1cced8fafbd99" +checksum = "d530e1a18b1cb4c484e6e34556a0d948706958449fca0cab753d649f2bce3d1f" dependencies = [ - "autocfg", + "equivalent", "hashbrown", ] @@ -1064,9 +1056,9 @@ checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" [[package]] name = "js-sys" -version = "0.3.64" +version = "0.3.66" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c5f195fe497f702db0f318b07fdd68edb16955aed830df8363d837542f8f935a" +checksum = "cee9c64da59eae3b50095c18d3e74f8b73c0b86d2792824ff01bbce68ba229ca" dependencies = [ "wasm-bindgen", ] @@ -1079,15 +1071,26 @@ checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646" [[package]] name = "libc" -version = "0.2.149" +version = "0.2.150" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "89d92a4743f9a61002fae18374ed11e7973f530cb3a3255fb354818118b2203c" + +[[package]] +name = "libredox" +version = "0.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a08173bc88b7955d1b3145aa561539096c421ac8debde8cbc3612ec635fee29b" +checksum = "85c833ca1e66078851dba29046874e38f08b2c883700aa29a03ddd3b23814ee8" +dependencies = [ + "bitflags 2.4.1", + "libc", + "redox_syscall 0.4.1", +] [[package]] name = "linux-raw-sys" -version = "0.4.10" +version = "0.4.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "da2479e8c062e40bf0066ffa0bc823de0a9368974af99c9f6df941d2c231e03f" +checksum = "c4cd1a83af159aa67994778be9070f0ae1bd732942279cabb14f86f986a21456" [[package]] name = "lock_api" @@ -1142,13 +1145,13 @@ dependencies = [ [[package]] name = "mio" -version = "0.8.8" +version = "0.8.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "927a765cd3fc26206e66b296465fa9d3e5ab003e651c1b3c060e7956d96b19d2" +checksum = "3dce281c5e46beae905d4de1870d8b1509a9142b62eedf18b443b011ca8343d0" dependencies = [ "libc", "wasi 0.11.0+wasi-snapshot-preview1", - "windows-sys", + "windows-sys 0.48.0", ] [[package]] @@ -1231,9 +1234,9 @@ checksum = "624a8340c38c1b80fd549087862da4ba43e08858af025b236e509b6649fc13d5" [[package]] name = "openssl" -version = "0.10.57" +version = "0.10.60" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bac25ee399abb46215765b1cb35bc0212377e58a061560d8b29b024fd0430e7c" +checksum = "79a4c6c3a2b158f7f8f2a2fc5a969fa3a068df6fc9dbb4a43845436e3af7c800" dependencies = [ "bitflags 2.4.1", "cfg-if", @@ -1252,7 +1255,7 @@ checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", ] [[package]] @@ -1263,9 +1266,9 @@ checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" [[package]] name = "openssl-sys" -version = "0.9.93" +version = "0.9.96" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "db4d56a4c0478783083cfafcc42493dd4a981d41669da64b4572a2a089b51b1d" +checksum = "3812c071ba60da8b5677cc12bcb1d42989a65553772897a7e0355545a819838f" dependencies = [ "cc", "libc", @@ -1318,29 +1321,9 @@ checksum = "de3145af08024dea9fa9914f381a17b8fc6034dfb00f3a84013f7ff43f29ed4c" [[package]] name = "percent-encoding" -version = "2.3.0" +version = "2.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9b2a4787296e9989611394c33f193f676704af1686e70b8f8033ab5ba9a35a94" - -[[package]] -name = "pin-project" -version = "1.1.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fda4ed1c6c173e3fc7a83629421152e01d7b1f9b7f65fb301e490e8cfc656422" -dependencies = [ - "pin-project-internal", -] - -[[package]] -name = "pin-project-internal" -version = "1.1.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4359fd9c9171ec6e8c62926d6faaf553a8dc3f64e1507e76da7911b4f6a04405" -dependencies = [ - "proc-macro2", - "quote", - "syn 2.0.38", -] +checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" [[package]] name = "pin-project-lite" @@ -1390,9 +1373,9 @@ checksum = "dc375e1527247fe1a97d8b7156678dfe7c1af2fc075c9a4db3690ecd2a148068" [[package]] name = "proc-macro2" -version = "1.0.69" +version = "1.0.70" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "134c189feb4956b20f6f547d2cf727d4c0fe06722b20a0eec87ed445a97f92da" +checksum = "39278fbbf5fb4f646ce651690877f89d1c5811a3d4acb27700c1cb3cdb78fd3b" dependencies = [ "unicode-ident", ] @@ -1438,11 +1421,9 @@ dependencies = [ "aws-config", "aws-credential-types", "aws-sdk-dynamodb", - "aws-smithy-client", - "aws-smithy-http", + "aws-smithy-runtime", "aws-smithy-runtime-api", - "aws-smithy-types", - "base64 0.21.4", + "base64 0.21.5", "hyper-rustls 0.24.2", "paste", "pretty_assertions", @@ -1472,7 +1453,7 @@ dependencies = [ "ident_case", "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", ] [[package]] @@ -1574,21 +1555,21 @@ dependencies = [ [[package]] name = "redox_syscall" -version = "0.3.5" +version = "0.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "567664f262709473930a4bf9e51bf2ebf3348f2e748ccc50dea20646858f8f29" +checksum = "4722d768eff46b75989dd134e5c353f0d6296e5aaa3132e776cbdb56be7731aa" dependencies = [ "bitflags 1.3.2", ] [[package]] name = "redox_users" -version = "0.4.3" +version = "0.4.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b033d837a7cf162d7993aded9304e30a83213c648b6e389db233191f891e5c2b" +checksum = "a18479200779601e498ada4e8c1e1f50e3ee19deb0259c25825a98b5603b2cb4" dependencies = [ - "getrandom 0.2.10", - "redox_syscall 0.2.16", + "getrandom 0.2.11", + "libredox", "thiserror", ] @@ -1653,16 +1634,16 @@ dependencies = [ [[package]] name = "ring" -version = "0.17.4" +version = "0.17.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fce3045ffa7c981a6ee93f640b538952e155f1ae3a1a02b84547fc7a56b7059a" +checksum = "684d5e6e18f669ccebf64a92236bb7db9a34f07be010e3627368182027180866" dependencies = [ "cc", - "getrandom 0.2.10", + "getrandom 0.2.11", "libc", "spin 0.9.8", "untrusted 0.9.0", - "windows-sys", + "windows-sys 0.48.0", ] [[package]] @@ -1770,9 +1751,9 @@ checksum = "d626bb9dae77e28219937af045c257c28bfd3f69333c512553507f5f9798cb76" [[package]] name = "rustc-serialize" -version = "0.3.24" +version = "0.3.25" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dcf128d1287d2ea9d80910b5f1120d0b8eede3fbf1abe91c40d39ea7d51e6fda" +checksum = "fe834bc780604f4674073badbad26d7219cadfb4a2275802db12cbae17498401" [[package]] name = "rustc_version" @@ -1785,15 +1766,15 @@ dependencies = [ [[package]] name = "rustix" -version = "0.38.19" +version = "0.38.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "745ecfa778e66b2b63c88a61cb36e0eea109e803b0b86bf9879fbc77c70e86ed" +checksum = "9470c4bf8246c8daf25f9598dca807fb6510347b1e1cfa55749113850c79d88a" dependencies = [ "bitflags 2.4.1", "errno", "libc", "linux-raw-sys", - "windows-sys", + "windows-sys 0.52.0", ] [[package]] @@ -1810,12 +1791,12 @@ dependencies = [ [[package]] name = "rustls" -version = "0.21.7" +version = "0.21.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cd8d6c9f025a446bc4d18ad9632e69aec8f287aa84499ee335599fabd20c3fd8" +checksum = "629648aced5775d558af50b2b4c7b02983a04b312126d45eeead26e7caa498b9" dependencies = [ "log", - "ring 0.16.20", + "ring 0.17.6", "rustls-webpki", "sct", ] @@ -1834,21 +1815,21 @@ dependencies = [ [[package]] name = "rustls-pemfile" -version = "1.0.3" +version = "1.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2d3987094b1d07b653b7dfdc3f70ce9a1da9c51ac18c1b06b662e4f9a0e9f4b2" +checksum = "1c74cae0a4cf6ccbbf5f359f08efdf8ee7e1dc532573bf0db71968cb56b1448c" dependencies = [ - "base64 0.21.4", + "base64 0.21.5", ] [[package]] name = "rustls-webpki" -version = "0.101.6" +version = "0.101.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c7d5dece342910d9ba34d259310cae3e0154b873b35408b787b59bce53d34fe" +checksum = "8b6275d1ee7a1cd780b64aca7726599a1dbc893b1e64144529e55c3c2f745765" dependencies = [ - "ring 0.16.20", - "untrusted 0.7.1", + "ring 0.17.6", + "untrusted 0.9.0", ] [[package]] @@ -1883,7 +1864,7 @@ version = "0.1.22" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0c3733bf4cf7ea0880754e19cb5a462007c4a8c1914bff372ccc95b464f1df88" dependencies = [ - "windows-sys", + "windows-sys 0.48.0", ] [[package]] @@ -1894,12 +1875,12 @@ checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" [[package]] name = "sct" -version = "0.7.0" +version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d53dcdb7c9f8158937a7981b48accfd39a43af418591a5d008c7b22b5e1b7ca4" +checksum = "da046153aa2352493d6cb7da4b6e5c0c057d8a1d0a9aa8560baffdd945acd414" dependencies = [ - "ring 0.16.20", - "untrusted 0.7.1", + "ring 0.17.6", + "untrusted 0.9.0", ] [[package]] @@ -1933,29 +1914,29 @@ checksum = "836fa6a3e1e547f9a2c4040802ec865b5d85f4014efe00555d7090a3dcaa1090" [[package]] name = "serde" -version = "1.0.189" +version = "1.0.193" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e422a44e74ad4001bdc8eede9a4570ab52f71190e9c076d14369f38b9200537" +checksum = "25dd9975e68d0cb5aa1120c288333fc98731bd1dd12f561e468ea4728c042b89" dependencies = [ "serde_derive", ] [[package]] name = "serde_derive" -version = "1.0.189" +version = "1.0.193" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1e48d1f918009ce3145511378cf68d613e3b3d9137d67272562080d68a2b32d5" +checksum = "43576ca501357b9b071ac53cdc7da8ef0cbd9493d8df094cd821777ea6e894d3" dependencies = [ "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", ] [[package]] name = "serde_json" -version = "1.0.107" +version = "1.0.108" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6b420ce6e3d8bd882e9b243c6eed35dbc9a6110c9769e74b584e0d68d1f20c65" +checksum = "3d1c7e3eac408d115102c4c24ad393e0821bb3a5df4d506a80f85f7a742a526b" dependencies = [ "itoa", "ryu", @@ -2021,15 +2002,15 @@ dependencies = [ [[package]] name = "smallvec" -version = "1.11.1" +version = "1.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "942b4a808e05215192e39f4ab80813e599068285906cc91aa64f923db842bd5a" +checksum = "4dccd0940a2dcdf68d092b8cbab7dc0ad8fa938bf95787e1b916b0e3d0e8e970" [[package]] name = "socket2" -version = "0.4.9" +version = "0.4.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "64a4a911eed85daf18834cfaa86a79b7d266ff93ff5ba14005426219480ed662" +checksum = "9f7916fc008ca5542385b89a3d3ce689953c143e9304a9bf8beec1de48994c0d" dependencies = [ "libc", "winapi", @@ -2037,12 +2018,12 @@ dependencies = [ [[package]] name = "socket2" -version = "0.5.4" +version = "0.5.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4031e820eb552adee9295814c0ced9e5cf38ddf1e8b7d566d6de8e2538ea989e" +checksum = "7b5fac59a5cb5dd637972e5fca70daf0523c9067fcdc4842f053dae04a18f8e9" dependencies = [ "libc", - "windows-sys", + "windows-sys 0.48.0", ] [[package]] @@ -2076,9 +2057,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.38" +version = "2.0.39" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e96b79aaa137db8f61e26363a0c9b47d8b4ec75da28b7d1d614c2303e232408b" +checksum = "23e78b90f2fcf45d3e842032ce32e3f2d1545ba6636271dcbf24fa306d87be7a" dependencies = [ "proc-macro2", "quote", @@ -2087,35 +2068,35 @@ dependencies = [ [[package]] name = "tempfile" -version = "3.8.0" +version = "3.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cb94d2f3cc536af71caac6b6fcebf65860b347e7ce0cc9ebe8f70d3e521054ef" +checksum = "7ef1adac450ad7f4b3c28589471ade84f25f731a7a0fe30d71dfa9f60fd808e5" dependencies = [ "cfg-if", "fastrand", - "redox_syscall 0.3.5", + "redox_syscall 0.4.1", "rustix", - "windows-sys", + "windows-sys 0.48.0", ] [[package]] name = "thiserror" -version = "1.0.49" +version = "1.0.50" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1177e8c6d7ede7afde3585fd2513e611227efd6481bd78d2e82ba1ce16557ed4" +checksum = "f9a7210f5c9a7156bb50aa36aed4c95afb51df0df00713949448cf9e97d382d2" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.49" +version = "1.0.50" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "10712f02019e9288794769fba95cd6847df9874d49d871d062172f9dd41bc4cc" +checksum = "266b2e40bc00e5a6c09c3584011e08b06f123c00362c92b975ba9843aaaa14b8" dependencies = [ "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", ] [[package]] @@ -2170,9 +2151,9 @@ dependencies = [ [[package]] name = "tokio" -version = "1.33.0" +version = "1.34.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4f38200e3ef7995e5ef13baec2f432a6da0aa9ac495b2c0e8f3b7eec2c92d653" +checksum = "d0c014766411e834f7af5b8f4cf46257aab4036ca95e9d2c144a10f59ad6f5b9" dependencies = [ "backtrace", "bytes", @@ -2181,20 +2162,20 @@ dependencies = [ "num_cpus", "pin-project-lite", "signal-hook-registry", - "socket2 0.5.4", + "socket2 0.5.5", "tokio-macros", - "windows-sys", + "windows-sys 0.48.0", ] [[package]] name = "tokio-macros" -version = "2.1.0" +version = "2.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "630bdcf245f78637c13ec01ffae6187cca34625e8c63150d424b59e55af2675e" +checksum = "5b8a1e28f2deaa14e508979454cb3a223b10b938b45af148bc0986de36f1923b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", ] [[package]] @@ -2224,26 +2205,15 @@ version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c28327cf380ac148141087fbfb9de9d7bd4e84ab5d2c28fbc911d753de8a7081" dependencies = [ - "rustls 0.21.7", - "tokio", -] - -[[package]] -name = "tokio-stream" -version = "0.1.14" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "397c988d37662c7dda6d2208364a706264bf3d6138b11d436cbac0ad38832842" -dependencies = [ - "futures-core", - "pin-project-lite", + "rustls 0.21.9", "tokio", ] [[package]] name = "tokio-util" -version = "0.7.9" +version = "0.7.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1d68074620f57a0b21594d9735eb2e98ab38b17f80d3fcb189fca266771ca60d" +checksum = "5419f34732d9eb6ee4c3578b7989078579b7f039cbbb9ca2c4da015749371e15" dependencies = [ "bytes", "futures-core", @@ -2253,28 +2223,6 @@ dependencies = [ "tracing", ] -[[package]] -name = "tower" -version = "0.4.13" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b8fa9be0de6cf49e536ce1851f987bd21a43b771b09473c3549a6c853db37c1c" -dependencies = [ - "futures-core", - "futures-util", - "pin-project", - "pin-project-lite", - "tokio", - "tower-layer", - "tower-service", - "tracing", -] - -[[package]] -name = "tower-layer" -version = "0.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c20c8dbed6283a09604c3e69b4b7eeb54e298b8a600d4d5ecb5ad39de609f1d0" - [[package]] name = "tower-service" version = "0.3.2" @@ -2283,11 +2231,10 @@ checksum = "b6bc1c9ce2b5135ac7f93c72918fc37feb872bdc6a5533a8b85eb4b86bfdae52" [[package]] name = "tracing" -version = "0.1.39" +version = "0.1.40" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ee2ef2af84856a50c1d430afce2fdded0a4ec7eda868db86409b4543df0797f9" +checksum = "c3523ab5a71916ccf420eebdf5521fcef02141234bbc0b8a49f2fdc4544364ef" dependencies = [ - "log", "pin-project-lite", "tracing-attributes", "tracing-core", @@ -2301,7 +2248,7 @@ checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", ] [[package]] @@ -2316,20 +2263,20 @@ dependencies = [ [[package]] name = "tracing-log" -version = "0.1.3" +version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "78ddad33d2d10b1ed7eb9d1f518a5674713876e97e5bb9b7345a7984fbb4f922" +checksum = "ee855f1f400bd0e5c02d150ae5de3840039a3f54b025156404e34c23c03f47c3" dependencies = [ - "lazy_static", "log", + "once_cell", "tracing-core", ] [[package]] name = "tracing-subscriber" -version = "0.3.17" +version = "0.3.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "30a651bc37f915e81f087d86e62a18eec5f79550c7faff886f7090b4ea757c77" +checksum = "ad0f048c97dbd9faa9b7df56362b8ebcaa52adb06b498c050d2f4e32f90a7a8b" dependencies = [ "matchers", "nu-ansi-term", @@ -2388,11 +2335,11 @@ checksum = "daf8dba3b7eb870caf1ddeed7bc9d2a049f3cfdfae7cb521b087cc33ae4c49da" [[package]] name = "uuid" -version = "1.5.0" +version = "1.6.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "88ad59a7560b41a70d191093a945f0b87bc1deeda46fb237479708a1d6b6cdfc" +checksum = "5e395fcf16a7a3d8127ec99782007af141946b4795001f876d54fb0d55978560" dependencies = [ - "getrandom 0.2.10", + "getrandom 0.2.11", ] [[package]] @@ -2448,9 +2395,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7706a72ab36d8cb1f80ffbf0e071533974a60d0a308d01a5d0375bf60499a342" +checksum = "0ed0d4f68a3015cc185aff4db9506a015f4b96f95303897bfa23f846db54064e" dependencies = [ "cfg-if", "wasm-bindgen-macro", @@ -2458,24 +2405,24 @@ dependencies = [ [[package]] name = "wasm-bindgen-backend" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5ef2b6d3c510e9625e5fe6f509ab07d66a760f0885d858736483c32ed7809abd" +checksum = "1b56f625e64f3a1084ded111c4d5f477df9f8c92df113852fa5a374dbda78826" dependencies = [ "bumpalo", "log", "once_cell", "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-futures" -version = "0.4.37" +version = "0.4.39" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c02dbc21516f9f1f04f187958890d7e6026df8d16540b7ad9492bc34a67cea03" +checksum = "ac36a15a220124ac510204aec1c3e5db8a22ab06fd6706d881dc6149f8ed9a12" dependencies = [ "cfg-if", "js-sys", @@ -2485,9 +2432,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dee495e55982a3bd48105a7b947fd2a9b4a8ae3010041b9e0faab3f9cd028f1d" +checksum = "0162dbf37223cd2afce98f3d0785506dcb8d266223983e4b5b525859e6e182b2" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -2495,22 +2442,22 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "54681b18a46765f095758388f2d0cf16eb8d4169b639ab575a8f5693af210c7b" +checksum = "f0eb82fcb7930ae6219a7ecfd55b217f5f0893484b7a13022ebb2b2bf20b5283" dependencies = [ "proc-macro2", "quote", - "syn 2.0.38", + "syn 2.0.39", "wasm-bindgen-backend", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-shared" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca6ad05a4870b2bf5fe995117d3728437bd27d7cd5f06f13c17443ef369775a1" +checksum = "7ab9b36309365056cd639da3134bf87fa8f3d86008abf99e612384a6eecd459f" [[package]] name = "wasm-timer" @@ -2529,9 +2476,9 @@ dependencies = [ [[package]] name = "web-sys" -version = "0.3.64" +version = "0.3.66" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9b85cbef8c220a6abc02aefd892dfc0fc23afb1c6a426316ec33253a3877249b" +checksum = "50c24a44ec86bb68fbecd1b3efed7e85ea5621b39b35ef2766b66cd984f8010f" dependencies = [ "js-sys", "wasm-bindgen", @@ -2543,7 +2490,7 @@ version = "0.22.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ed63aea5ce73d0ff405984102c42de94fc55a6b75765d621c65262469b3c9b53" dependencies = [ - "ring 0.17.4", + "ring 0.17.6", "untrusted 0.9.0", ] @@ -2575,7 +2522,7 @@ version = "0.51.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f1f8cf84f35d2db49a46868f947758c7a1138116f7fac3bc844f43ade1292e64" dependencies = [ - "windows-targets", + "windows-targets 0.48.5", ] [[package]] @@ -2584,7 +2531,16 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" dependencies = [ - "windows-targets", + "windows-targets 0.48.5", +] + +[[package]] +name = "windows-sys" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" +dependencies = [ + "windows-targets 0.52.0", ] [[package]] @@ -2593,13 +2549,28 @@ version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" dependencies = [ - "windows_aarch64_gnullvm", - "windows_aarch64_msvc", - "windows_i686_gnu", - "windows_i686_msvc", - "windows_x86_64_gnu", - "windows_x86_64_gnullvm", - "windows_x86_64_msvc", + "windows_aarch64_gnullvm 0.48.5", + "windows_aarch64_msvc 0.48.5", + "windows_i686_gnu 0.48.5", + "windows_i686_msvc 0.48.5", + "windows_x86_64_gnu 0.48.5", + "windows_x86_64_gnullvm 0.48.5", + "windows_x86_64_msvc 0.48.5", +] + +[[package]] +name = "windows-targets" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8a18201040b24831fbb9e4eb208f8892e1f50a37feb53cc7ff887feb8f50e7cd" +dependencies = [ + "windows_aarch64_gnullvm 0.52.0", + "windows_aarch64_msvc 0.52.0", + "windows_i686_gnu 0.52.0", + "windows_i686_msvc 0.52.0", + "windows_x86_64_gnu 0.52.0", + "windows_x86_64_gnullvm 0.52.0", + "windows_x86_64_msvc 0.52.0", ] [[package]] @@ -2608,42 +2579,84 @@ version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cb7764e35d4db8a7921e09562a0304bf2f93e0a51bfccee0bd0bb0b666b015ea" + [[package]] name = "windows_aarch64_msvc" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" +[[package]] +name = "windows_aarch64_msvc" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bbaa0368d4f1d2aaefc55b6fcfee13f41544ddf36801e793edbbfd7d7df075ef" + [[package]] name = "windows_i686_gnu" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" +[[package]] +name = "windows_i686_gnu" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a28637cb1fa3560a16915793afb20081aba2c92ee8af57b4d5f28e4b3e7df313" + [[package]] name = "windows_i686_msvc" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" +[[package]] +name = "windows_i686_msvc" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ffe5e8e31046ce6230cc7215707b816e339ff4d4d67c65dffa206fd0f7aa7b9a" + [[package]] name = "windows_x86_64_gnu" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" +[[package]] +name = "windows_x86_64_gnu" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3d6fa32db2bc4a2f5abeacf2b69f7992cd09dca97498da74a151a3132c26befd" + [[package]] name = "windows_x86_64_gnullvm" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1a657e1e9d3f514745a572a6846d3c7aa7dbe1658c056ed9c3344c4109a6949e" + [[package]] name = "windows_x86_64_msvc" version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" +[[package]] +name = "windows_x86_64_msvc" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dff9641d1cd4be8d1a070daf9e3773c5f67e78b4d9d42263020c057706765c04" + [[package]] name = "xml-rs" version = "0.8.19" @@ -2664,6 +2677,6 @@ checksum = "09041cd90cf85f7f8b2df60c646f853b7f535ce68f85244eb6731cf89fa498ec" [[package]] name = "zeroize" -version = "1.6.0" +version = "1.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2a0956f1ba7c7909bfb66c2e9e4124ab6f6482560f6628b5aaeba39207c9aad9" +checksum = "525b4ec142c6b68a2d10f01f7bbf6755599ca3f81ea53b8431b7dd348f5fdb2d" diff --git a/makefile b/makefile index c62e76b0..d1a312ac 100644 --- a/makefile +++ b/makefile @@ -1,28 +1,28 @@ .PHONY: dynamo dynamo: - - docker compose down --volumes + docker compose down --volumes docker compose up -d --wait dynamodb docker compose up aws-cli deno run --allow-net=localhost:8000 --allow-env --no-check ./setup/setup.ts .PHONY: test test: - make dynamo - cargo test -- --test-threads=1 make dynamo cargo test --no-default-features --features aws-sdk -- --test-threads=1 + make dynamo + cargo test --no-default-features --features rusoto -- --test-threads=1 .PHONY: lint lint: - cargo clippy --all-targets -- -D warnings - cargo clippy --all-targets --features tracing -- -D warnings - cargo clippy --all-targets --no-default-features --features rusoto_rustls -- -D warnings cargo clippy --all-targets --no-default-features --features aws-sdk -- -D warnings + cargo clippy --all-targets --no-default-features --features rusoto -- -D warnings + cargo clippy --all-targets --no-default-features --features rusoto_rustls -- -D warnings + cargo clippy --all-targets --features tracing -- -D warnings .PHONY: check-deps check-deps: cargo machete || echo - cargo +nightly udeps --all-targets cargo +nightly udeps --all-targets --features tracing - cargo +nightly udeps --all-targets --no-default-features --features rusoto_rustls cargo +nightly udeps --all-targets --no-default-features --features aws-sdk + cargo +nightly udeps --all-targets --no-default-features --features rusoto + cargo +nightly udeps --all-targets --no-default-features --features rusoto_rustls diff --git a/raiden-derive/Cargo.toml b/raiden-derive/Cargo.toml index b5a18434..efda9bd5 100644 --- a/raiden-derive/Cargo.toml +++ b/raiden-derive/Cargo.toml @@ -12,9 +12,9 @@ proc-macro = true [dependencies] convert_case = "^0.6.0" ident_case = "^1.0.1" -proc-macro2 = "^1.0.69" +proc-macro2 = "^1.0.70" quote = "^1.0.33" -syn = "^2.0.38" +syn = "^2.0.39" [features] default = ["rusoto"] diff --git a/raiden-derive/src/aws_sdk/client.rs b/raiden-derive/src/aws_sdk/client.rs index 77ee235a..dd06350c 100644 --- a/raiden-derive/src/aws_sdk/client.rs +++ b/raiden-derive/src/aws_sdk/client.rs @@ -25,7 +25,10 @@ pub(crate) fn expand_client_constructor( impl #client_name { pub fn new(region: ::raiden::Region) -> Self { - let config = ::raiden::Config::builder().region(region).build(); + let config = ::raiden::Config::builder() + .behavior_version(::raiden::BehaviorVersion::latest()) + .region(region) + .build(); let client = ::raiden::#dynamodb_client_name::from_conf(config); Self::new_with_dynamo_db_client(client) } diff --git a/raiden-derive/src/aws_sdk/ops/batch_delete.rs b/raiden-derive/src/aws_sdk/ops/batch_delete.rs index ab35c663..01369fe5 100644 --- a/raiden-derive/src/aws_sdk/ops/batch_delete.rs +++ b/raiden-derive/src/aws_sdk/ops/batch_delete.rs @@ -33,7 +33,8 @@ pub(crate) fn expand_batch_delete( (stringify!(#partition_key_ident).to_string(), pk_attr_value), (stringify!(#sort_key_ident).to_string(), sk_attr_value), ]))) - .build(); + .build() + .expect("should be built"); ::raiden::WriteRequest::builder() .delete_request(delete_request) @@ -72,7 +73,8 @@ pub(crate) fn expand_batch_delete( .set_key(Some(::std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_string(), pk_attr_value), ]))) - .build(); + .build() + .expect("should be built"); ::raiden::WriteRequest::builder() .delete_request(delete_request) diff --git a/raiden-derive/src/aws_sdk/ops/batch_get.rs b/raiden-derive/src/aws_sdk/ops/batch_get.rs index 54e9cc09..520a97f5 100644 --- a/raiden-derive/src/aws_sdk/ops/batch_get.rs +++ b/raiden-derive/src/aws_sdk/ops/batch_get.rs @@ -138,16 +138,19 @@ pub(crate) fn expand_batch_get( use ::std::iter::FromIterator; let mut items: std::vec::Vec<#struct_name> = vec![]; - let mut unprocessed_keys = ::raiden::KeysAndAttributes::builder().build(); + let mut unprocessed_keys = ::raiden::KeysAndAttributes::builder() + .set_keys(Some(vec![])) + .build() + .expect("should be built"); // TODO: for now set 5, however we should make it more flexible. let mut unprocessed_retry = 5; loop { - let unprocessed_key_len = unprocessed_keys.keys().map_or(0, |v| v.len()); + let unprocessed_key_len = unprocessed_keys.keys().len(); let mut item_builder = ::raiden::KeysAndAttributes::builder() .set_expression_attribute_names(self.attribute_names.clone()) .set_projection_expression(self.projection_expression.clone()) - .set_keys(unprocessed_keys.keys); + .set_keys(Some(unprocessed_keys.keys)); if unprocessed_key_len < 100 { let keys = self.keys.drain(0..std::cmp::min(100 - unprocessed_key_len, self.keys.len())); @@ -155,7 +158,10 @@ pub(crate) fn expand_batch_get( } let builder = ::raiden::BatchGetItemInput::builder() - .request_items(self.table_name.to_string(), item_builder.build()); + .request_items( + self.table_name.to_string(), + item_builder.build().expect("should be built"), + ); let res = #call_inner_run; @@ -179,7 +185,7 @@ pub(crate) fn expand_batch_get( return Err(::raiden::RaidenError::ResourceNotFound("resource not found".to_owned())); } - unprocessed_keys.keys = None; + unprocessed_keys.keys = vec![]; if let Some(keys_by_table) = res.unprocessed_keys { if let Some(keys_attrs) = keys_by_table.get(&self.table_name) { @@ -188,7 +194,7 @@ pub(crate) fn expand_batch_get( } if ( - self.keys.is_empty() && unprocessed_keys.keys.clone().map_or(true, |v| v.is_empty()) + self.keys.is_empty() && unprocessed_keys.keys.is_empty() ) || unprocessed_retry == 0 { return Ok(::raiden::batch_get::BatchGetOutput { diff --git a/raiden-derive/src/aws_sdk/ops/transact_write.rs b/raiden-derive/src/aws_sdk/ops/transact_write.rs index 239b4944..d95c2220 100644 --- a/raiden-derive/src/aws_sdk/ops/transact_write.rs +++ b/raiden-derive/src/aws_sdk/ops/transact_write.rs @@ -149,6 +149,7 @@ pub(crate) fn expand_transact_write( self.builder .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)) .build() + .expect("should be built") } } @@ -288,7 +289,7 @@ pub(crate) fn expand_transact_write( self.builder = self.builder .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)); - self.builder.build() + self.builder.build().expect("should be built") } } @@ -354,6 +355,7 @@ pub(crate) fn expand_transact_write( self.builder .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)) .build() + .expect("should be built") } } @@ -398,6 +400,7 @@ pub(crate) fn expand_transact_write( self.builder .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)) .build() + .expect("should be built") } } diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index 47153293..67ea6fcf 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -8,11 +8,9 @@ edition = "2018" [dependencies] again = "0.1" -aws-config = { version = "0.56.1", optional = true } -aws-sdk-dynamodb = { version = "0.34.0", optional = true } -aws-smithy-http = { version = "0.56.1", optional = true } -aws-smithy-runtime-api = { version = "0.56.1", optional = true } -aws-smithy-types = { version = "0.56.1", optional = true } +aws-config = { version = "^1", optional = true } +aws-sdk-dynamodb = { version = "^1", optional = true } +aws-smithy-runtime-api = { version = "^1", optional = true } base64 = "^0.21" paste = { version = "1.0.14", optional = true } raiden-derive = { version = "*", path = "../raiden-derive", default_features = false } @@ -35,12 +33,13 @@ serde_derive = "^1" serde_json = "^1" thiserror = "^1" tracing = { version = "0.1", optional = true } -uuid = { version = "^1.4.1", features = ["v4"] } +uuid = { version = "^1.6", features = ["v4"] } + [dev-dependencies] -aws-credential-types = "0.56.1" -aws-smithy-client = "0.56.1" -hyper-rustls = { version = "0.24.2", default-features = false, features = [ +aws-credential-types = "1.0.1" +aws-smithy-runtime = { version = "^1" } +hyper-rustls = { version = "0.24", default-features = false, features = [ "http1", "http2", "native-tokio", @@ -48,17 +47,16 @@ hyper-rustls = { version = "0.24.2", default-features = false, features = [ pretty_assertions = "1.4.0" raiden = { path = "./", features = ["tracing"], default_features = false } time = "0.3.30" -tokio = { version = "1.33.0", features = ["rt-multi-thread"] } -tracing-subscriber = { version = "0.3.17", features = ["env-filter", "time"] } +tokio = { version = "^1", features = ["rt-multi-thread"] } +tracing-subscriber = { version = "0.3", features = ["env-filter", "time"] } + [features] default = ["rusoto"] aws-sdk = [ "dep:aws-config", "dep:aws-sdk-dynamodb", - "dep:aws-smithy-http", "dep:aws-smithy-runtime-api", - "dep:aws-smithy-types", "dep:paste", "raiden-derive/aws-sdk", ] diff --git a/raiden/examples/delete.rs b/raiden/examples/delete.rs index f309290a..d695d4c3 100644 --- a/raiden/examples/delete.rs +++ b/raiden/examples/delete.rs @@ -29,14 +29,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/get_with_reserved.rs b/raiden/examples/get_with_reserved.rs index 84d1673b..1edce86f 100644 --- a/raiden/examples/get_with_reserved.rs +++ b/raiden/examples/get_with_reserved.rs @@ -24,14 +24,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersiontest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/get_with_retries.rs b/raiden/examples/get_with_retries.rs index d4a0b176..63d30a1b 100644 --- a/raiden/examples/get_with_retries.rs +++ b/raiden/examples/get_with_retries.rs @@ -39,14 +39,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/hello.rs b/raiden/examples/hello.rs index 7ac9f506..ecc3cd3a 100644 --- a/raiden/examples/hello.rs +++ b/raiden/examples/hello.rs @@ -39,14 +39,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/last_key.rs b/raiden/examples/last_key.rs index a33961b4..80441e6e 100644 --- a/raiden/examples/last_key.rs +++ b/raiden/examples/last_key.rs @@ -33,14 +33,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/put.rs b/raiden/examples/put.rs index 2216bcba..e80c43a5 100644 --- a/raiden/examples/put.rs +++ b/raiden/examples/put.rs @@ -74,14 +74,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/query.rs b/raiden/examples/query.rs index 2e57fd32..8a1dc9d1 100644 --- a/raiden/examples/query.rs +++ b/raiden/examples/query.rs @@ -46,14 +46,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/query_rename.rs b/raiden/examples/query_rename.rs index 2a7fe39d..0638daca 100644 --- a/raiden/examples/query_rename.rs +++ b/raiden/examples/query_rename.rs @@ -32,14 +32,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/scan.rs b/raiden/examples/scan.rs index 8e549db9..17a5285a 100644 --- a/raiden/examples/scan.rs +++ b/raiden/examples/scan.rs @@ -27,14 +27,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/scan_with_filter.rs b/raiden/examples/scan_with_filter.rs index b3986bf3..ccad087d 100644 --- a/raiden/examples/scan_with_filter.rs +++ b/raiden/examples/scan_with_filter.rs @@ -28,14 +28,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/transact_write.rs b/raiden/examples/transact_write.rs index 5be3f3eb..9f03aa63 100644 --- a/raiden/examples/transact_write.rs +++ b/raiden/examples/transact_write.rs @@ -36,14 +36,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/transact_write_with_http_client.rs b/raiden/examples/transact_write_with_http_client.rs index 690e0939..2cd84a57 100644 --- a/raiden/examples/transact_write_with_http_client.rs +++ b/raiden/examples/transact_write_with_http_client.rs @@ -45,31 +45,29 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - use aws_smithy_client::{http_connector::ConnectorSettings, hyper_ext}; - let https_connector = hyper_rustls::HttpsConnectorBuilder::new() .with_native_roots() .https_or_http() .enable_http1() .enable_http2() .build(); - let smithy_connector = hyper_ext::Adapter::builder() - .connector_settings( - ConnectorSettings::builder() - .connect_timeout(std::time::Duration::from_secs(5)) - .build(), - ) + let http_client = aws_smithy_runtime::client::http::hyper_014::HyperClientBuilder::new() .build(https_connector); - - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) - .http_connector(smithy_connector) + .endpoint_url("http://localhost:8000") + .http_client(http_client) + .region(raiden::Region::from_static("ap-northeast-1")) + .timeout_config( + aws_config::timeout::TimeoutConfig::builder() + .connect_timeout(std::time::Duration::from_secs(5)) + .build(), + ) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/update.rs b/raiden/examples/update.rs index 46a379a0..ada57c45 100644 --- a/raiden/examples/update.rs +++ b/raiden/examples/update.rs @@ -34,14 +34,15 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/examples/with_http_client.rs b/raiden/examples/with_http_client.rs index 0b878a7c..ce94ef1a 100644 --- a/raiden/examples/with_http_client.rs +++ b/raiden/examples/with_http_client.rs @@ -38,31 +38,29 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - use aws_smithy_client::{http_connector::ConnectorSettings, hyper_ext}; - let https_connector = hyper_rustls::HttpsConnectorBuilder::new() .with_native_roots() .https_or_http() .enable_http1() .enable_http2() .build(); - let smithy_connector = hyper_ext::Adapter::builder() - .connector_settings( - ConnectorSettings::builder() - .connect_timeout(std::time::Duration::from_secs(5)) - .build(), - ) + let http_client = aws_smithy_runtime::client::http::hyper_014::HyperClientBuilder::new() .build(https_connector); - - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) - .http_connector(smithy_connector) + .endpoint_url("http://localhost:8000") + .http_client(http_client) + .region(raiden::Region::from_static("ap-northeast-1")) + .timeout_config( + aws_config::timeout::TimeoutConfig::builder() + .connect_timeout(std::time::Duration::from_secs(5)) + .build(), + ) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/raiden/src/aws_sdk/errors.rs b/raiden/src/aws_sdk/errors.rs index 47db1495..4dba8d38 100644 --- a/raiden/src/aws_sdk/errors.rs +++ b/raiden/src/aws_sdk/errors.rs @@ -1,5 +1,4 @@ -use aws_smithy_http::result::SdkError; -use aws_smithy_runtime_api::client::orchestrator::HttpResponse; +use aws_sdk_dynamodb::error::SdkError; use crate::{ BatchGetItemError, BatchWriteItemError, DeleteItemError, GetItemError, PutItemError, @@ -7,28 +6,26 @@ use crate::{ TransactWriteItemsError, UpdateItemError, }; -type AwsSdkError = SdkError; - -fn into_raiden_error(error: AwsSdkError) -> RaidenError { +fn into_raiden_error(error: SdkError) -> RaidenError { match error { - AwsSdkError::ConstructionFailure(err) => RaidenError::Construction(err), - AwsSdkError::TimeoutError(err) => RaidenError::Timeout(err), - AwsSdkError::DispatchFailure(err) => RaidenError::HttpDispatch(err), - AwsSdkError::ResponseError(err) => RaidenError::Unknown(err.into_raw()), - AwsSdkError::ServiceError(err) => { - // AwsSdkError::ServiceError should be handled ( except for E::Unhandled(_)). + SdkError::ConstructionFailure(err) => RaidenError::Construction(err), + SdkError::TimeoutError(err) => RaidenError::Timeout(err), + SdkError::DispatchFailure(err) => RaidenError::HttpDispatch(err), + SdkError::ResponseError(err) => RaidenError::Unknown(err.into_raw()), + SdkError::ServiceError(err) => { + // SdkError::ServiceError should be handled ( except for E::Unhandled(_)). RaidenError::Unknown(err.into_raw()) } _ => unreachable!( - "Unexpected variant of AwsSdkError detected. Raiden must be handle this variant." + "Unexpected variant of SdkError detected. Raiden must be handle this variant." ), } } -impl From> for RaidenError { - fn from(error: AwsSdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { - AwsSdkError::ServiceError(err) => match err.err() { + SdkError::ServiceError(err) => match err.err() { BatchGetItemError::InternalServerError(err) => { RaidenError::InternalServerError(err.to_string()) } @@ -51,10 +48,10 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: AwsSdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { - AwsSdkError::ServiceError(err) => match err.err() { + SdkError::ServiceError(err) => match err.err() { BatchWriteItemError::InternalServerError(err) => { RaidenError::InternalServerError(err.to_string()) } @@ -80,10 +77,10 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: AwsSdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { - AwsSdkError::ServiceError(err) => match err.err() { + SdkError::ServiceError(err) => match err.err() { GetItemError::InternalServerError(err) => { RaidenError::InternalServerError(err.to_string()) } @@ -106,10 +103,10 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: AwsSdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { - AwsSdkError::ServiceError(err) => match err.err() { + SdkError::ServiceError(err) => match err.err() { QueryError::InternalServerError(err) => { RaidenError::InternalServerError(err.to_string()) } @@ -132,10 +129,10 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: AwsSdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { - AwsSdkError::ServiceError(err) => match err.err() { + SdkError::ServiceError(err) => match err.err() { ScanError::InternalServerError(err) => { RaidenError::InternalServerError(err.to_string()) } @@ -158,10 +155,10 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: AwsSdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { - AwsSdkError::ServiceError(err) => match err.err() { + SdkError::ServiceError(err) => match err.err() { PutItemError::ConditionalCheckFailedException(err) => { RaidenError::ConditionalCheckFailed(err.to_string()) } @@ -193,10 +190,10 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: AwsSdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { - AwsSdkError::ServiceError(err) => match err.err() { + SdkError::ServiceError(err) => match err.err() { UpdateItemError::ConditionalCheckFailedException(err) => { RaidenError::ConditionalCheckFailed(err.to_string()) } @@ -228,10 +225,10 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: AwsSdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { - AwsSdkError::ServiceError(err) => match err.err() { + SdkError::ServiceError(err) => match err.err() { DeleteItemError::ConditionalCheckFailedException(err) => { RaidenError::ConditionalCheckFailed(err.to_string()) } @@ -263,10 +260,10 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: AwsSdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { - AwsSdkError::ServiceError(err) => match err.err() { + SdkError::ServiceError(err) => match err.err() { TransactWriteItemsError::IdempotentParameterMismatchException(err) => { RaidenError::IdempotentParameterMismatch(err.to_string()) } diff --git a/raiden/src/aws_sdk/mod.rs b/raiden/src/aws_sdk/mod.rs index 0d6b510e..aa824a55 100644 --- a/raiden/src/aws_sdk/mod.rs +++ b/raiden/src/aws_sdk/mod.rs @@ -5,6 +5,7 @@ pub(crate) mod serialize; use std::collections::{BTreeSet, HashMap, HashSet}; pub use self::{errors::*, ops::*}; +pub use aws_config::{BehaviorVersion, SdkConfig as AwsSdkConfig}; pub use aws_sdk_dynamodb::{ client::*, config::*, diff --git a/raiden/src/aws_sdk/serialize/delete_request.rs b/raiden/src/aws_sdk/serialize/delete_request.rs index f7abd09c..22be631f 100644 --- a/raiden/src/aws_sdk/serialize/delete_request.rs +++ b/raiden/src/aws_sdk/serialize/delete_request.rs @@ -1,6 +1,6 @@ use std::collections::HashMap; -use serde::de; +use serde::de::{self, Error as _}; use serde_json::{json, Error, Map, Value}; use crate::aws_sdk::serialize::{ @@ -9,9 +9,9 @@ use crate::aws_sdk::serialize::{ pub fn delete_request_to_value(v: &crate::DeleteRequest) -> Value { json!({ - "key": v.key.as_ref().map(|v| v.iter().map(|(k, v)| { + "key": v.key.iter().map(|(k, v)| { (k.clone(), attribute_value_to_value(v)) - }).collect::>()), + }).collect::>(), }) } @@ -32,7 +32,9 @@ pub fn value_to_delete_request(value: Value) -> Result Value { json!({ - "keys": v.keys.as_ref().map(|v| v.iter().map(|v| v.iter().map(|(k, v)| { + "keys": v.keys.iter().map(|v| v.iter().map(|(k, v)| { (k.clone(), attribute_value_to_value(v)) - }).collect::>()).collect::>()), + }).collect::>()).collect::>(), "attributes_to_get": v.attributes_to_get, "consistent_read": v.consistent_read, "projection_expression": v.projection_expression, @@ -82,7 +82,9 @@ pub fn value_to_keys_and_attributes(value: Value) -> Result = (0..101).into_iter().map(|n| format!("id{n}")).collect(); + let keys: Vec = (0..101).map(|n| format!("id{n}")).collect(); let expected_items = (0..101) .map(|n| BatchTest0 { id: format!("id{n}"), @@ -140,7 +140,6 @@ mod tests { async fn example() { let client = crate::all::create_client_from_struct!(BatchTest1); let keys: Vec<(String, usize)> = (0..250) - .into_iter() .map(|n| (format!("id{n}"), (2000 + n) as usize)) .collect(); let expected_items = (0..250) @@ -182,7 +181,6 @@ mod tests { async fn example() { let client = crate::all::create_client_from_struct!(BatchTest1a); let keys: Vec<(String, usize)> = (0..250) - .into_iter() .map(|n| (format!("id{n}"), (2000 + n) as usize)) .collect(); let expected_items = (0..250) diff --git a/raiden/tests/all/mod.rs b/raiden/tests/all/mod.rs index 1f9c4b0f..02124483 100644 --- a/raiden/tests/all/mod.rs +++ b/raiden/tests/all/mod.rs @@ -36,14 +36,15 @@ macro_rules! create_client_from_struct { #[cfg(feature = "aws-sdk")] macro_rules! create_client { ($ty: ty) => {{ - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); @@ -54,14 +55,15 @@ macro_rules! create_client { #[cfg(feature = "aws-sdk")] macro_rules! create_client_from_struct { ($ty: ty) => {{ - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); @@ -84,5 +86,11 @@ fn default_key_and_attributes() -> raiden::KeysAndAttributes { #[cfg(feature = "aws-sdk")] fn default_key_and_attributes() -> raiden::KeysAndAttributes { - raiden::KeysAndAttributes::builder().build() + let mut v = raiden::KeysAndAttributes::builder() + .keys(std::collections::HashMap::new()) + .build() + .expect("should be built"); + + v.keys = vec![]; + v } diff --git a/raiden/tests/all/transact_write.rs b/raiden/tests/all/transact_write.rs index 4216e288..42dd125f 100644 --- a/raiden/tests/all/transact_write.rs +++ b/raiden/tests/all/transact_write.rs @@ -10,14 +10,15 @@ mod tests { #[cfg(feature = "aws-sdk")] fn create_client() -> ::raiden::WriteTx { - let sdk_config = aws_config::SdkConfig::builder() - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + let sdk_config = raiden::AwsSdkConfig::builder() + .behavior_version(raiden::BehaviorVersion::latest()) .credentials_provider( aws_credential_types::provider::SharedCredentialsProvider::new( aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), ), ) + .endpoint_url("http://localhost:8000") + .region(raiden::Region::from_static("ap-northeast-1")) .build(); let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); diff --git a/rust-toolchain b/rust-toolchain index 65ee0959..ee2f4ca9 100644 --- a/rust-toolchain +++ b/rust-toolchain @@ -1 +1 @@ -1.67.0 +1.68.0 From 25a258d0c8158a3fd15524c9183a8dee20c15c11 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Thu, 7 Dec 2023 00:03:35 +0900 Subject: [PATCH 07/22] Some updates fix: creating configuration for aws-sdk-rust. chore: use tokio::test macro. --- raiden/Cargo.toml | 2 +- raiden/examples/delete.rs | 11 +- raiden/examples/get_with_reserved.rs | 11 +- raiden/examples/get_with_retries.rs | 11 +- raiden/examples/hello.rs | 11 +- raiden/examples/last_key.rs | 11 +- raiden/examples/put.rs | 11 +- raiden/examples/query.rs | 11 +- raiden/examples/query_rename.rs | 11 +- raiden/examples/scan.rs | 11 +- raiden/examples/scan_with_filter.rs | 11 +- raiden/examples/transact_write.rs | 11 +- .../transact_write_with_http_client.rs | 11 +- raiden/examples/update.rs | 11 +- raiden/examples/with_http_client.rs | 11 +- raiden/src/aws_sdk/mod.rs | 2 +- raiden/tests/all/batch_delete.rs | 200 ++--- raiden/tests/all/batch_get.rs | 347 ++++---- raiden/tests/all/delete.rs | 66 +- raiden/tests/all/get.rs | 633 ++++++-------- raiden/tests/all/mod.rs | 22 +- raiden/tests/all/put.rs | 338 +++---- raiden/tests/all/query.rs | 764 ++++++++-------- raiden/tests/all/rename.rs | 118 ++- raiden/tests/all/rename_all.rs | 68 +- raiden/tests/all/scan.rs | 270 +++--- raiden/tests/all/transact_write.rs | 350 ++++---- raiden/tests/all/update.rs | 821 ++++++++---------- 28 files changed, 1803 insertions(+), 2352 deletions(-) diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index 67ea6fcf..d8eeef14 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -47,7 +47,7 @@ hyper-rustls = { version = "0.24", default-features = false, features = [ pretty_assertions = "1.4.0" raiden = { path = "./", features = ["tracing"], default_features = false } time = "0.3.30" -tokio = { version = "^1", features = ["rt-multi-thread"] } +tokio = { version = "^1", features = ["rt-multi-thread", "macros"] } tracing-subscriber = { version = "0.3", features = ["env-filter", "time"] } diff --git a/raiden/examples/delete.rs b/raiden/examples/delete.rs index d695d4c3..ef980bf5 100644 --- a/raiden/examples/delete.rs +++ b/raiden/examples/delete.rs @@ -29,16 +29,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = Test::client_with(sdk_client); diff --git a/raiden/examples/get_with_reserved.rs b/raiden/examples/get_with_reserved.rs index 1edce86f..31bfa6d4 100644 --- a/raiden/examples/get_with_reserved.rs +++ b/raiden/examples/get_with_reserved.rs @@ -24,16 +24,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersiontest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = Reserved::client_with(sdk_client); diff --git a/raiden/examples/get_with_retries.rs b/raiden/examples/get_with_retries.rs index 63d30a1b..bb4bc1c5 100644 --- a/raiden/examples/get_with_retries.rs +++ b/raiden/examples/get_with_retries.rs @@ -39,16 +39,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = User::client_with(sdk_client); diff --git a/raiden/examples/hello.rs b/raiden/examples/hello.rs index ecc3cd3a..de164ec8 100644 --- a/raiden/examples/hello.rs +++ b/raiden/examples/hello.rs @@ -39,16 +39,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = User::client_with(sdk_client); diff --git a/raiden/examples/last_key.rs b/raiden/examples/last_key.rs index 80441e6e..65efa789 100644 --- a/raiden/examples/last_key.rs +++ b/raiden/examples/last_key.rs @@ -33,16 +33,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = Test::client_with(sdk_client); diff --git a/raiden/examples/put.rs b/raiden/examples/put.rs index e80c43a5..8703d15b 100644 --- a/raiden/examples/put.rs +++ b/raiden/examples/put.rs @@ -74,16 +74,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = User::client_with(sdk_client); diff --git a/raiden/examples/query.rs b/raiden/examples/query.rs index 8a1dc9d1..d1193621 100644 --- a/raiden/examples/query.rs +++ b/raiden/examples/query.rs @@ -46,16 +46,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = QueryTestData0::client_with(sdk_client); diff --git a/raiden/examples/query_rename.rs b/raiden/examples/query_rename.rs index 0638daca..947cebb3 100644 --- a/raiden/examples/query_rename.rs +++ b/raiden/examples/query_rename.rs @@ -32,16 +32,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = Project::client_with(sdk_client); diff --git a/raiden/examples/scan.rs b/raiden/examples/scan.rs index 17a5285a..a12c70a3 100644 --- a/raiden/examples/scan.rs +++ b/raiden/examples/scan.rs @@ -27,16 +27,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = ScanTestData0::client_with(sdk_client); diff --git a/raiden/examples/scan_with_filter.rs b/raiden/examples/scan_with_filter.rs index ccad087d..05cf7c7a 100644 --- a/raiden/examples/scan_with_filter.rs +++ b/raiden/examples/scan_with_filter.rs @@ -28,16 +28,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = Scan::client_with(sdk_client); diff --git a/raiden/examples/transact_write.rs b/raiden/examples/transact_write.rs index 9f03aa63..182cc231 100644 --- a/raiden/examples/transact_write.rs +++ b/raiden/examples/transact_write.rs @@ -36,16 +36,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let tx = ::raiden::WriteTx::new_with_client(sdk_client); diff --git a/raiden/examples/transact_write_with_http_client.rs b/raiden/examples/transact_write_with_http_client.rs index 2cd84a57..cdfc5cb0 100644 --- a/raiden/examples/transact_write_with_http_client.rs +++ b/raiden/examples/transact_write_with_http_client.rs @@ -53,13 +53,7 @@ async fn example() { .build(); let http_client = aws_smithy_runtime::client::http::hyper_014::HyperClientBuilder::new() .build(https_connector); - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .http_client(http_client) .region(raiden::Region::from_static("ap-northeast-1")) @@ -68,7 +62,8 @@ async fn example() { .connect_timeout(std::time::Duration::from_secs(5)) .build(), ) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let tx = ::raiden::WriteTx::new_with_client(sdk_client); diff --git a/raiden/examples/update.rs b/raiden/examples/update.rs index ada57c45..9a1ff24e 100644 --- a/raiden/examples/update.rs +++ b/raiden/examples/update.rs @@ -34,16 +34,11 @@ async fn example() { #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = Example::client_with(sdk_client); diff --git a/raiden/examples/with_http_client.rs b/raiden/examples/with_http_client.rs index ce94ef1a..196ba6dc 100644 --- a/raiden/examples/with_http_client.rs +++ b/raiden/examples/with_http_client.rs @@ -46,13 +46,7 @@ async fn example() { .build(); let http_client = aws_smithy_runtime::client::http::hyper_014::HyperClientBuilder::new() .build(https_connector); - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .http_client(http_client) .region(raiden::Region::from_static("ap-northeast-1")) @@ -61,7 +55,8 @@ async fn example() { .connect_timeout(std::time::Duration::from_secs(5)) .build(), ) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); let client = User::client_with(sdk_client); diff --git a/raiden/src/aws_sdk/mod.rs b/raiden/src/aws_sdk/mod.rs index aa824a55..54cfb255 100644 --- a/raiden/src/aws_sdk/mod.rs +++ b/raiden/src/aws_sdk/mod.rs @@ -5,7 +5,7 @@ pub(crate) mod serialize; use std::collections::{BTreeSet, HashMap, HashSet}; pub use self::{errors::*, ops::*}; -pub use aws_config::{BehaviorVersion, SdkConfig as AwsSdkConfig}; +pub use aws_config as config; pub use aws_sdk_dynamodb::{ client::*, config::*, diff --git a/raiden/tests/all/batch_delete.rs b/raiden/tests/all/batch_delete.rs index 84323938..8293cced 100644 --- a/raiden/tests/all/batch_delete.rs +++ b/raiden/tests/all/batch_delete.rs @@ -12,68 +12,52 @@ mod partition_key_tests { name: String, } - #[test] - fn test_batch_delete_item() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchDeleteTest0); - let res: batch_delete::BatchDeleteOutput = client - .batch_delete(vec!["id0", "id1", "id2"]) - .run() - .await - .unwrap(); - - assert_eq!( - res, - batch_delete::BatchDeleteOutput { - consumed_capacity: None, - unprocessed_items: vec![], - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_delete_item() { + let client = crate::all::create_client_from_struct!(BatchDeleteTest0); + let res: batch_delete::BatchDeleteOutput = client + .batch_delete(vec!["id0", "id1", "id2"]) + .run() + .await + .unwrap(); + + assert_eq!( + res, + batch_delete::BatchDeleteOutput { + consumed_capacity: None, + unprocessed_items: vec![], + } + ); } - #[test] - fn test_batch_delete_item_for_stored_and_unstored_keys() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchDeleteTest0); - let res = client.batch_delete(vec!["id3", "unstored"]).run().await; + #[tokio::test] + async fn test_batch_delete_item_for_stored_and_unstored_keys() { + let client = crate::all::create_client_from_struct!(BatchDeleteTest0); + let res = client.batch_delete(vec!["id3", "unstored"]).run().await; - assert!(res.is_ok()); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert!(res.is_ok()); } - #[test] - fn test_batch_delete_item_for_unstored_keys() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchDeleteTest0); - let res = client - .batch_delete(vec!["unstored0", "unstored1", "unstored2"]) - .run() - .await; - - assert!(res.is_ok()); - } + #[tokio::test] + async fn test_batch_delete_item_for_unstored_keys() { + let client = crate::all::create_client_from_struct!(BatchDeleteTest0); + let res = client + .batch_delete(vec!["unstored0", "unstored1", "unstored2"]) + .run() + .await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert!(res.is_ok()); } - #[test] - fn test_batch_delete_over_25_items() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchDeleteTest0); - let res = client - .batch_delete((4..=100).map(|i| format!("id{i}")).collect()) - .run() - .await; + #[tokio::test] + async fn test_batch_delete_over_25_items() { + let client = crate::all::create_client_from_struct!(BatchDeleteTest0); + let res = client + .batch_delete((4..=100).map(|i| format!("id{i}")).collect()) + .run() + .await; - assert!(res.is_ok()); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert!(res.is_ok()); } } @@ -91,75 +75,59 @@ mod partition_key_and_sort_key_tests { year: usize, } - #[test] - fn test_batch_delete_item_with_sort_key() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchDeleteTest1); - let res = client - .batch_delete(vec![ - ("id0", 1999_usize), - ("id1", 2000_usize), - ("id2", 2001_usize), - ]) - .run() - .await; - - assert!(res.is_ok()); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_delete_item_with_sort_key() { + let client = crate::all::create_client_from_struct!(BatchDeleteTest1); + let res = client + .batch_delete(vec![ + ("id0", 1999_usize), + ("id1", 2000_usize), + ("id2", 2001_usize), + ]) + .run() + .await; + + assert!(res.is_ok()); } - #[test] - fn test_batch_delete_item_with_sort_key_for_stored_and_unstored_keys() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchDeleteTest1); - let res = client - .batch_delete(vec![("id3", 2002_usize), ("unstored", 2000_usize)]) - .run() - .await; - - assert!(res.is_ok()); - } + #[tokio::test] + async fn test_batch_delete_item_with_sort_key_for_stored_and_unstored_keys() { + let client = crate::all::create_client_from_struct!(BatchDeleteTest1); + let res = client + .batch_delete(vec![("id3", 2002_usize), ("unstored", 2000_usize)]) + .run() + .await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert!(res.is_ok()); } - #[test] - fn test_batch_delete_item_with_sort_key_for_unstored_keys() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchDeleteTest1); - let res = client - .batch_delete(vec![ - ("unstored0", 1999_usize), - ("unstore1", 2000_usize), - ("unstored2", 2001_usize), - ]) - .run() - .await; - - assert!(res.is_ok()); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_delete_item_with_sort_key_for_unstored_keys() { + let client = crate::all::create_client_from_struct!(BatchDeleteTest1); + let res = client + .batch_delete(vec![ + ("unstored0", 1999_usize), + ("unstore1", 2000_usize), + ("unstored2", 2001_usize), + ]) + .run() + .await; + + assert!(res.is_ok()); } - #[test] - fn test_batch_delete_with_sort_key_over_25_items() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchDeleteTest1); - let res = client - .batch_delete( - (4..=100) - .map(|i| (format!("id{i}"), 1999_usize + i)) - .collect(), - ) - .run() - .await; - - assert!(res.is_ok()); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_delete_with_sort_key_over_25_items() { + let client = crate::all::create_client_from_struct!(BatchDeleteTest1); + let res = client + .batch_delete( + (4..=100) + .map(|i| (format!("id{i}"), 1999_usize + i)) + .collect(), + ) + .run() + .await; + + assert!(res.is_ok()); } } diff --git a/raiden/tests/all/batch_get.rs b/raiden/tests/all/batch_get.rs index 86519753..7fb005ec 100644 --- a/raiden/tests/all/batch_get.rs +++ b/raiden/tests/all/batch_get.rs @@ -23,95 +23,83 @@ mod tests { batch_get::BatchGetOutput { ..output } } - #[test] - fn test_batch_get_item() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchTest0); - let res: batch_get::BatchGetOutput = client - .batch_get(vec!["id0", "id1", "id2"]) - .run() - .await - .unwrap(); - - assert_eq!( - sort_by_id_0(res), - batch_get::BatchGetOutput { - items: vec![ - BatchTest0 { - id: "id0".to_owned(), - name: "bob".to_owned(), - }, - BatchTest0 { - id: "id1".to_owned(), - name: "bob".to_owned(), - }, - BatchTest0 { - id: "id2".to_owned(), - name: "bob".to_owned(), - }, - ], - consumed_capacity: None, - unprocessed_keys: Some(crate::all::default_key_and_attributes()), - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_get_item() { + let client = crate::all::create_client_from_struct!(BatchTest0); + let res: batch_get::BatchGetOutput = client + .batch_get(vec!["id0", "id1", "id2"]) + .run() + .await + .unwrap(); + + assert_eq!( + sort_by_id_0(res), + batch_get::BatchGetOutput { + items: vec![ + BatchTest0 { + id: "id0".to_owned(), + name: "bob".to_owned(), + }, + BatchTest0 { + id: "id1".to_owned(), + name: "bob".to_owned(), + }, + BatchTest0 { + id: "id2".to_owned(), + name: "bob".to_owned(), + }, + ], + consumed_capacity: None, + unprocessed_keys: Some(crate::all::default_key_and_attributes()), + } + ); } - #[test] - fn test_batch_get_item_extended() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchTest0); - let keys: Vec = (0..101).map(|n| format!("id{n}")).collect(); - let expected_items = (0..101) - .map(|n| BatchTest0 { - id: format!("id{n}"), - name: "bob".to_owned(), - }) - .collect(); - let res: batch_get::BatchGetOutput = - client.batch_get(keys).run().await.unwrap(); - - assert_eq!( - sort_by_id_0(res), - batch_get::BatchGetOutput { - items: expected_items, - consumed_capacity: None, - unprocessed_keys: Some(crate::all::default_key_and_attributes()), - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_get_item_extended() { + let client = crate::all::create_client_from_struct!(BatchTest0); + let keys: Vec = (0..101).map(|n| format!("id{n}")).collect(); + let expected_items = (0..101) + .map(|n| BatchTest0 { + id: format!("id{n}"), + name: "bob".to_owned(), + }) + .collect(); + let res: batch_get::BatchGetOutput = + client.batch_get(keys).run().await.unwrap(); + + assert_eq!( + sort_by_id_0(res), + batch_get::BatchGetOutput { + items: expected_items, + consumed_capacity: None, + unprocessed_keys: Some(crate::all::default_key_and_attributes()), + } + ); } // NOTE: Same behavior with original SDK, but we're planning to improve this. // ref. https://github.com/raiden-rs/raiden/issues/44 - #[test] - fn test_batch_get_item_partial_missing() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchTest0); - let res: batch_get::BatchGetOutput = client - .batch_get(vec!["id100", "id101", "id102"]) - .run() - .await - .unwrap(); - - assert_eq!( - sort_by_id_0(res), - batch_get::BatchGetOutput { - items: vec![BatchTest0 { - id: "id100".to_owned(), - name: "bob".to_owned(), - },], - consumed_capacity: None, - unprocessed_keys: Some(crate::all::default_key_and_attributes()), - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_get_item_partial_missing() { + let client = crate::all::create_client_from_struct!(BatchTest0); + let res: batch_get::BatchGetOutput = client + .batch_get(vec!["id100", "id101", "id102"]) + .run() + .await + .unwrap(); + + assert_eq!( + sort_by_id_0(res), + batch_get::BatchGetOutput { + items: vec![BatchTest0 { + id: "id100".to_owned(), + name: "bob".to_owned(), + },], + consumed_capacity: None, + unprocessed_keys: Some(crate::all::default_key_and_attributes()), + } + ); } #[derive(Raiden, Debug, PartialEq)] @@ -135,35 +123,31 @@ mod tests { batch_get::BatchGetOutput { ..output } } - #[test] - fn test_batch_get_item_sort_key() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchTest1); - let keys: Vec<(String, usize)> = (0..250) - .map(|n| (format!("id{n}"), (2000 + n) as usize)) - .collect(); - let expected_items = (0..250) - .map(|n| BatchTest1 { - id: format!("id{n}"), - name: "bob".to_owned(), - year: (2000 + n), - num: n, - }) - .collect(); - let res: batch_get::BatchGetOutput = - client.batch_get(keys).run().await.unwrap(); - - assert_eq!( - sort_by_id_1(res), - batch_get::BatchGetOutput { - items: expected_items, - consumed_capacity: None, - unprocessed_keys: Some(crate::all::default_key_and_attributes()), - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_get_item_sort_key() { + let client = crate::all::create_client_from_struct!(BatchTest1); + let keys: Vec<(String, usize)> = (0..250) + .map(|n| (format!("id{n}"), (2000 + n) as usize)) + .collect(); + let expected_items = (0..250) + .map(|n| BatchTest1 { + id: format!("id{n}"), + name: "bob".to_owned(), + year: (2000 + n), + num: n, + }) + .collect(); + let res: batch_get::BatchGetOutput = + client.batch_get(keys).run().await.unwrap(); + + assert_eq!( + sort_by_id_1(res), + batch_get::BatchGetOutput { + items: expected_items, + consumed_capacity: None, + unprocessed_keys: Some(crate::all::default_key_and_attributes()), + } + ); } #[derive(Raiden, Debug, PartialEq)] @@ -176,66 +160,58 @@ mod tests { year: usize, } - #[test] - fn test_batch_get_item_for_projection_expression() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchTest1a); - let keys: Vec<(String, usize)> = (0..250) - .map(|n| (format!("id{n}"), (2000 + n) as usize)) - .collect(); - let expected_items = (0..250) - .map(|n| BatchTest1a { - id: format!("id{n}"), - name: "bob".to_owned(), - year: 2000 + n as usize, - }) - .collect(); - let mut res: batch_get::BatchGetOutput = - client.batch_get(keys).run().await.unwrap(); - res.items.sort_by_key(|i| { - let mut id = i.id.to_string(); - id.replace_range(0..2, ""); - id.parse::().unwrap() - }); - - assert_eq!( - res, - batch_get::BatchGetOutput { - items: expected_items, - consumed_capacity: None, - unprocessed_keys: Some(crate::all::default_key_and_attributes()), - } - ); - } + #[tokio::test] + async fn test_batch_get_item_for_projection_expression() { + let client = crate::all::create_client_from_struct!(BatchTest1a); + let keys: Vec<(String, usize)> = (0..250) + .map(|n| (format!("id{n}"), (2000 + n) as usize)) + .collect(); + let expected_items = (0..250) + .map(|n| BatchTest1a { + id: format!("id{n}"), + name: "bob".to_owned(), + year: 2000 + n as usize, + }) + .collect(); + let mut res: batch_get::BatchGetOutput = + client.batch_get(keys).run().await.unwrap(); + res.items.sort_by_key(|i| { + let mut id = i.id.to_string(); + id.replace_range(0..2, ""); + id.parse::().unwrap() + }); - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res, + batch_get::BatchGetOutput { + items: expected_items, + consumed_capacity: None, + unprocessed_keys: Some(crate::all::default_key_and_attributes()), + } + ); } - #[test] - fn test_batch_get_item_missing_all() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchTest1); - let res: batch_get::BatchGetOutput = client - .batch_get(vec![ - ("id300", 2300_usize), - ("id301", 2301_usize), - ("id302", 2302_usize), - ]) - .run() - .await - .unwrap(); - - assert_eq!( - sort_by_id_1(res), - batch_get::BatchGetOutput { - items: vec![], - consumed_capacity: None, - unprocessed_keys: Some(crate::all::default_key_and_attributes()), - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_get_item_missing_all() { + let client = crate::all::create_client_from_struct!(BatchTest1); + let res: batch_get::BatchGetOutput = client + .batch_get(vec![ + ("id300", 2300_usize), + ("id301", 2301_usize), + ("id302", 2302_usize), + ]) + .run() + .await + .unwrap(); + + assert_eq!( + sort_by_id_1(res), + batch_get::BatchGetOutput { + items: vec![], + consumed_capacity: None, + unprocessed_keys: Some(crate::all::default_key_and_attributes()), + } + ); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -244,24 +220,21 @@ mod tests { id: String, name: String, } - #[test] - fn test_batch_get_item_with_16mb_limitation() { - async fn example() { - let client = crate::all::create_client_from_struct!(BatchTest2); - let res: batch_get::BatchGetOutput = client - .batch_get(vec![ - "id0", "id1", "id2", "id3", "id4", "id5", "id6", "id7", "id8", "id9", "id10", - "id11", "id12", "id13", "id14", "id15", "id16", "id17", "id18", "id19", "id20", - "id21", "id22", "id23", "id24", "id25", "id26", "id27", "id28", "id29", "id30", - "id31", "id32", "id33", "id34", "id35", "id36", "id37", "id38", "id39", "id40", - "id41", "id42", "id43", "id44", "id45", "id46", "id47", "id48", "id49", "id50", - ]) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 51); - } - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_batch_get_item_with_16mb_limitation() { + let client = crate::all::create_client_from_struct!(BatchTest2); + let res: batch_get::BatchGetOutput = client + .batch_get(vec![ + "id0", "id1", "id2", "id3", "id4", "id5", "id6", "id7", "id8", "id9", "id10", + "id11", "id12", "id13", "id14", "id15", "id16", "id17", "id18", "id19", "id20", + "id21", "id22", "id23", "id24", "id25", "id26", "id27", "id28", "id29", "id30", + "id31", "id32", "id33", "id34", "id35", "id36", "id37", "id38", "id39", "id40", + "id41", "id42", "id43", "id44", "id45", "id46", "id47", "id48", "id49", "id50", + ]) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 51); } } diff --git a/raiden/tests/all/delete.rs b/raiden/tests/all/delete.rs index 8af25539..9054adcc 100644 --- a/raiden/tests/all/delete.rs +++ b/raiden/tests/all/delete.rs @@ -14,44 +14,32 @@ mod tests { removable: bool, } - #[test] - fn test_delete_item() { - async fn example() { - let client = crate::all::create_client_from_struct!(DeleteTest0); - let res = client.delete("id0").run().await; + #[tokio::test] + async fn test_delete_item() { + let client = crate::all::create_client_from_struct!(DeleteTest0); + let res = client.delete("id0").run().await; - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.is_ok(), true); } - #[test] - fn test_delete_item_with_unstored_key() { - async fn example() { - let client = crate::all::create_client_from_struct!(DeleteTest0); - let res = client.delete("unstored").run().await; - - assert_eq!(res.is_ok(), true); - } + #[tokio::test] + async fn test_delete_item_with_unstored_key() { + let client = crate::all::create_client_from_struct!(DeleteTest0); + let res = client.delete("unstored").run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.is_ok(), true); } - #[test] - fn test_delete_item_with_condition() { - async fn example() { - let client = crate::all::create_client_from_struct!(DeleteTest0); - let cond = DeleteTest0::condition() - .attr(DeleteTest0::removable()) - .eq_value(true); - let res = client.delete("id0").condition(cond.clone()).run().await; - assert_eq!(res.is_ok(), false); - let res = client.delete("id1").condition(cond).run().await; - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_delete_item_with_condition() { + let client = crate::all::create_client_from_struct!(DeleteTest0); + let cond = DeleteTest0::condition() + .attr(DeleteTest0::removable()) + .eq_value(true); + let res = client.delete("id0").condition(cond.clone()).run().await; + assert_eq!(res.is_ok(), false); + let res = client.delete("id1").condition(cond).run().await; + assert_eq!(res.is_ok(), true); } #[allow(dead_code)] @@ -64,15 +52,11 @@ mod tests { year: usize, } - #[test] - fn test_delete_item_with_sort_key() { - async fn example() { - let client = crate::all::create_client_from_struct!(DeleteTest1); - let res = client.delete("id0", 1999_usize).run().await; - - assert_eq!(res.is_ok(), true); - } + #[tokio::test] + async fn test_delete_item_with_sort_key() { + let client = crate::all::create_client_from_struct!(DeleteTest1); + let res = client.delete("id0", 1999_usize).run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.is_ok(), true); } } diff --git a/raiden/tests/all/get.rs b/raiden/tests/all/get.rs index 673c55c8..db664eea 100644 --- a/raiden/tests/all/get.rs +++ b/raiden/tests/all/get.rs @@ -19,74 +19,62 @@ mod tests { option_i16: Option, } - #[test] - fn test_user_get_item() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let res = client.get("user_primary_key").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: User { - id: "user_primary_key".to_owned(), - name: "bokuweb".to_owned(), - num_usize: 42, - num_u8: 255, - num_i8: -127, - option_u16: None, - option_i16: Some(-1), - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); - } - - #[test] - fn test_user_get_item_with_consistent_read() { - async fn example() { - let client = crate::all::create_client!(UserClient); - let res = client.get("user_primary_key").consistent().run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: User { - id: "user_primary_key".to_owned(), - name: "bokuweb".to_owned(), - num_usize: 42, - num_u8: 255, - num_i8: -127, - option_u16: None, - option_i16: Some(-1), - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_user_get_item() { + let client = crate::all::create_client_from_struct!(User); + let res = client.get("user_primary_key").run().await; + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: User { + id: "user_primary_key".to_owned(), + name: "bokuweb".to_owned(), + num_usize: 42, + num_u8: 255, + num_i8: -127, + option_u16: None, + option_i16: Some(-1), + }, + consumed_capacity: None, + } + ); + } + + #[tokio::test] + async fn test_user_get_item_with_consistent_read() { + let client = crate::all::create_client!(UserClient); + let res = client.get("user_primary_key").consistent().run().await; + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: User { + id: "user_primary_key".to_owned(), + name: "bokuweb".to_owned(), + num_usize: 42, + num_u8: 255, + num_i8: -127, + option_u16: None, + option_i16: Some(-1), + }, + consumed_capacity: None, + } + ); } - #[test] - fn test_user_get_item_with_not_found_error() { - async fn example() { - let client = crate::all::create_client!(UserClient); - let res = client.get("not_exist_key").consistent().run().await; + #[tokio::test] + async fn test_user_get_item_with_not_found_error() { + let client = crate::all::create_client!(UserClient); + let res = client.get("not_exist_key").consistent().run().await; - assert!(res.is_err()); + assert!(res.is_err()); - if let RaidenError::ResourceNotFound(msg) = res.unwrap_err() { - assert_eq!("resource not found", msg); - } else { - panic!("err should be RaidenError::ResourceNotFound"); - } + if let RaidenError::ResourceNotFound(msg) = res.unwrap_err() { + assert_eq!("resource not found", msg); + } else { + panic!("err should be RaidenError::ResourceNotFound"); } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -99,22 +87,18 @@ mod tests { unstored: usize, } - #[test] - fn test_get_unstored_value() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserWithUnStored); - let res = client.get("user_primary_key").consistent().run().await; + #[tokio::test] + async fn test_get_unstored_value() { + let client = crate::all::create_client_from_struct!(UserWithUnStored); + let res = client.get("user_primary_key").consistent().run().await; - assert!(res.is_err()); + assert!(res.is_err()); - if let RaidenError::AttributeConvertError { attr_name } = res.unwrap_err() { - assert_eq!("unstored", attr_name); - } else { - panic!("err should be RaidenError::AttributeConvertError"); - } + if let RaidenError::AttributeConvertError { attr_name } = res.unwrap_err() { + assert_eq!("unstored", attr_name); + } else { + panic!("err should be RaidenError::AttributeConvertError"); } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); } #[derive(Raiden)] @@ -127,26 +111,22 @@ mod tests { empty_set: std::collections::HashSet, } - #[test] - fn test_get_empty_hashset() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserWithEmptyHashSet); - let res = client.get("user_primary_key").consistent().run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: UserWithEmptyHashSet { - id: "user_primary_key".to_owned(), - name: "bokuweb".to_owned(), - empty_set: std::collections::HashSet::new(), - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_get_empty_hashset() { + let client = crate::all::create_client_from_struct!(UserWithEmptyHashSet); + let res = client.get("user_primary_key").consistent().run().await; + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: UserWithEmptyHashSet { + id: "user_primary_key".to_owned(), + name: "bokuweb".to_owned(), + empty_set: std::collections::HashSet::new(), + }, + consumed_capacity: None, + } + ); } #[derive(Raiden)] @@ -159,26 +139,22 @@ mod tests { empty_vec: Vec, } - #[test] - fn test_get_empty_vec() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserWithEmptyVec); - let res = client.get("user_primary_key").consistent().run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: UserWithEmptyVec { - id: "user_primary_key".to_owned(), - name: "bokuweb".to_owned(), - empty_vec: vec![], - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_get_empty_vec() { + let client = crate::all::create_client_from_struct!(UserWithEmptyVec); + let res = client.get("user_primary_key").consistent().run().await; + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: UserWithEmptyVec { + id: "user_primary_key".to_owned(), + name: "bokuweb".to_owned(), + empty_vec: vec![], + }, + consumed_capacity: None, + } + ); } #[derive(Raiden)] @@ -191,28 +167,24 @@ mod tests { string_set: std::collections::HashSet, } - #[test] - fn test_get_stringset() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserWithStringSet); - let res = client.get("user_primary_key").consistent().run().await; - let mut set = std::collections::HashSet::new(); - set.insert("Hello".to_owned()); - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: UserWithStringSet { - id: "user_primary_key".to_owned(), - name: "bokuweb".to_owned(), - string_set: set, - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_get_stringset() { + let client = crate::all::create_client_from_struct!(UserWithStringSet); + let res = client.get("user_primary_key").consistent().run().await; + let mut set = std::collections::HashSet::new(); + set.insert("Hello".to_owned()); + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: UserWithStringSet { + id: "user_primary_key".to_owned(), + name: "bokuweb".to_owned(), + string_set: set, + }, + consumed_capacity: None, + } + ); } #[derive(Raiden)] @@ -225,28 +197,24 @@ mod tests { string_set: std::collections::BTreeSet, } - #[test] - fn test_get_btree_stringset() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserWithStringBTreeSet); - let res = client.get("user_primary_key").consistent().run().await; - let mut set = std::collections::BTreeSet::new(); - set.insert("Hello".to_owned()); - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: UserWithStringBTreeSet { - id: "user_primary_key".to_owned(), - name: "bokuweb".to_owned(), - string_set: set, - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_get_btree_stringset() { + let client = crate::all::create_client_from_struct!(UserWithStringBTreeSet); + let res = client.get("user_primary_key").consistent().run().await; + let mut set = std::collections::BTreeSet::new(); + set.insert("Hello".to_owned()); + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: UserWithStringBTreeSet { + id: "user_primary_key".to_owned(), + name: "bokuweb".to_owned(), + string_set: set, + }, + consumed_capacity: None, + } + ); } #[derive(Debug, Clone, PartialEq, Eq, Hash)] @@ -274,28 +242,24 @@ mod tests { pub string_set: std::collections::HashSet, } - #[test] - fn test_get_custom_stringset() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserWithCustomStringSet); - let res = client.get("user_primary_key").consistent().run().await; - let mut set = std::collections::HashSet::new(); - set.insert(CustomSSItem("Hello".to_owned())); - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: UserWithCustomStringSet { - id: "user_primary_key".to_owned(), - name: "bokuweb".to_owned(), - string_set: set, - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_get_custom_stringset() { + let client = crate::all::create_client_from_struct!(UserWithCustomStringSet); + let res = client.get("user_primary_key").consistent().run().await; + let mut set = std::collections::HashSet::new(); + set.insert(CustomSSItem("Hello".to_owned())); + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: UserWithCustomStringSet { + id: "user_primary_key".to_owned(), + name: "bokuweb".to_owned(), + string_set: set, + }, + consumed_capacity: None, + } + ); } #[derive(Raiden, Debug, PartialEq)] @@ -309,27 +273,23 @@ mod tests { num: usize, } - #[test] - fn test_user_get_item_with_sort_key() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserWithSortKey); - let res = client.get("id1", 2003_usize).run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: UserWithSortKey { - id: "id1".to_owned(), - name: "bob".to_owned(), - year: 2003, - num: 300, - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_user_get_item_with_sort_key() { + let client = crate::all::create_client_from_struct!(UserWithSortKey); + let res = client.get("id1", 2003_usize).run().await; + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: UserWithSortKey { + id: "id1".to_owned(), + name: "bob".to_owned(), + year: 2003, + num: 300, + }, + consumed_capacity: None, + } + ); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -340,25 +300,21 @@ mod tests { name: String, } - #[test] - fn test_get_empty_string() { - async fn example() { - let client = crate::all::create_client_from_struct!(EmptyStringTestData0); - let res = client.get("id0").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: EmptyStringTestData0 { - id: "id0".to_owned(), - name: "".to_owned(), - }, - consumed_capacity: None, - } - ); - } + #[tokio::test] + async fn test_get_empty_string() { + let client = crate::all::create_client_from_struct!(EmptyStringTestData0); + let res = client.get("id0").run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + get::GetOutput { + item: EmptyStringTestData0 { + id: "id0".to_owned(), + name: "".to_owned(), + }, + consumed_capacity: None, + } + ); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -370,25 +326,21 @@ mod tests { flag: bool, } - #[test] - fn test_use_default_for_null() { - async fn example() { - let client = crate::all::create_client_from_struct!(UseDefaultForNull); - let res = client.get("id0").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: UseDefaultForNull { - id: "id0".to_owned(), - flag: false, - }, - consumed_capacity: None, - } - ); - } + #[tokio::test] + async fn test_use_default_for_null() { + let client = crate::all::create_client_from_struct!(UseDefaultForNull); + let res = client.get("id0").run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + get::GetOutput { + item: UseDefaultForNull { + id: "id0".to_owned(), + flag: false, + }, + consumed_capacity: None, + } + ); } use std::sync::atomic::{AtomicUsize, Ordering}; @@ -407,31 +359,24 @@ mod tests { } } - #[test] - fn test_retry() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let _ = client - .with_retries(Box::new(MyRetryStrategy)) - .get("anonymous") - .run() - .await; - } + #[tokio::test] + async fn test_retry() { + let client = crate::all::create_client_from_struct!(User); + let _ = client + .with_retries(Box::new(MyRetryStrategy)) + .get("anonymous") + .run() + .await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); assert_eq!(RETRY_COUNT.load(Ordering::Relaxed), 4) } - #[test] - fn test_should_build_with_twice_retry() { - async fn example() { - let client = crate::all::create_client_from_struct!(User) - .with_retries(Box::new(MyRetryStrategy)); - let _ = client.get("anonymous").run().await; - let _ = client.get("anonymous").run().await; - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_should_build_with_twice_retry() { + let client = + crate::all::create_client_from_struct!(User).with_retries(Box::new(MyRetryStrategy)); + let _ = client.get("anonymous").run().await; + let _ = client.get("anonymous").run().await; } #[derive(Raiden)] @@ -444,26 +389,22 @@ mod tests { num_usize: usize, } - #[test] - fn test_user_get_item_for_projection_expression() { - async fn example() { - let client = crate::all::create_client_from_struct!(PartialUser); - let res = client.get("user_primary_key").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: PartialUser { - id: "user_primary_key".to_owned(), - name: "bokuweb".to_owned(), - num_usize: 42, - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_user_get_item_for_projection_expression() { + let client = crate::all::create_client_from_struct!(PartialUser); + let res = client.get("user_primary_key").run().await; + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: PartialUser { + id: "user_primary_key".to_owned(), + name: "bokuweb".to_owned(), + num_usize: 42, + }, + consumed_capacity: None, + } + ); } #[derive(Raiden)] @@ -476,25 +417,21 @@ mod tests { r#type: String, } - #[test] - fn test_reserved_keyword() { - async fn example() { - let client = crate::all::create_client_from_struct!(Reserved); - let res = client.get("id0").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: Reserved { - id: "id0".to_owned(), - r#type: "reserved".to_owned(), - }, - consumed_capacity: None, - } - ); - } + #[tokio::test] + async fn test_reserved_keyword() { + let client = crate::all::create_client_from_struct!(Reserved); + let res = client.get("id0").run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + get::GetOutput { + item: Reserved { + id: "id0".to_owned(), + r#type: "reserved".to_owned(), + }, + consumed_capacity: None, + } + ); } #[derive(Raiden)] @@ -507,25 +444,21 @@ mod tests { some_type: String, } - #[test] - fn test_rename_with_reserved() { - async fn example() { - let client = crate::all::create_client_from_struct!(ReservedWithRename); - let res = client.get("id0").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: ReservedWithRename { - id: "id0".to_owned(), - some_type: "reserved".to_owned(), - }, - consumed_capacity: None, - } - ); - } + #[tokio::test] + async fn test_rename_with_reserved() { + let client = crate::all::create_client_from_struct!(ReservedWithRename); + let res = client.get("id0").run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + get::GetOutput { + item: ReservedWithRename { + id: "id0".to_owned(), + some_type: "reserved".to_owned(), + }, + consumed_capacity: None, + } + ); } #[derive(Raiden)] @@ -538,25 +471,21 @@ mod tests { is_ok: bool, } - #[test] - fn test_use_default() { - async fn example() { - let client = crate::all::create_client_from_struct!(UseDefault); - let res = client.get("id0").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: UseDefault { - id: "id0".to_owned(), - is_ok: false, - }, - consumed_capacity: None, - } - ); - } + #[tokio::test] + async fn test_use_default() { + let client = crate::all::create_client_from_struct!(UseDefault); + let res = client.get("id0").run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + get::GetOutput { + item: UseDefault { + id: "id0".to_owned(), + is_ok: false, + }, + consumed_capacity: None, + } + ); } #[derive(Raiden)] @@ -569,25 +498,21 @@ mod tests { float64: f64, } - #[test] - fn test_float() { - async fn example() { - let client = crate::all::create_client_from_struct!(FloatTest); - let res = client.get("primary_key").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: FloatTest { - id: "primary_key".to_owned(), - float32: 1.23, - float64: 2.34, - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_float() { + let client = crate::all::create_client_from_struct!(FloatTest); + let res = client.get("primary_key").run().await; + + assert_eq!( + res.unwrap(), + get::GetOutput { + item: FloatTest { + id: "primary_key".to_owned(), + float32: 1.23, + float64: 2.34, + }, + consumed_capacity: None, + } + ); } } diff --git a/raiden/tests/all/mod.rs b/raiden/tests/all/mod.rs index 02124483..623d2edb 100644 --- a/raiden/tests/all/mod.rs +++ b/raiden/tests/all/mod.rs @@ -36,16 +36,11 @@ macro_rules! create_client_from_struct { #[cfg(feature = "aws-sdk")] macro_rules! create_client { ($ty: ty) => {{ - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); <$ty>::new_with_client(sdk_client) @@ -55,16 +50,11 @@ macro_rules! create_client { #[cfg(feature = "aws-sdk")] macro_rules! create_client_from_struct { ($ty: ty) => {{ - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); <$ty>::client_with(sdk_client) diff --git a/raiden/tests/all/put.rs b/raiden/tests/all/put.rs index 956464f0..cfc2578e 100644 --- a/raiden/tests/all/put.rs +++ b/raiden/tests/all/put.rs @@ -26,8 +26,8 @@ mod tests { name: String, } - #[test] - fn test_put_user_with_attribute_not_exists_condition_input() { + #[tokio::test] + async fn test_put_user_with_attribute_not_exists_condition_input() { let client = crate::all::create_client_from_struct!(User); let user = UserPutItemInput { id: "mock_id".to_owned(), @@ -75,32 +75,24 @@ mod tests { assert_eq!(input, expected); } - #[test] - fn test_put_user() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let user = UserPutItemInput { - id: "mock_id".to_owned(), - name: "bokuweb".to_owned(), - }; - let _res = client.put(user).run().await; - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_user() { + let client = crate::all::create_client_from_struct!(User); + let user = UserPutItemInput { + id: "mock_id".to_owned(), + name: "bokuweb".to_owned(), + }; + let _res = client.put(user).run().await; } - #[test] - fn test_put_user_with_builder() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let user = User::put_item_builder() - .id("mock_id".to_owned()) - .name("bokuweb".to_owned()) - .build(); - let _res = client.put(user).run().await; - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_user_with_builder() { + let client = crate::all::create_client_from_struct!(User); + let user = User::put_item_builder() + .id("mock_id".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let _res = client.put(user).run().await; } #[derive(Raiden, Debug, Clone)] @@ -111,98 +103,78 @@ mod tests { name: String, } - #[test] - fn test_put_user_eq_op_condition_expression() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let user = UserPutItemInput { - id: "id0".to_owned(), - name: "bokuweb".to_owned(), - }; - let cond = User::condition().value("bokuweb").eq_attr(User::name()); - let res = client.put(user).condition(cond).run().await; - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_user_eq_op_condition_expression() { + let client = crate::all::create_client_from_struct!(User); + let user = UserPutItemInput { + id: "id0".to_owned(), + name: "bokuweb".to_owned(), + }; + let cond = User::condition().value("bokuweb").eq_attr(User::name()); + let res = client.put(user).condition(cond).run().await; + assert_eq!(res.is_ok(), true); } - #[test] #[allow(dead_code)] - fn test_put_user_eq_op_condition_expression_with_not_exist_name() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let user = UserPutItemInput { - id: "id0".to_owned(), - name: "bokuweb".to_owned(), - }; - let cond = User::condition().value("bokuweb_").eq_attr(User::name()); - let res = client.put(user).condition(cond).run().await; - assert!(res.is_err()); - - if let RaidenError::ConditionalCheckFailed(msg) = res.unwrap_err() { - assert!(msg.contains("The conditional request failed")); - } else { - panic!("err should be RaidenError::ConditionalCheckFailed"); - } + #[tokio::test] + async fn test_put_user_eq_op_condition_expression_with_not_exist_name() { + let client = crate::all::create_client_from_struct!(User); + let user = UserPutItemInput { + id: "id0".to_owned(), + name: "bokuweb".to_owned(), + }; + let cond = User::condition().value("bokuweb_").eq_attr(User::name()); + let res = client.put(user).condition(cond).run().await; + assert!(res.is_err()); + + if let RaidenError::ConditionalCheckFailed(msg) = res.unwrap_err() { + assert!(msg.contains("The conditional request failed")); + } else { + panic!("err should be RaidenError::ConditionalCheckFailed"); } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[test] #[allow(dead_code)] - fn test_put_user_id_not_exists_expression() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let user = UserPutItemInput { - id: "id0".to_owned(), - name: "bokuweb".to_owned(), - }; - let cond = User::condition().attr_not_exists(User::id()); - let res = client.put(user).condition(cond).run().await; - assert!(res.is_err()); - - if let RaidenError::ConditionalCheckFailed(msg) = res.unwrap_err() { - assert!(msg.contains("The conditional request failed")); - } else { - panic!("err should be RaidenError::ConditionalCheckFailed"); - } + #[tokio::test] + async fn test_put_user_id_not_exists_expression() { + let client = crate::all::create_client_from_struct!(User); + let user = UserPutItemInput { + id: "id0".to_owned(), + name: "bokuweb".to_owned(), + }; + let cond = User::condition().attr_not_exists(User::id()); + let res = client.put(user).condition(cond).run().await; + assert!(res.is_err()); + + if let RaidenError::ConditionalCheckFailed(msg) = res.unwrap_err() { + assert!(msg.contains("The conditional request failed")); + } else { + panic!("err should be RaidenError::ConditionalCheckFailed"); } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); } - #[test] #[allow(dead_code)] - fn test_put_user_id_exists_expression() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let user = UserPutItemInput { - id: "id0".to_owned(), - name: "bokuweb".to_owned(), - }; - let cond = User::condition().attr_exists(User::id()); - let res = client.put(user).condition(cond).run().await; - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_user_id_exists_expression() { + let client = crate::all::create_client_from_struct!(User); + let user = UserPutItemInput { + id: "id0".to_owned(), + name: "bokuweb".to_owned(), + }; + let cond = User::condition().attr_exists(User::id()); + let res = client.put(user).condition(cond).run().await; + assert_eq!(res.is_ok(), true); } - #[test] #[allow(dead_code)] - fn test_put_user_with_uuid() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserWithUuid); - let item = UserWithUuid::put_item_builder() - .name("bokuweb".to_owned()) - .build(); - let res = client.put(item).run().await; - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_user_with_uuid() { + let client = crate::all::create_client_from_struct!(UserWithUuid); + let item = UserWithUuid::put_item_builder() + .name("bokuweb".to_owned()) + .build(); + let res = client.put(item).run().await; + assert_eq!(res.is_ok(), true); } #[derive(Raiden)] @@ -217,19 +189,15 @@ mod tests { nums: Vec, } - #[test] - fn test_put_user_with_number_vec() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserVecTest); - let item = UserVecTest::put_item_builder() - .name("bokuweb".to_owned()) - .nums(vec![0, 1, 2]) - .build(); - let res = client.put(item).run().await; - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_user_with_number_vec() { + let client = crate::all::create_client_from_struct!(UserVecTest); + let item = UserVecTest::put_item_builder() + .name("bokuweb".to_owned()) + .nums(vec![0, 1, 2]) + .build(); + let res = client.put(item).run().await; + assert_eq!(res.is_ok(), true); } #[derive(Raiden)] @@ -244,22 +212,18 @@ mod tests { nums: std::collections::HashSet, } - #[test] - fn test_put_user_with_number_set() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserSetTest); - let mut nums: std::collections::HashSet = std::collections::HashSet::new(); - nums.insert(1); - - let item = UserSetTest::put_item_builder() - .name("bokuweb".to_owned()) - .nums(nums) - .build(); - let res = client.put(item).run().await; - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_user_with_number_set() { + let client = crate::all::create_client_from_struct!(UserSetTest); + let mut nums: std::collections::HashSet = std::collections::HashSet::new(); + nums.insert(1); + + let item = UserSetTest::put_item_builder() + .name("bokuweb".to_owned()) + .nums(nums) + .build(); + let res = client.put(item).run().await; + assert_eq!(res.is_ok(), true); } #[derive(Debug, Clone, Hash, PartialEq, Eq)] @@ -289,22 +253,18 @@ mod tests { nums: std::collections::HashSet, } - #[test] - fn test_put_user_with_user_defined_set() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserSetTest); - let mut nums: std::collections::HashSet = std::collections::HashSet::new(); - nums.insert(1); - - let item = UserSetTest::put_item_builder() - .name("bokuweb".to_owned()) - .nums(nums) - .build(); - let res = client.put(item).run().await; - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_user_with_user_defined_set() { + let client = crate::all::create_client_from_struct!(UserSetTest); + let mut nums: std::collections::HashSet = std::collections::HashSet::new(); + nums.insert(1); + + let item = UserSetTest::put_item_builder() + .name("bokuweb".to_owned()) + .nums(nums) + .build(); + let res = client.put(item).run().await; + assert_eq!(res.is_ok(), true); } #[derive(Raiden)] @@ -318,18 +278,14 @@ mod tests { set: std::collections::HashSet, } - #[test] - fn test_put_user_with_empty_set() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserEmptySetTest); - let set: std::collections::HashSet = std::collections::HashSet::new(); - let item = UserEmptySetTest::put_item_builder().set(set).build(); - let res = client.put(item).run().await; - - assert_eq!(res.is_ok(), true); - } + #[tokio::test] + async fn test_put_user_with_empty_set() { + let client = crate::all::create_client_from_struct!(UserEmptySetTest); + let set: std::collections::HashSet = std::collections::HashSet::new(); + let item = UserEmptySetTest::put_item_builder().set(set).build(); + let res = client.put(item).run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.is_ok(), true); } #[derive(Raiden, Debug, Clone)] @@ -341,18 +297,14 @@ mod tests { name: String, } - #[test] - fn test_put_with_empty_string() { - async fn example() { - let client = crate::all::create_client_from_struct!(EmptyStringTestData0); - let item = EmptyStringTestData0::put_item_builder() - .name("".to_owned()) - .build(); - let res = client.put(item).run().await; - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_with_empty_string() { + let client = crate::all::create_client_from_struct!(EmptyStringTestData0); + let item = EmptyStringTestData0::put_item_builder() + .name("".to_owned()) + .build(); + let res = client.put(item).run().await; + assert_eq!(res.is_ok(), true); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -363,28 +315,24 @@ mod tests { sset: std::collections::HashSet, } - #[test] - fn test_put_with_empty_sset() { - async fn example() { - let client = crate::all::create_client_from_struct!(EmptyPutTestData0); - let set: std::collections::HashSet = std::collections::HashSet::new(); - let expected_set: std::collections::HashSet = std::collections::HashSet::new(); - let item = EmptyPutTestData0::put_item_builder() - .id("testid".to_owned()) - .sset(set) - .build(); - let res = client.put(item).run().await; - assert_eq!(res.is_ok(), true); - let res = client.get(res.unwrap().item.id).run().await; - assert_eq!( - res.unwrap().item, - EmptyPutTestData0 { - id: "testid".to_owned(), - sset: expected_set - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_put_with_empty_sset() { + let client = crate::all::create_client_from_struct!(EmptyPutTestData0); + let set: std::collections::HashSet = std::collections::HashSet::new(); + let expected_set: std::collections::HashSet = std::collections::HashSet::new(); + let item = EmptyPutTestData0::put_item_builder() + .id("testid".to_owned()) + .sset(set) + .build(); + let res = client.put(item).run().await; + assert_eq!(res.is_ok(), true); + let res = client.get(res.unwrap().item.id).run().await; + assert_eq!( + res.unwrap().item, + EmptyPutTestData0 { + id: "testid".to_owned(), + sset: expected_set + } + ); } } diff --git a/raiden/tests/all/query.rs b/raiden/tests/all/query.rs index 70648b12..3f16e8fd 100644 --- a/raiden/tests/all/query.rs +++ b/raiden/tests/all/query.rs @@ -15,231 +15,190 @@ mod tests { option: Option, } - #[test] - fn test_query() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id0"); - let res = client.query().key_condition(cond).run().await; - - assert_eq!( - res.unwrap(), - query::QueryOutput { - consumed_capacity: None, - count: Some(2), - items: vec![ - QueryTestData0 { - id: "id0".to_owned(), - name: "john".to_owned(), - year: 1999, - num: 1000, - option: None, - }, - QueryTestData0 { - id: "id0".to_owned(), - name: "john".to_owned(), - year: 2000, - num: 2000, - option: None, - }, - ], - next_token: None, - scanned_count: Some(2), - } - ) - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); - } - - #[test] - fn test_query_with_and_key_condition() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()) - .eq("id0") - .and(QueryTestData0::key_condition(QueryTestData0::year()).eq(1999)); - let res = client.query().key_condition(cond).run().await; - - assert_eq!( - res.unwrap(), - query::QueryOutput { - consumed_capacity: None, - count: Some(1), - items: vec![QueryTestData0 { + #[tokio::test] + async fn test_query() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id0"); + let res = client.query().key_condition(cond).run().await; + + assert_eq!( + res.unwrap(), + query::QueryOutput { + consumed_capacity: None, + count: Some(2), + items: vec![ + QueryTestData0 { id: "id0".to_owned(), name: "john".to_owned(), year: 1999, num: 1000, option: None, - },], - next_token: None, - scanned_count: Some(1), - } - ) - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + }, + QueryTestData0 { + id: "id0".to_owned(), + name: "john".to_owned(), + year: 2000, + num: 2000, + option: None, + }, + ], + next_token: None, + scanned_count: Some(2), + } + ); + } + + #[tokio::test] + async fn test_query_with_and_key_condition() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()) + .eq("id0") + .and(QueryTestData0::key_condition(QueryTestData0::year()).eq(1999)); + let res = client.query().key_condition(cond).run().await; + + assert_eq!( + res.unwrap(), + query::QueryOutput { + consumed_capacity: None, + count: Some(1), + items: vec![QueryTestData0 { + id: "id0".to_owned(), + name: "john".to_owned(), + year: 1999, + num: 1000, + option: None, + },], + next_token: None, + scanned_count: Some(1), + } + ); } - #[test] - fn test_query_with_simple_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id3"); - let filter = QueryTestData0::filter_expression(QueryTestData0::num()).eq(4000); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 3); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_with_simple_filter() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id3"); + let filter = QueryTestData0::filter_expression(QueryTestData0::num()).eq(4000); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 3); } - #[test] - fn test_query_with_size_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id5"); - let filter = QueryTestData0::filter_expression(QueryTestData0::name()) - .size() - .ge(4); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_with_size_filter() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id5"); + let filter = QueryTestData0::filter_expression(QueryTestData0::name()) + .size() + .ge(4); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); } - #[test] - fn test_query_with_or_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id3"); - let filter = QueryTestData0::filter_expression(QueryTestData0::name()) - .eq("bar0") - .or(QueryTestData0::filter_expression(QueryTestData0::name()).eq("bar1")); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_with_or_filter() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id3"); + let filter = QueryTestData0::filter_expression(QueryTestData0::name()) + .eq("bar0") + .or(QueryTestData0::filter_expression(QueryTestData0::name()).eq("bar1")); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); } - #[test] - fn test_query_with_attribute_exists_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = - QueryTestData0::filter_expression(QueryTestData0::option()).attribute_exists(); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_with_attribute_exists_filter() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = QueryTestData0::filter_expression(QueryTestData0::option()).attribute_exists(); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); } - #[test] - fn test_query_with_attribute_not_exists_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = - QueryTestData0::filter_expression(QueryTestData0::option()).attribute_not_exists(); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 1); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_with_attribute_not_exists_filter() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = + QueryTestData0::filter_expression(QueryTestData0::option()).attribute_not_exists(); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 1); } - #[test] - fn test_query_with_attribute_type_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = QueryTestData0::filter_expression(QueryTestData0::option()) - .attribute_type(raiden::AttributeType::S); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_with_attribute_type_filter() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = QueryTestData0::filter_expression(QueryTestData0::option()) + .attribute_type(raiden::AttributeType::S); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); } - #[test] - fn test_query_with_contains_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = QueryTestData0::filter_expression(QueryTestData0::name()).contains("bar"); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_with_contains_filter() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = QueryTestData0::filter_expression(QueryTestData0::name()).contains("bar"); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); } - #[test] - fn test_query_in_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0); - let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); - let filter = QueryTestData0::filter_expression(QueryTestData0::name()) - .r#in(vec!["bar0", "bar1"]); - let res = client - .query() - .key_condition(cond) - .filter(filter) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 2); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_in_filter() { + let client = crate::all::create_client_from_struct!(QueryTestData0); + let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id4"); + let filter = + QueryTestData0::filter_expression(QueryTestData0::name()).r#in(vec!["bar0", "bar1"]); + let res = client + .query() + .key_condition(cond) + .filter(filter) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 2); } #[derive(Raiden)] @@ -252,106 +211,86 @@ mod tests { long_text: String, } - #[test] - fn test_query_limit_1() { - async fn example() { - let client = crate::all::create_client_from_struct!(Test); - let cond = Test::key_condition(Test::ref_id()).eq("id0"); - let res = client - .query() - .index("testGSI") - .limit(1) - .key_condition(cond) - .run() - .await; - assert_eq!(res.unwrap().items.len(), 1); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_limit_1() { + let client = crate::all::create_client_from_struct!(Test); + let cond = Test::key_condition(Test::ref_id()).eq("id0"); + let res = client + .query() + .index("testGSI") + .limit(1) + .key_condition(cond) + .run() + .await; + assert_eq!(res.unwrap().items.len(), 1); } - #[test] - fn test_query_limit_5() { - async fn example() { - let client = crate::all::create_client_from_struct!(Test); - let cond = Test::key_condition(Test::ref_id()).eq("id0"); - let res = client - .query() - .index("testGSI") - .limit(5) - .key_condition(cond) - .run() - .await; - assert_eq!(res.unwrap().items.len(), 5); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_limit_5() { + let client = crate::all::create_client_from_struct!(Test); + let cond = Test::key_condition(Test::ref_id()).eq("id0"); + let res = client + .query() + .index("testGSI") + .limit(5) + .key_condition(cond) + .run() + .await; + assert_eq!(res.unwrap().items.len(), 5); } - #[test] - fn test_query_no_limit() { - async fn example() { - let client = crate::all::create_client_from_struct!(Test); - let cond = Test::key_condition(Test::ref_id()).eq("id0"); - let res = client - .query() - .index("testGSI") - .key_condition(cond) - .run() - .await; - assert_eq!(res.unwrap().items.len(), 10); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_no_limit() { + let client = crate::all::create_client_from_struct!(Test); + let cond = Test::key_condition(Test::ref_id()).eq("id0"); + let res = client + .query() + .index("testGSI") + .key_condition(cond) + .run() + .await; + assert_eq!(res.unwrap().items.len(), 10); } - #[test] - fn test_query_over_limit() { - async fn example() { - let client = crate::all::create_client_from_struct!(Test); - let cond = Test::key_condition(Test::ref_id()).eq("id0"); - let res = client - .query() - .index("testGSI") - .limit(11) - .key_condition(cond) - .run() - .await; - assert_eq!(res.unwrap().items.len(), 10); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_over_limit() { + let client = crate::all::create_client_from_struct!(Test); + let cond = Test::key_condition(Test::ref_id()).eq("id0"); + let res = client + .query() + .index("testGSI") + .limit(11) + .key_condition(cond) + .run() + .await; + assert_eq!(res.unwrap().items.len(), 10); } - #[test] - fn test_query_over_limit_with_next_token() { - async fn example() { - let client = crate::all::create_client_from_struct!(Test); - let cond = Test::key_condition(Test::ref_id()).eq("id0"); - let res = client - .query() - .index("testGSI") - .limit(9) - .key_condition(cond) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 9); - assert!(res.next_token.is_some()); - let cond = Test::key_condition(Test::ref_id()).eq("id0"); - let res = client - .query() - .index("testGSI") - .limit(10) - .next_token(res.next_token.unwrap()) - .key_condition(cond) - .run() - .await - .unwrap(); - assert_eq!(res.items.len(), 1); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_over_limit_with_next_token() { + let client = crate::all::create_client_from_struct!(Test); + let cond = Test::key_condition(Test::ref_id()).eq("id0"); + let res = client + .query() + .index("testGSI") + .limit(9) + .key_condition(cond) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 9); + assert!(res.next_token.is_some()); + let cond = Test::key_condition(Test::ref_id()).eq("id0"); + let res = client + .query() + .index("testGSI") + .limit(10) + .next_token(res.next_token.unwrap()) + .key_condition(cond) + .run() + .await + .unwrap(); + assert_eq!(res.items.len(), 1); } #[derive(Raiden)] @@ -365,22 +304,18 @@ mod tests { updated_at: String, } - #[test] - fn test_query_with_renamed() { - async fn example() { - let client = crate::all::create_client_from_struct!(Project); - let cond = Project::key_condition(Project::org_id()).eq("myOrg"); - let res = client - .query() - .index("orgIndex") - .limit(11) - .key_condition(cond) - .run() - .await; - assert_eq!(res.unwrap().items.len(), 10); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_with_renamed() { + let client = crate::all::create_client_from_struct!(Project); + let cond = Project::key_condition(Project::org_id()).eq("myOrg"); + let res = client + .query() + .index("orgIndex") + .limit(11) + .key_condition(cond) + .run() + .await; + assert_eq!(res.unwrap().items.len(), 10); } #[derive(Raiden, Debug, PartialEq)] @@ -391,37 +326,34 @@ mod tests { name: String, year: usize, } - #[test] - fn test_query_for_projection_expression() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData0a); - let cond = QueryTestData0a::key_condition(QueryTestData0a::id()).eq("id0"); - let res = client.query().key_condition(cond).run().await; - - assert_eq!( - res.unwrap(), - query::QueryOutput { - consumed_capacity: None, - count: Some(2), - items: vec![ - QueryTestData0a { - id: "id0".to_owned(), - name: "john".to_owned(), - year: 1999, - }, - QueryTestData0a { - id: "id0".to_owned(), - name: "john".to_owned(), - year: 2000, - }, - ], - next_token: None, - scanned_count: Some(2), - } - ) - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + + #[tokio::test] + async fn test_query_for_projection_expression() { + let client = crate::all::create_client_from_struct!(QueryTestData0a); + let cond = QueryTestData0a::key_condition(QueryTestData0a::id()).eq("id0"); + let res = client.query().key_condition(cond).run().await; + + assert_eq!( + res.unwrap(), + query::QueryOutput { + consumed_capacity: None, + count: Some(2), + items: vec![ + QueryTestData0a { + id: "id0".to_owned(), + name: "john".to_owned(), + year: 1999, + }, + QueryTestData0a { + id: "id0".to_owned(), + name: "john".to_owned(), + year: 2000, + }, + ], + next_token: None, + scanned_count: Some(2), + } + ); } #[derive(Raiden, Debug, PartialEq)] @@ -433,37 +365,33 @@ mod tests { name: String, } - #[test] - fn test_query_with_begins_with_key_condition() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryTestData1); - let cond = QueryTestData1::key_condition(QueryTestData1::id()) - .eq("id0") - .and(QueryTestData1::key_condition(QueryTestData1::name()).begins_with("j")); - let res = client.query().key_condition(cond).run().await; - - assert_eq!( - res.unwrap(), - query::QueryOutput { - consumed_capacity: None, - count: Some(2), - items: vec![ - QueryTestData1 { - id: "id0".to_owned(), - name: "jack".to_owned(), - }, - QueryTestData1 { - id: "id0".to_owned(), - name: "john".to_owned(), - } - ], - next_token: None, - scanned_count: Some(2), - } - ) - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_query_with_begins_with_key_condition() { + let client = crate::all::create_client_from_struct!(QueryTestData1); + let cond = QueryTestData1::key_condition(QueryTestData1::id()) + .eq("id0") + .and(QueryTestData1::key_condition(QueryTestData1::name()).begins_with("j")); + let res = client.query().key_condition(cond).run().await; + + assert_eq!( + res.unwrap(), + query::QueryOutput { + consumed_capacity: None, + count: Some(2), + items: vec![ + QueryTestData1 { + id: "id0".to_owned(), + name: "jack".to_owned(), + }, + QueryTestData1 { + id: "id0".to_owned(), + name: "john".to_owned(), + } + ], + next_token: None, + scanned_count: Some(2), + } + ); } #[derive(Raiden, Debug, PartialEq)] @@ -475,55 +403,47 @@ mod tests { name: String, } - #[test] - fn should_be_obtainable_when_the_size_is_1mb_or_larger() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryLargeDataTest); - let cond = QueryLargeDataTest::key_condition(QueryLargeDataTest::ref_id()).eq("ref"); - let res = client - .query() - .index("testGSI") - .key_condition(cond) - .run() - .await; - - assert_eq!(res.unwrap().items.len(), 100) - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn should_be_obtainable_when_the_size_is_1mb_or_larger() { + let client = crate::all::create_client_from_struct!(QueryLargeDataTest); + let cond = QueryLargeDataTest::key_condition(QueryLargeDataTest::ref_id()).eq("ref"); + let res = client + .query() + .index("testGSI") + .key_condition(cond) + .run() + .await; + + assert_eq!(res.unwrap().items.len(), 100); } - #[test] - fn should_be_obtainable_specified_limit_items_when_the_size_is_1mb_or_larger() { - async fn example() { - let client = crate::all::create_client_from_struct!(QueryLargeDataTest); - let cond = QueryLargeDataTest::key_condition(QueryLargeDataTest::ref_id()).eq("ref"); - let res = client - .query() - .index("testGSI") - .key_condition(cond) - .limit(40) - .run() - .await - .unwrap(); - - assert_eq!(res.items.len(), 40); - - let token = res.next_token; - - let cond = QueryLargeDataTest::key_condition(QueryLargeDataTest::ref_id()).eq("ref"); - let res = client - .query() - .index("testGSI") - .key_condition(cond) - .next_token(token.unwrap()) - .run() - .await - .unwrap(); - - assert_eq!(res.items.len(), 60); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn should_be_obtainable_specified_limit_items_when_the_size_is_1mb_or_larger() { + let client = crate::all::create_client_from_struct!(QueryLargeDataTest); + let cond = QueryLargeDataTest::key_condition(QueryLargeDataTest::ref_id()).eq("ref"); + let res = client + .query() + .index("testGSI") + .key_condition(cond) + .limit(40) + .run() + .await + .unwrap(); + + assert_eq!(res.items.len(), 40); + + let token = res.next_token; + + let cond = QueryLargeDataTest::key_condition(QueryLargeDataTest::ref_id()).eq("ref"); + let res = client + .query() + .index("testGSI") + .key_condition(cond) + .next_token(token.unwrap()) + .run() + .await + .unwrap(); + + assert_eq!(res.items.len(), 60); } } diff --git a/raiden/tests/all/rename.rs b/raiden/tests/all/rename.rs index 207900b0..031761c3 100644 --- a/raiden/tests/all/rename.rs +++ b/raiden/tests/all/rename.rs @@ -28,77 +28,65 @@ mod tests { before_rename: usize, } - #[test] - fn test_rename_get_item() { - async fn example() { - let client = crate::all::create_client_from_struct!(RenameTest); - let res = client.get("id0").run().await; + #[tokio::test] + async fn test_rename_get_item() { + let client = crate::all::create_client_from_struct!(RenameTest); + let res = client.get("id0").run().await; - assert_eq!( - res.unwrap(), - get::GetOutput { - item: RenameTest { - id: "id0".to_owned(), - name: "john".to_owned(), - before_rename: 1999, - }, - consumed_capacity: None, - } - ); - assert_eq!( - RenameTestAttrNames::Renamed.into_attr_name(), - "renamed".to_owned() - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + get::GetOutput { + item: RenameTest { + id: "id0".to_owned(), + name: "john".to_owned(), + before_rename: 1999, + }, + consumed_capacity: None, + } + ); + assert_eq!( + RenameTestAttrNames::Renamed.into_attr_name(), + "renamed".to_owned() + ); } - #[test] - fn test_rename_key_get_item() { - async fn example() { - let client = crate::all::create_client_from_struct!(RenameKeyTest); - let res = client.get("id0").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: RenameKeyTest { - before_renamed_id: "id0".to_owned(), - name: "john".to_owned(), - before_rename: 1999, - }, - consumed_capacity: None, - } - ); - } + #[tokio::test] + async fn test_rename_key_get_item() { + let client = crate::all::create_client_from_struct!(RenameKeyTest); + let res = client.get("id0").run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + get::GetOutput { + item: RenameKeyTest { + before_renamed_id: "id0".to_owned(), + name: "john".to_owned(), + before_rename: 1999, + }, + consumed_capacity: None, + } + ); } - #[test] - fn test_rename_query() { - async fn example() { - let client = crate::all::create_client_from_struct!(RenameTest); - let cond = RenameTest::key_condition(RenameTest::id()).eq("id0"); - let res = client.query().key_condition(cond).run().await; - - assert_eq!( - res.unwrap(), - query::QueryOutput { - consumed_capacity: None, - count: Some(1), - items: vec![RenameTest { - id: "id0".to_owned(), - name: "john".to_owned(), - before_rename: 1999, - },], - next_token: None, - scanned_count: Some(1), - } - ) - } + #[tokio::test] + async fn test_rename_query() { + let client = crate::all::create_client_from_struct!(RenameTest); + let cond = RenameTest::key_condition(RenameTest::id()).eq("id0"); + let res = client.query().key_condition(cond).run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + query::QueryOutput { + consumed_capacity: None, + count: Some(1), + items: vec![RenameTest { + id: "id0".to_owned(), + name: "john".to_owned(), + before_rename: 1999, + },], + next_token: None, + scanned_count: Some(1), + } + ); } } diff --git a/raiden/tests/all/rename_all.rs b/raiden/tests/all/rename_all.rs index 824ac16a..f67db3dd 100644 --- a/raiden/tests/all/rename_all.rs +++ b/raiden/tests/all/rename_all.rs @@ -16,26 +16,22 @@ mod tests { project_id: usize, } - #[test] - fn test_rename_all_camelcase_get() { - async fn example() { - let client = crate::all::create_client_from_struct!(RenameAllCamelCaseTest); - let res = client.get("id0").run().await; + #[tokio::test] + async fn test_rename_all_camelcase_get() { + let client = crate::all::create_client_from_struct!(RenameAllCamelCaseTest); + let res = client.get("id0").run().await; - assert_eq!( - res.unwrap(), - get::GetOutput { - item: RenameAllCamelCaseTest { - partition_key: "id0".to_owned(), - foo_bar: "john".to_owned(), - project_id: 1, - }, - consumed_capacity: None, - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + get::GetOutput { + item: RenameAllCamelCaseTest { + partition_key: "id0".to_owned(), + foo_bar: "john".to_owned(), + project_id: 1, + }, + consumed_capacity: None, + } + ); } #[derive(Raiden)] @@ -49,25 +45,21 @@ mod tests { project_id: usize, } - #[test] - fn test_rename_all_pascalcase_get() { - async fn example() { - let client = crate::all::create_client_from_struct!(RenameAllPascalCaseTest); - let res = client.get("id0").run().await; - - assert_eq!( - res.unwrap(), - get::GetOutput { - item: RenameAllPascalCaseTest { - partition_key: "id0".to_owned(), - foo_bar: "john".to_owned(), - project_id: 1, - }, - consumed_capacity: None, - } - ); - } + #[tokio::test] + async fn test_rename_all_pascalcase_get() { + let client = crate::all::create_client_from_struct!(RenameAllPascalCaseTest); + let res = client.get("id0").run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!( + res.unwrap(), + get::GetOutput { + item: RenameAllPascalCaseTest { + partition_key: "id0".to_owned(), + foo_bar: "john".to_owned(), + project_id: 1, + }, + consumed_capacity: None, + } + ); } } diff --git a/raiden/tests/all/scan.rs b/raiden/tests/all/scan.rs index fc9d0a0a..8d643b5c 100644 --- a/raiden/tests/all/scan.rs +++ b/raiden/tests/all/scan.rs @@ -14,30 +14,26 @@ mod tests { num: usize, } - #[test] - fn test_scan() { - async fn example() { - let client = crate::all::create_client_from_struct!(ScanTestData0); - let res = client.scan().run().await; - - assert_eq!( - res.unwrap(), - scan::ScanOutput { - consumed_capacity: None, - count: Some(1), - items: vec![ScanTestData0 { - id: "scanId0".to_owned(), - name: "scanAlice".to_owned(), - year: 2001, - num: 2000 - }], - last_evaluated_key: None, - scanned_count: Some(1), - } - ) - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_scan() { + let client = crate::all::create_client_from_struct!(ScanTestData0); + let res = client.scan().run().await; + + assert_eq!( + res.unwrap(), + scan::ScanOutput { + consumed_capacity: None, + count: Some(1), + items: vec![ScanTestData0 { + id: "scanId0".to_owned(), + name: "scanAlice".to_owned(), + year: 2001, + num: 2000 + }], + last_evaluated_key: None, + scanned_count: Some(1), + } + ); } #[derive(Raiden)] @@ -50,52 +46,36 @@ mod tests { long_text: String, } - #[test] - fn test_scan_limit_1() { - async fn example() { - let client = crate::all::create_client_from_struct!(Test); - let res = client.scan().limit(1).run().await; + #[tokio::test] + async fn test_scan_limit_1() { + let client = crate::all::create_client_from_struct!(Test); + let res = client.scan().limit(1).run().await; - assert_eq!(res.unwrap().items.len(), 1); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.unwrap().items.len(), 1); } - #[test] - fn test_scan_limit_5() { - async fn example() { - let client = crate::all::create_client_from_struct!(Test); - let res = client.scan().limit(5).run().await; - - assert_eq!(res.unwrap().items.len(), 5); - } + #[tokio::test] + async fn test_scan_limit_5() { + let client = crate::all::create_client_from_struct!(Test); + let res = client.scan().limit(5).run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.unwrap().items.len(), 5); } - #[test] - fn test_scan_no_limit() { - async fn example() { - let client = crate::all::create_client_from_struct!(Test); - let res = client.scan().run().await; + #[tokio::test] + async fn test_scan_no_limit() { + let client = crate::all::create_client_from_struct!(Test); + let res = client.scan().run().await; - assert_eq!(res.unwrap().items.len(), 10); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.unwrap().items.len(), 10); } - #[test] - fn test_scan_over_limit() { - async fn example() { - let client = crate::all::create_client_from_struct!(Test); - let res = client.scan().limit(11).run().await; - - assert_eq!(res.unwrap().items.len(), 10); - } + #[tokio::test] + async fn test_scan_over_limit() { + let client = crate::all::create_client_from_struct!(Test); + let res = client.scan().limit(11).run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.unwrap().items.len(), 10); } #[derive(Raiden)] @@ -109,16 +89,12 @@ mod tests { updated_at: String, } - #[test] - fn test_scan_with_renamed() { - async fn example() { - let client = crate::all::create_client_from_struct!(Project); - let res = client.scan().limit(11).run().await; + #[tokio::test] + async fn test_scan_with_renamed() { + let client = crate::all::create_client_from_struct!(Project); + let res = client.scan().limit(11).run().await; - assert_eq!(res.unwrap().items.len(), 10); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.unwrap().items.len(), 10); } #[derive(Raiden, Debug, PartialEq)] @@ -129,28 +105,24 @@ mod tests { name: String, } - #[test] - fn test_scan_for_projection_expression() { - async fn example() { - let client = crate::all::create_client_from_struct!(ScanTestData0a); - let res = client.scan().run().await; - - assert_eq!( - res.unwrap(), - scan::ScanOutput { - consumed_capacity: None, - count: Some(1), - items: vec![ScanTestData0a { - id: "scanId0".to_owned(), - name: "scanAlice".to_owned(), - }], - last_evaluated_key: None, - scanned_count: Some(1), - } - ) - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_scan_for_projection_expression() { + let client = crate::all::create_client_from_struct!(ScanTestData0a); + let res = client.scan().run().await; + + assert_eq!( + res.unwrap(), + scan::ScanOutput { + consumed_capacity: None, + count: Some(1), + items: vec![ScanTestData0a { + id: "scanId0".to_owned(), + name: "scanAlice".to_owned(), + }], + last_evaluated_key: None, + scanned_count: Some(1), + } + ); } #[derive(Raiden, Debug, PartialEq)] @@ -162,16 +134,12 @@ mod tests { name: String, } - #[test] - fn should_be_scan_when_the_size_is_1mb_or_larger() { - async fn example() { - let client = crate::all::create_client_from_struct!(ScanLargeDataTest); - let res = client.scan().run().await; - - assert_eq!(res.unwrap().items.len(), 100) - } + #[tokio::test] + async fn should_be_scan_when_the_size_is_1mb_or_larger() { + let client = crate::all::create_client_from_struct!(ScanLargeDataTest); + let res = client.scan().run().await; - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.unwrap().items.len(), 100); } #[derive(Raiden, Debug)] @@ -186,84 +154,60 @@ mod tests { option: Option, } - #[test] - fn test_simple_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(Scan); - let filter = Scan::filter_expression(Scan::num()).eq(1000); - let res = client.scan().filter(filter).run().await.unwrap(); + #[tokio::test] + async fn test_simple_filter() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::num()).eq(1000); + let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 50); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.items.len(), 50); } - #[test] - fn test_size_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(Scan); - let filter = Scan::filter_expression(Scan::name()).size().eq(10); - let res = client.scan().filter(filter).run().await.unwrap(); - - assert_eq!(res.items.len(), 10); - } + #[tokio::test] + async fn test_size_filter() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::name()).size().eq(10); + let res = client.scan().filter(filter).run().await.unwrap(); - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.items.len(), 10); } - #[test] - fn test_or_with_contain_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(Scan); - let filter = Scan::filter_expression(Scan::num()) - .eq(1000) - .or(Scan::filter_expression(Scan::id()).contains("scanId50")); - let res = client.scan().filter(filter).run().await.unwrap(); - - assert_eq!(res.items.len(), 51); - } + #[tokio::test] + async fn test_or_with_contain_filter() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::num()) + .eq(1000) + .or(Scan::filter_expression(Scan::id()).contains("scanId50")); + let res = client.scan().filter(filter).run().await.unwrap(); - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.items.len(), 51); } - #[test] - fn test_attribute_exists_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(Scan); - let filter = Scan::filter_expression(Scan::option()).attribute_exists(); - let res = client.scan().filter(filter).run().await.unwrap(); + #[tokio::test] + async fn test_attribute_exists_filter() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::option()).attribute_exists(); + let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 50); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.items.len(), 50); } - #[test] - fn test_attribute_not_exists_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(Scan); - let filter = Scan::filter_expression(Scan::option()).attribute_not_exists(); - let res = client.scan().filter(filter).run().await.unwrap(); - - assert_eq!(res.items.len(), 50); - } + #[tokio::test] + async fn test_attribute_not_exists_filter() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = Scan::filter_expression(Scan::option()).attribute_not_exists(); + let res = client.scan().filter(filter).run().await.unwrap(); - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.items.len(), 50); } - #[test] - fn test_attribute_type_filter() { - async fn example() { - let client = crate::all::create_client_from_struct!(Scan); - let filter = - Scan::filter_expression(Scan::option()).attribute_type(raiden::AttributeType::S); - let res = client.scan().filter(filter).run().await.unwrap(); - - assert_eq!(res.items.len(), 50); - } + #[tokio::test] + async fn test_attribute_type_filter() { + let client = crate::all::create_client_from_struct!(Scan); + let filter = + Scan::filter_expression(Scan::option()).attribute_type(raiden::AttributeType::S); + let res = client.scan().filter(filter).run().await.unwrap(); - tokio::runtime::Runtime::new().unwrap().block_on(example()); + assert_eq!(res.items.len(), 50); } } diff --git a/raiden/tests/all/transact_write.rs b/raiden/tests/all/transact_write.rs index 42dd125f..aca43ba4 100644 --- a/raiden/tests/all/transact_write.rs +++ b/raiden/tests/all/transact_write.rs @@ -1,7 +1,7 @@ #[cfg(test)] mod tests { #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] - fn create_client() -> ::raiden::WriteTx { + async fn create_client() -> ::raiden::WriteTx { ::raiden::WriteTx::new(Region::Custom { endpoint: "http://localhost:8000".into(), name: "ap-northeast-1".into(), @@ -9,17 +9,12 @@ mod tests { } #[cfg(feature = "aws-sdk")] - fn create_client() -> ::raiden::WriteTx { - let sdk_config = raiden::AwsSdkConfig::builder() - .behavior_version(raiden::BehaviorVersion::latest()) - .credentials_provider( - aws_credential_types::provider::SharedCredentialsProvider::new( - aws_credential_types::Credentials::new("dummy", "dummy", None, None, "dummy"), - ), - ) + async fn create_client() -> ::raiden::WriteTx { + let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") .region(raiden::Region::from_static("ap-northeast-1")) - .build(); + .load() + .await; let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); ::raiden::WriteTx::new_with_client(sdk_client) @@ -39,79 +34,67 @@ mod tests { name: String, } - #[test] - fn test_minimum_transact_write() { - async fn example() { - let tx = create_client(); - let cond = User::condition().attr_not_exists(User::id()); - let input = User::put_item_builder() - .id("testId".to_owned()) - .name("bokuweb".to_owned()) - .build(); - let input2 = User::put_item_builder() - .id("testId2".to_owned()) - .name("bokuweb".to_owned()) - .build(); - - assert_eq!( - tx.put(User::put(input).condition(cond)) - .put(User::put(input2)) - .run() - .await - .is_ok(), - true, - ) - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); - } + #[tokio::test] + async fn test_minimum_transact_write() { + let tx = create_client().await; + let cond = User::condition().attr_not_exists(User::id()); + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let input2 = User::put_item_builder() + .id("testId2".to_owned()) + .name("bokuweb".to_owned()) + .build(); - #[test] - fn test_transact_write_put_and_update() { - async fn example() { - let tx = create_client(); - let input = User::put_item_builder() - .id("testId".to_owned()) - .name("bokuweb".to_owned()) - .build(); - let set_expression = User::update_expression() - .set(User::name()) - .value("updated!!"); - let res = tx - .put(User::put(input)) - .update(User::update("testId2").set(set_expression)) + assert_eq!( + tx.put(User::put(input).condition(cond)) + .put(User::put(input2)) .run() - .await; - - assert_eq!(res.is_ok(), true); - } + .await + .is_ok(), + true, + ); + } - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_transact_write_put_and_update() { + let tx = create_client().await; + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let set_expression = User::update_expression() + .set(User::name()) + .value("updated!!"); + let res = tx + .put(User::put(input)) + .update(User::update("testId2").set(set_expression)) + .run() + .await; + + assert_eq!(res.is_ok(), true); } - #[test] - fn test_transact_write_with_prefix_suffix() { - async fn example() { - let tx = create_client(); - let input = User::put_item_builder() - .id("testId".to_owned()) - .name("bokuweb".to_owned()) - .build(); + #[tokio::test] + async fn test_transact_write_with_prefix_suffix() { + let tx = create_client().await; + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); - assert_eq!( - tx.put( - User::put(input) - .table_prefix("test-") - .table_suffix("-staging"), - ) - .run() - .await - .is_ok(), - true, + assert_eq!( + tx.put( + User::put(input) + .table_prefix("test-") + .table_suffix("-staging"), ) - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + .run() + .await + .is_ok(), + true, + ); } use std::sync::atomic::{AtomicUsize, Ordering}; @@ -130,26 +113,23 @@ mod tests { } } - #[test] - fn test_retry() { - async fn example() { - let tx = create_client(); - let input = User::put_item_builder() - .id("testId".to_owned()) - .name("bokuweb".to_owned()) - .build(); + #[tokio::test] + async fn test_retry() { + let tx = create_client().await; + let input = User::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); - assert_eq!( - tx.with_retries(Box::new(MyRetryStrategy)) - .put(User::put(input).table_prefix("unknown")) - .run() - .await - .is_err(), - true, - ) - } + assert_eq!( + tx.with_retries(Box::new(MyRetryStrategy)) + .put(User::put(input).table_prefix("unknown")) + .run() + .await + .is_err(), + true, + ); - tokio::runtime::Runtime::new().unwrap().block_on(example()); assert_eq!(RETRY_COUNT.load(Ordering::Relaxed), 4) } @@ -160,45 +140,41 @@ mod tests { name: String, } - #[test] - fn test_transact_delete_and_put() { - async fn example() { - let tx = create_client(); - let input = TxDeleteTestData0::put_item_builder() - .id("testId".to_owned()) - .name("bokuweb".to_owned()) - .build(); - - assert_eq!( - tx.put(TxDeleteTestData0::put(input)) - .delete(TxDeleteTestData0::delete("id0")) - .run() - .await - .is_ok(), - true, - ); + #[tokio::test] + async fn test_transact_delete_and_put() { + let tx = create_client().await; + let input = TxDeleteTestData0::put_item_builder() + .id("testId".to_owned()) + .name("bokuweb".to_owned()) + .build(); - let client = crate::all::create_client_from_struct!(TxDeleteTestData0); - let res = client.get("id0").run().await; - assert!(res.is_err()); + assert_eq!( + tx.put(TxDeleteTestData0::put(input)) + .delete(TxDeleteTestData0::delete("id0")) + .run() + .await + .is_ok(), + true, + ); - if let RaidenError::ResourceNotFound(msg) = res.unwrap_err() { - assert_eq!("resource not found", msg); - } else { - panic!("err should be RaidenError::ResourceNotFound"); - } + let client = crate::all::create_client_from_struct!(TxDeleteTestData0); + let res = client.get("id0").run().await; + assert!(res.is_err()); - let res = client.get("testId").run().await; - assert_eq!( - res.unwrap().item, - TxDeleteTestData0 { - id: "testId".to_owned(), - name: "bokuweb".to_owned() - } - ); + if let RaidenError::ResourceNotFound(msg) = res.unwrap_err() { + assert_eq!("resource not found", msg); + } else { + panic!("err should be RaidenError::ResourceNotFound"); } - tokio::runtime::Runtime::new().unwrap().block_on(example()); + let res = client.get("testId").run().await; + assert_eq!( + res.unwrap().item, + TxDeleteTestData0 { + id: "testId".to_owned(), + name: "bokuweb".to_owned() + } + ); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -215,74 +191,64 @@ mod tests { name: String, } - #[test] - fn should_succeed_to_put_when_condition_check_ok() { - async fn example() { - let tx = create_client(); - let input = TxConditionalCheckTestData0::put_item_builder() - .id("testId0".to_owned()) - .name("bokuweb".to_owned()) - .build(); - let cond = TxConditionalCheckTestData1::condition() - .attr_exists(TxConditionalCheckTestData1::id()); - assert_eq!( - tx.put(TxConditionalCheckTestData0::put(input)) - .condition_check( - TxConditionalCheckTestData1::condition_check("id1").condition(cond) - ) - .run() - .await - .is_ok(), - true, - ); - - let client = crate::all::create_client_from_struct!(TxConditionalCheckTestData0); - let res = client.get("testId0").run().await; - assert_eq!( - res.unwrap().item, - TxConditionalCheckTestData0 { - id: "testId0".to_owned(), - name: "bokuweb".to_owned() - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); - } - - #[test] - fn should_fail_to_put_when_condition_check_ng() { - async fn example() { - let tx = create_client(); - let input = TxConditionalCheckTestData0::put_item_builder() - .id("testId1".to_owned()) - .name("bokuweb".to_owned()) - .build(); - let cond = TxConditionalCheckTestData1::condition() - .attr_not_exists(TxConditionalCheckTestData1::id()); - - let res = tx - .put(TxConditionalCheckTestData0::put(input)) + #[tokio::test] + async fn should_succeed_to_put_when_condition_check_ok() { + let tx = create_client().await; + let input = TxConditionalCheckTestData0::put_item_builder() + .id("testId0".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let cond = + TxConditionalCheckTestData1::condition().attr_exists(TxConditionalCheckTestData1::id()); + assert_eq!( + tx.put(TxConditionalCheckTestData0::put(input)) .condition_check( - TxConditionalCheckTestData1::condition_check("id1").condition(cond), + TxConditionalCheckTestData1::condition_check("id1").condition(cond) ) .run() - .await; - assert!(res.is_err()); - - if let RaidenError::TransactionCanceled { reasons, .. } = res.unwrap_err() { - assert_eq!( - RaidenTransactionCancellationReasons(vec![ - None, - Some(RaidenTransactionCancellationReason::ConditionalCheckFailed), - ]), - reasons - ); - } else { - panic!("err should be RaidenError::TransactionCanceled"); + .await + .is_ok(), + true, + ); + + let client = crate::all::create_client_from_struct!(TxConditionalCheckTestData0); + let res = client.get("testId0").run().await; + assert_eq!( + res.unwrap().item, + TxConditionalCheckTestData0 { + id: "testId0".to_owned(), + name: "bokuweb".to_owned() } - } + ); + } + + #[tokio::test] + async fn should_fail_to_put_when_condition_check_ng() { + let tx = create_client().await; + let input = TxConditionalCheckTestData0::put_item_builder() + .id("testId1".to_owned()) + .name("bokuweb".to_owned()) + .build(); + let cond = TxConditionalCheckTestData1::condition() + .attr_not_exists(TxConditionalCheckTestData1::id()); + + let res = tx + .put(TxConditionalCheckTestData0::put(input)) + .condition_check(TxConditionalCheckTestData1::condition_check("id1").condition(cond)) + .run() + .await; + assert!(res.is_err()); - tokio::runtime::Runtime::new().unwrap().block_on(example()); + if let RaidenError::TransactionCanceled { reasons, .. } = res.unwrap_err() { + assert_eq!( + RaidenTransactionCancellationReasons(vec![ + None, + Some(RaidenTransactionCancellationReason::ConditionalCheckFailed), + ]), + reasons + ); + } else { + panic!("err should be RaidenError::TransactionCanceled"); + } } } diff --git a/raiden/tests/all/update.rs b/raiden/tests/all/update.rs index 159f1c36..caf8a16d 100644 --- a/raiden/tests/all/update.rs +++ b/raiden/tests/all/update.rs @@ -15,56 +15,48 @@ mod tests { age: usize, } - #[test] - fn test_update() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let set_name_expression = User::update_expression() - .set(User::name()) - .value("updated!!"); - let set_age_expression = User::update_expression().set(User::age()).value(12); - let res = client - .update("id0") - .set(set_name_expression) - .set(set_age_expression) - .return_all_new() - .run() - .await - .unwrap(); - - assert_eq!( - res.item, - Some(User { - id: "id0".to_owned(), - name: "updated!!".to_owned(), - age: 12, - }) - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update() { + let client = crate::all::create_client_from_struct!(User); + let set_name_expression = User::update_expression() + .set(User::name()) + .value("updated!!"); + let set_age_expression = User::update_expression().set(User::age()).value(12); + let res = client + .update("id0") + .set(set_name_expression) + .set(set_age_expression) + .return_all_new() + .run() + .await + .unwrap(); + + assert_eq!( + res.item, + Some(User { + id: "id0".to_owned(), + name: "updated!!".to_owned(), + age: 12, + }) + ); } - #[test] - fn test_update_with_invalid_key_with_condition() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let cond = User::condition().attr_exists(User::id()); - let set_expression = User::update_expression() - .set(User::name()) - .value("updated!!"); - let res = client - .update("invalid_key!!!!!!") - .return_all_new() - .condition(cond) - .set(set_expression) - .run() - .await; - - assert_eq!(res.is_err(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_with_invalid_key_with_condition() { + let client = crate::all::create_client_from_struct!(User); + let cond = User::condition().attr_exists(User::id()); + let set_expression = User::update_expression() + .set(User::name()) + .value("updated!!"); + let res = client + .update("invalid_key!!!!!!") + .return_all_new() + .condition(cond) + .set(set_expression) + .run() + .await; + + assert_eq!(res.is_err(), true); } #[derive(Raiden)] @@ -77,24 +69,20 @@ mod tests { unstored: usize, } - #[test] - fn test_update_with_unstored() { - async fn example() { - let client = crate::all::create_client_from_struct!(UserWithUnStored); - let set_expression = UserWithUnStored::update_expression() - .set(UserWithUnStored::name()) - .value("updated!!"); - let res = client - .update("id0") - .set(set_expression) - .run() - .await - .unwrap(); - - assert_eq!(res.item, None); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_with_unstored() { + let client = crate::all::create_client_from_struct!(UserWithUnStored); + let set_expression = UserWithUnStored::update_expression() + .set(UserWithUnStored::name()) + .value("updated!!"); + let res = client + .update("id0") + .set(set_expression) + .run() + .await + .unwrap(); + + assert_eq!(res.item, None); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -106,32 +94,28 @@ mod tests { age: usize, } - #[test] - fn test_update_with_sort_key() { - async fn example() { - let client = crate::all::create_client_from_struct!(UpdateTestData1); - let set_expression = UpdateTestData1::update_expression() - .set(UpdateTestData1::name()) - .value("bob"); - let res = client - .update("id0", 36_usize) - .set(set_expression) - .return_all_new() - .run() - .await - .unwrap(); - - assert_eq!( - res.item, - Some(UpdateTestData1 { - id: "id0".to_owned(), - name: "bob".to_owned(), - age: 36 - }) - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_with_sort_key() { + let client = crate::all::create_client_from_struct!(UpdateTestData1); + let set_expression = UpdateTestData1::update_expression() + .set(UpdateTestData1::name()) + .value("bob"); + let res = client + .update("id0", 36_usize) + .set(set_expression) + .return_all_new() + .run() + .await + .unwrap(); + + assert_eq!( + res.item, + Some(UpdateTestData1 { + id: "id0".to_owned(), + name: "bob".to_owned(), + age: 36 + }) + ); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -141,72 +125,59 @@ mod tests { sset: std::collections::HashSet, } - #[test] - fn test_update_with_only_attr() { - async fn example() { - let client = crate::all::create_client_from_struct!(EmptySetTestData0); - let set_expression = EmptySetTestData0::update_expression() - .set(EmptySetTestData0::sset()) - .attr(EmptySetTestData0::sset()); - let res = client - .update("id1") - .set(set_expression) - .return_all_new() - .run() - .await; - - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_with_only_attr() { + let client = crate::all::create_client_from_struct!(EmptySetTestData0); + let set_expression = EmptySetTestData0::update_expression() + .set(EmptySetTestData0::sset()) + .attr(EmptySetTestData0::sset()); + let res = client + .update("id1") + .set(set_expression) + .return_all_new() + .run() + .await; + + assert_eq!(res.is_ok(), true); } - #[test] - fn test_update_empty_set_sort_key() { - async fn example() { - let client = crate::all::create_client_from_struct!(EmptySetTestData0); - let sset: std::collections::HashSet = std::collections::HashSet::new(); - let expected_sset: std::collections::HashSet = std::collections::HashSet::new(); - let set_expression = EmptySetTestData0::update_expression() - .set(EmptySetTestData0::sset()) - .value(sset); - let res = client - .update("id0") - .set(set_expression) - .return_all_new() - .run() - .await; - - assert!(res.is_ok()); - assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_empty_set_sort_key() { + let client = crate::all::create_client_from_struct!(EmptySetTestData0); + let sset: std::collections::HashSet = std::collections::HashSet::new(); + let expected_sset: std::collections::HashSet = std::collections::HashSet::new(); + let set_expression = EmptySetTestData0::update_expression() + .set(EmptySetTestData0::sset()) + .value(sset); + let res = client + .update("id0") + .set(set_expression) + .return_all_new() + .run() + .await; + + assert!(res.is_ok()); + assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } - #[test] - fn test_add_with_empty_hash_set() { - async fn example() { - let client = crate::all::create_client_from_struct!(EmptySetTestData0); - let sset: std::collections::HashSet = std::collections::HashSet::new(); - let mut expected_sset: std::collections::HashSet = - std::collections::HashSet::new(); - expected_sset.insert("Hello".to_owned()); - let expression = EmptySetTestData0::update_expression() - .add(EmptySetTestData0::sset()) - .value(sset); - let res = client - .update("id0") - .add(expression) - .return_all_new() - .run() - .await; - - assert_eq!(res.is_ok(), true); - assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_add_with_empty_hash_set() { + let client = crate::all::create_client_from_struct!(EmptySetTestData0); + let sset: std::collections::HashSet = std::collections::HashSet::new(); + let mut expected_sset: std::collections::HashSet = std::collections::HashSet::new(); + expected_sset.insert("Hello".to_owned()); + let expression = EmptySetTestData0::update_expression() + .add(EmptySetTestData0::sset()) + .value(sset); + let res = client + .update("id0") + .add(expression) + .return_all_new() + .run() + .await; + + assert_eq!(res.is_ok(), true); + assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -216,31 +187,25 @@ mod tests { sset: std::collections::HashSet, } - #[test] - fn test_update_delete_sset() { - async fn example() { - let client = crate::all::create_client_from_struct!(UpdateDeleteTestData0); - let mut delete_sset: std::collections::HashSet = - std::collections::HashSet::new(); - delete_sset.insert("foo".to_owned()); - let delete_expression = UpdateDeleteTestData0::update_expression() - .delete(UpdateDeleteTestData0::sset()) - .value(delete_sset); - let mut expected_sset: std::collections::HashSet = - std::collections::HashSet::new(); - expected_sset.insert("bar".to_owned()); - - let res = client - .update("id0") - .delete(delete_expression) - .return_all_new() - .run() - .await; - - assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_delete_sset() { + let client = crate::all::create_client_from_struct!(UpdateDeleteTestData0); + let mut delete_sset: std::collections::HashSet = std::collections::HashSet::new(); + delete_sset.insert("foo".to_owned()); + let delete_expression = UpdateDeleteTestData0::update_expression() + .delete(UpdateDeleteTestData0::sset()) + .value(delete_sset); + let mut expected_sset: std::collections::HashSet = std::collections::HashSet::new(); + expected_sset.insert("bar".to_owned()); + + let res = client + .update("id0") + .delete(delete_expression) + .return_all_new() + .run() + .await; + + assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -250,77 +215,63 @@ mod tests { sset: std::collections::HashSet, } - #[test] - fn test_update_add_sset() { - async fn example() { - let client = crate::all::create_client_from_struct!(UpdateAddTestData0); - let mut add_sset: std::collections::HashSet = std::collections::HashSet::new(); - add_sset.insert("added".to_owned()); - let add_expression = UpdateAddTestData0::update_expression() - .add(UpdateAddTestData0::sset()) - .value(add_sset); - let mut expected_sset: std::collections::HashSet = - std::collections::HashSet::new(); - expected_sset.insert("foo".to_owned()); - expected_sset.insert("bar".to_owned()); - expected_sset.insert("added".to_owned()); - - let res = client - .update("id0") - .add(add_expression) - .return_all_new() - .run() - .await; - - assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_add_sset() { + let client = crate::all::create_client_from_struct!(UpdateAddTestData0); + let mut add_sset: std::collections::HashSet = std::collections::HashSet::new(); + add_sset.insert("added".to_owned()); + let add_expression = UpdateAddTestData0::update_expression() + .add(UpdateAddTestData0::sset()) + .value(add_sset); + let mut expected_sset: std::collections::HashSet = std::collections::HashSet::new(); + expected_sset.insert("foo".to_owned()); + expected_sset.insert("bar".to_owned()); + expected_sset.insert("added".to_owned()); + + let res = client + .update("id0") + .add(add_expression) + .return_all_new() + .run() + .await; + + assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } - #[test] - fn test_update_add_sset_to_empty() { - async fn example() { - let client = crate::all::create_client_from_struct!(UpdateAddTestData0); - let mut add_sset: std::collections::HashSet = std::collections::HashSet::new(); - add_sset.insert("added".to_owned()); - let add_expression = UpdateAddTestData0::update_expression() - .add(UpdateAddTestData0::sset()) - .value(add_sset); - let mut expected_sset: std::collections::HashSet = - std::collections::HashSet::new(); - expected_sset.insert("added".to_owned()); - - let res = client - .update("id2") - .add(add_expression) - .return_all_new() - .run() - .await; - - assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_add_sset_to_empty() { + let client = crate::all::create_client_from_struct!(UpdateAddTestData0); + let mut add_sset: std::collections::HashSet = std::collections::HashSet::new(); + add_sset.insert("added".to_owned()); + let add_expression = UpdateAddTestData0::update_expression() + .add(UpdateAddTestData0::sset()) + .value(add_sset); + let mut expected_sset: std::collections::HashSet = std::collections::HashSet::new(); + expected_sset.insert("added".to_owned()); + + let res = client + .update("id2") + .add(add_expression) + .return_all_new() + .run() + .await; + + assert_eq!(res.unwrap().item.unwrap().sset, expected_sset); } - #[test] - fn test_update_to_empty_string() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let set_name_expression = User::update_expression().set(User::name()).value(""); - let res = client - .update("id0") - .set(set_name_expression) - .return_all_new() - .run() - .await - .unwrap(); - - assert_eq!(res.item.unwrap().name, "".to_owned()); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_to_empty_string() { + let client = crate::all::create_client_from_struct!(User); + let set_name_expression = User::update_expression().set(User::name()).value(""); + let res = client + .update("id0") + .set(set_name_expression) + .return_all_new() + .run() + .await + .unwrap(); + + assert_eq!(res.item.unwrap().name, "".to_owned()); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -330,42 +281,38 @@ mod tests { name: Option, } - #[test] - fn test_update_remove_sset() { - async fn example() { - let client = crate::all::create_client_from_struct!(UpdateRemoveTestData0); - let res = client - .update("id1") - .remove(UpdateRemoveTestData0::name()) - .return_all_new() - .run() - .await; - - assert_eq!( - res.unwrap().item.unwrap(), - UpdateRemoveTestData0 { - id: "id1".to_owned(), - name: None - } - ); - - let res = client - .update("id2") - .remove(UpdateRemoveTestData0::name()) - .return_all_new() - .run() - .await; - - assert_eq!( - res.unwrap().item.unwrap(), - UpdateRemoveTestData0 { - id: "id2".to_owned(), - name: None - } - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn test_update_remove_sset() { + let client = crate::all::create_client_from_struct!(UpdateRemoveTestData0); + let res = client + .update("id1") + .remove(UpdateRemoveTestData0::name()) + .return_all_new() + .run() + .await; + + assert_eq!( + res.unwrap().item.unwrap(), + UpdateRemoveTestData0 { + id: "id1".to_owned(), + name: None + } + ); + + let res = client + .update("id2") + .remove(UpdateRemoveTestData0::name()) + .return_all_new() + .run() + .await; + + assert_eq!( + res.unwrap().item.unwrap(), + UpdateRemoveTestData0 { + id: "id2".to_owned(), + name: None + } + ); } #[derive(Raiden, Debug, Clone, PartialEq)] @@ -376,182 +323,158 @@ mod tests { name: String, } - #[test] - fn should_update_with_contains_condition_in_sset() { - async fn example() { - let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); - let set_expression = UpdateWithContainsInSetCondition::update_expression() - .set(UpdateWithContainsInSetCondition::name()) - .value("Changed"); - let cond = UpdateWithContainsInSetCondition::condition().contains( - UpdateWithContainsInSetCondition::sset(), - "Hello".to_string(), - ); - - let res = client - .update("id0") - .set(set_expression) - .condition(cond) - .return_all_new() - .run() - .await; - - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn should_update_with_contains_condition_in_sset() { + let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); + let set_expression = UpdateWithContainsInSetCondition::update_expression() + .set(UpdateWithContainsInSetCondition::name()) + .value("Changed"); + let cond = UpdateWithContainsInSetCondition::condition().contains( + UpdateWithContainsInSetCondition::sset(), + "Hello".to_string(), + ); + + let res = client + .update("id0") + .set(set_expression) + .condition(cond) + .return_all_new() + .run() + .await; + + assert_eq!(res.is_ok(), true); } - #[test] - fn should_not_update_with_contains_condition_in_sset() { - async fn example() { - let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); - let set_expression = UpdateWithContainsInSetCondition::update_expression() - .set(UpdateWithContainsInSetCondition::name()) - .value("Changed"); - let cond = UpdateWithContainsInSetCondition::condition().contains( - UpdateWithContainsInSetCondition::sset(), - "World".to_string(), - ); - - let res = client - .update("id0") - .set(set_expression) - .condition(cond) - .return_all_new() - .run() - .await; - - assert_eq!(res.is_err(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn should_not_update_with_contains_condition_in_sset() { + let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); + let set_expression = UpdateWithContainsInSetCondition::update_expression() + .set(UpdateWithContainsInSetCondition::name()) + .value("Changed"); + let cond = UpdateWithContainsInSetCondition::condition().contains( + UpdateWithContainsInSetCondition::sset(), + "World".to_string(), + ); + + let res = client + .update("id0") + .set(set_expression) + .condition(cond) + .return_all_new() + .run() + .await; + + assert_eq!(res.is_err(), true); } - #[test] - fn should_not_update_with_or_condition_failed() { - async fn example() { - let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); - let set_expression = UpdateWithContainsInSetCondition::update_expression() - .set(UpdateWithContainsInSetCondition::name()) - .value("Changed"); - let cond = UpdateWithContainsInSetCondition::condition() - .contains( - UpdateWithContainsInSetCondition::sset(), - "Merhaba".to_string(), - ) - .or(UpdateWithContainsInSetCondition::condition().contains( - UpdateWithContainsInSetCondition::sset(), - "Bonjour".to_string(), - )); - - let res = client - .update("id0") - .set(set_expression) - .condition(cond) - .return_all_new() - .run() - .await; - - assert_eq!(res.is_err(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn should_not_update_with_or_condition_failed() { + let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); + let set_expression = UpdateWithContainsInSetCondition::update_expression() + .set(UpdateWithContainsInSetCondition::name()) + .value("Changed"); + let cond = UpdateWithContainsInSetCondition::condition() + .contains( + UpdateWithContainsInSetCondition::sset(), + "Merhaba".to_string(), + ) + .or(UpdateWithContainsInSetCondition::condition().contains( + UpdateWithContainsInSetCondition::sset(), + "Bonjour".to_string(), + )); + + let res = client + .update("id0") + .set(set_expression) + .condition(cond) + .return_all_new() + .run() + .await; + + assert_eq!(res.is_err(), true); } - #[test] - fn should_update_with_or_condition() { - async fn example() { - let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); - let set_expression = UpdateWithContainsInSetCondition::update_expression() - .set(UpdateWithContainsInSetCondition::name()) - .value("Changed"); - let cond = UpdateWithContainsInSetCondition::condition() - .contains( - UpdateWithContainsInSetCondition::sset(), - "Hello".to_string(), - ) - .or(UpdateWithContainsInSetCondition::condition().contains( - UpdateWithContainsInSetCondition::sset(), - "Bonjour".to_string(), - )); - - let res = client - .update("id0") - .set(set_expression) - .condition(cond) - .return_all_new() - .run() - .await; - - assert_eq!(res.is_ok(), true); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn should_update_with_or_condition() { + let client = crate::all::create_client_from_struct!(UpdateWithContainsInSetCondition); + let set_expression = UpdateWithContainsInSetCondition::update_expression() + .set(UpdateWithContainsInSetCondition::name()) + .value("Changed"); + let cond = UpdateWithContainsInSetCondition::condition() + .contains( + UpdateWithContainsInSetCondition::sset(), + "Hello".to_string(), + ) + .or(UpdateWithContainsInSetCondition::condition().contains( + UpdateWithContainsInSetCondition::sset(), + "Bonjour".to_string(), + )); + + let res = client + .update("id0") + .set(set_expression) + .condition(cond) + .return_all_new() + .run() + .await; + + assert_eq!(res.is_ok(), true); } - #[test] - fn should_set_if_attr_not_exists() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - let set_name_expression = User::update_expression() - .set(User::name()) - .value("updated") - .if_not_exists(); - let set_age_expression = User::update_expression().set(User::age()).value(12); - - let res = client - .update("if_not_exists#0") - .set(set_name_expression) - .set(set_age_expression) - .return_all_new() - .run() - .await - .unwrap(); - - assert_eq!( - res.item, - Some(User { - id: "if_not_exists#0".into(), - name: "updated".into(), - age: 12 - }) - ); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn should_set_if_attr_not_exists() { + let client = crate::all::create_client_from_struct!(User); + let set_name_expression = User::update_expression() + .set(User::name()) + .value("updated") + .if_not_exists(); + let set_age_expression = User::update_expression().set(User::age()).value(12); + + let res = client + .update("if_not_exists#0") + .set(set_name_expression) + .set(set_age_expression) + .return_all_new() + .run() + .await + .unwrap(); + + assert_eq!( + res.item, + Some(User { + id: "if_not_exists#0".into(), + name: "updated".into(), + age: 12 + }) + ); } - #[test] - fn should_not_set_if_attr_exists() { - async fn example() { - let client = crate::all::create_client_from_struct!(User); - - let set_name_expression = User::update_expression().set(User::name()).value("created"); - let set_age_expression = User::update_expression().set(User::age()).value(12); - - client - .update("if_not_exists#1") - .set(set_name_expression) - .set(set_age_expression) - .run() - .await - .unwrap(); - - let set_name_expression = User::update_expression() - .set(User::name()) - .value("updated") - .if_not_exists(); // update only if attribute not exists - let res = client - .update("if_not_exists#1") - .set(set_name_expression) - .return_all_new() - .run() - .await - .unwrap(); - assert_eq!(res.item.map(|u| u.name), Some("created".into())); - } - - tokio::runtime::Runtime::new().unwrap().block_on(example()); + #[tokio::test] + async fn should_not_set_if_attr_exists() { + let client = crate::all::create_client_from_struct!(User); + + let set_name_expression = User::update_expression().set(User::name()).value("created"); + let set_age_expression = User::update_expression().set(User::age()).value(12); + + client + .update("if_not_exists#1") + .set(set_name_expression) + .set(set_age_expression) + .run() + .await + .unwrap(); + + let set_name_expression = User::update_expression() + .set(User::name()) + .value("updated") + .if_not_exists(); // update only if attribute not exists + let res = client + .update("if_not_exists#1") + .set(set_name_expression) + .return_all_new() + .run() + .await + .unwrap(); + assert_eq!(res.item.map(|u| u.name), Some("created".into())); } } From 16abc8bf66a1ad34471e31038b42402f38d6084a Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Wed, 29 May 2024 17:05:50 +0900 Subject: [PATCH 08/22] chore: update dependencies. --- Cargo.lock | 726 ++++++++++++++++++++++----------------- raiden-derive/Cargo.toml | 6 +- raiden/Cargo.toml | 36 +- raiden/src/rusoto/mod.rs | 14 +- rust-toolchain | 2 +- 5 files changed, 426 insertions(+), 358 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 494518ff..23f873ac 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -54,13 +54,13 @@ dependencies = [ [[package]] name = "async-trait" -version = "0.1.74" +version = "0.1.77" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a66537f1bb974b254c98ed142ff995236e81b9d0fe4db0575f46612cb15eb0f9" +checksum = "c980ee35e870bd1a4d2c8294d4c04d0499e67bca1e4b5cefcc693c2fa00caea9" dependencies = [ "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", ] [[package]] @@ -71,12 +71,11 @@ checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" [[package]] name = "aws-config" -version = "1.0.1" +version = "1.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "80c950a809d39bc9480207cb1cfc879ace88ea7e3a4392a8e9999e45d6e5692e" +checksum = "0b96342ea8948ab9bef3e6234ea97fc32e2d8a88d8fb6a084e52267317f94b6b" dependencies = [ "aws-credential-types", - "aws-http", "aws-runtime", "aws-sdk-sso", "aws-sdk-ssooidc", @@ -91,10 +90,10 @@ dependencies = [ "bytes", "fastrand", "hex", - "http", + "http 0.2.11", "hyper", - "ring 0.17.6", - "time 0.3.30", + "ring 0.17.8", + "time 0.3.36", "tokio", "tracing", "zeroize", @@ -102,9 +101,9 @@ dependencies = [ [[package]] name = "aws-credential-types" -version = "1.0.1" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8c1317e1a3514b103cf7d5828bbab3b4d30f56bd22d684f8568bc51b6cfbbb1c" +checksum = "e16838e6c9e12125face1c1eff1343c75e3ff540de98ff7ebd61874a89bcfeb9" dependencies = [ "aws-smithy-async", "aws-smithy-runtime-api", @@ -112,51 +111,36 @@ dependencies = [ "zeroize", ] -[[package]] -name = "aws-http" -version = "0.60.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "361c4310fdce94328cc2d1ca0c8a48c13f43009c61d3367585685a50ca8c66b6" -dependencies = [ - "aws-smithy-runtime-api", - "aws-smithy-types", - "aws-types", - "bytes", - "http", - "http-body", - "pin-project-lite", - "tracing", -] - [[package]] name = "aws-runtime" -version = "1.0.1" +version = "1.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1ed7ef604a15fd0d4d9e43701295161ea6b504b63c44990ead352afea2bc15e9" +checksum = "6e38bab716c8bf07da24be07ecc02e0f5656ce8f30a891322ecdcb202f943b85" dependencies = [ "aws-credential-types", - "aws-http", "aws-sigv4", "aws-smithy-async", "aws-smithy-http", "aws-smithy-runtime-api", "aws-smithy-types", "aws-types", + "bytes", "fastrand", - "http", + "http 0.2.11", + "http-body", "percent-encoding", + "pin-project-lite", "tracing", "uuid", ] [[package]] name = "aws-sdk-dynamodb" -version = "1.3.0" +version = "1.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "23c4ed3708df2778c0c49b16e8235e52eb8f2133ae6752c40eea1376e2563fec" +checksum = "785c15d901cb8c3a85817902221cc9ba3d51b2c65483ff51112f2ed9fe54815a" dependencies = [ "aws-credential-types", - "aws-http", "aws-runtime", "aws-smithy-async", "aws-smithy-http", @@ -167,19 +151,19 @@ dependencies = [ "aws-types", "bytes", "fastrand", - "http", - "regex", + "http 0.2.11", + "once_cell", + "regex-lite", "tracing", ] [[package]] name = "aws-sdk-sso" -version = "1.3.0" +version = "1.15.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0619ab97a5ca8982e7de073cdc66f93e5f6a1b05afc09e696bec1cb3607cd4df" +checksum = "d84bd3925a17c9adbf6ec65d52104a44a09629d8f70290542beeee69a95aee7f" dependencies = [ "aws-credential-types", - "aws-http", "aws-runtime", "aws-smithy-async", "aws-smithy-http", @@ -189,19 +173,19 @@ dependencies = [ "aws-smithy-types", "aws-types", "bytes", - "http", - "regex", + "http 0.2.11", + "once_cell", + "regex-lite", "tracing", ] [[package]] name = "aws-sdk-ssooidc" -version = "1.3.0" +version = "1.15.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f04b9f5474cc0f35d829510b2ec8c21e352309b46bf9633c5a81fb9321e9b1c7" +checksum = "2c2dae39e997f58bc4d6292e6244b26ba630c01ab671b6f9f44309de3eb80ab8" dependencies = [ "aws-credential-types", - "aws-http", "aws-runtime", "aws-smithy-async", "aws-smithy-http", @@ -211,19 +195,19 @@ dependencies = [ "aws-smithy-types", "aws-types", "bytes", - "http", - "regex", + "http 0.2.11", + "once_cell", + "regex-lite", "tracing", ] [[package]] name = "aws-sdk-sts" -version = "1.3.1" +version = "1.15.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "798c8d82203af9e15a8b406574e0b36da91dd6db533028b74676489a1bc8bc7d" +checksum = "17fd9a53869fee17cea77e352084e1aa71e2c5e323d974c13a9c2bcfd9544c7f" dependencies = [ "aws-credential-types", - "aws-http", "aws-runtime", "aws-smithy-async", "aws-smithy-http", @@ -234,16 +218,17 @@ dependencies = [ "aws-smithy-types", "aws-smithy-xml", "aws-types", - "http", - "regex", + "http 0.2.11", + "once_cell", + "regex-lite", "tracing", ] [[package]] name = "aws-sigv4" -version = "1.0.1" +version = "1.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "380adcc8134ad8bbdfeb2ace7626a869914ee266322965276cbc54066186d236" +checksum = "8ada00a4645d7d89f296fe0ddbc3fe3554f03035937c849a05d37ddffc1f29a1" dependencies = [ "aws-credential-types", "aws-smithy-http", @@ -253,20 +238,20 @@ dependencies = [ "form_urlencoded", "hex", "hmac 0.12.1", - "http", + "http 0.2.11", + "http 1.0.0", "once_cell", "percent-encoding", - "regex", "sha2 0.10.8", - "time 0.3.30", + "time 0.3.36", "tracing", ] [[package]] name = "aws-smithy-async" -version = "1.0.3" +version = "1.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "573441a5a0219e436e86a7f9a20b0f2505c5ae6fe7fe3eba6e3950991c9ad914" +checksum = "62220bc6e97f946ddd51b5f1361f78996e704677afc518a4ff66b7a72ea1378c" dependencies = [ "futures-util", "pin-project-lite", @@ -275,16 +260,16 @@ dependencies = [ [[package]] name = "aws-smithy-http" -version = "0.60.0" +version = "0.60.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5b1de8aee22f67de467b2e3d0dd0fb30859dc53f579a63bd5381766b987db644" +checksum = "b6ca214a6a26f1b7ebd63aa8d4f5e2194095643023f9608edf99a58247b9d80d" dependencies = [ "aws-smithy-runtime-api", "aws-smithy-types", "bytes", "bytes-utils", "futures-core", - "http", + "http 0.2.11", "http-body", "once_cell", "percent-encoding", @@ -295,18 +280,18 @@ dependencies = [ [[package]] name = "aws-smithy-json" -version = "0.60.0" +version = "0.60.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6a46dd338dc9576d6a6a5b5a19bd678dcad018ececee11cf28ecd7588bd1a55c" +checksum = "1af80ecf3057fb25fe38d1687e94c4601a7817c6a1e87c1b0635f7ecb644ace5" dependencies = [ "aws-smithy-types", ] [[package]] name = "aws-smithy-query" -version = "0.60.0" +version = "0.60.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "feb5b8c7a86d4b6399169670723b7e6f21a39fc833a30f5c5a2f997608178129" +checksum = "eb27084f72ea5fc20033efe180618677ff4a2f474b53d84695cfe310a6526cbc" dependencies = [ "aws-smithy-types", "urlencoding", @@ -314,9 +299,9 @@ dependencies = [ [[package]] name = "aws-smithy-runtime" -version = "1.0.3" +version = "1.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c0c628feae802ab1589936e2aaef6f8ab2b8fc1ee1f947c276dd8a7c3cda1904" +checksum = "fbb5fca54a532a36ff927fbd7407a7c8eb9c3b4faf72792ba2965ea2cad8ed55" dependencies = [ "aws-smithy-async", "aws-smithy-http", @@ -325,28 +310,29 @@ dependencies = [ "bytes", "fastrand", "h2", - "http", + "http 0.2.11", "http-body", "hyper", "hyper-rustls 0.24.2", "once_cell", "pin-project-lite", "pin-utils", - "rustls 0.21.9", + "rustls 0.21.10", "tokio", "tracing", ] [[package]] name = "aws-smithy-runtime-api" -version = "1.0.3" +version = "1.6.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7460e5cc8e6eb0749608535854352f6e121433960ba05daf4dbde0e42c1199a5" +checksum = "5b7d790d553d163c7d80a4e06e2906bf24b9172c9ebe045fc3a274e9358ab7bb" dependencies = [ "aws-smithy-async", "aws-smithy-types", "bytes", - "http", + "http 0.2.11", + "http 1.0.0", "pin-project-lite", "tokio", "tracing", @@ -355,15 +341,15 @@ dependencies = [ [[package]] name = "aws-smithy-types" -version = "1.0.3" +version = "1.1.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8ba838f43d0d72d76918895a93c3ad647f75a058541a60e85beefb6bb0a9bd40" +checksum = "5b6764ba7e1c5ede1c9f9e4046645534f06c2581402461c559b481a420330a83" dependencies = [ "base64-simd", "bytes", "bytes-utils", "futures-core", - "http", + "http 0.2.11", "http-body", "itoa", "num-integer", @@ -371,31 +357,31 @@ dependencies = [ "pin-utils", "ryu", "serde", - "time 0.3.30", + "time 0.3.36", "tokio", "tokio-util", ] [[package]] name = "aws-smithy-xml" -version = "0.60.0" +version = "0.60.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0ec40d74a67fd395bc3f6b4ccbdf1543672622d905ef3f979689aea5b730cb95" +checksum = "0fccd8f595d0ca839f9f2548e66b99514a85f92feb4c01cf2868d93eb4888a42" dependencies = [ "xmlparser", ] [[package]] name = "aws-types" -version = "1.0.1" +version = "1.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8403fc56b1f3761e8efe45771ddc1165e47ec3417c68e68a4519b5cb030159ca" +checksum = "d07c63521aa1ea9a9f92a701f1a08ce3fd20b46c6efc0d5c8947c1fd879e3df1" dependencies = [ "aws-credential-types", "aws-smithy-async", "aws-smithy-runtime-api", "aws-smithy-types", - "http", + "http 0.2.11", "rustc_version", "tracing", ] @@ -423,9 +409,15 @@ checksum = "9e1b586273c5702936fe7b7d6896644d8be71e6314cfe09d3167c95f712589e8" [[package]] name = "base64" -version = "0.21.5" +version = "0.21.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "35636a1494ede3b646cc98f74f8e62c773a38a659ebc777a2cf26b9b74171df9" +checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567" + +[[package]] +name = "base64" +version = "0.22.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "72b3254f16251a8381aa12e40e3c4d2f0199f8c6508fbecb9d91f575e0fbb8c6" [[package]] name = "base64-simd" @@ -445,9 +437,9 @@ checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" [[package]] name = "bitflags" -version = "2.4.1" +version = "2.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "327762f6e5a765692301e5bb513e0d9fef63be86bbc14528052b1cd3e6f03e07" +checksum = "ed570934406eb16438a4e976b1b4500774099c13b8cb96eec99f620f05090ddf" [[package]] name = "block-buffer" @@ -469,9 +461,9 @@ dependencies = [ [[package]] name = "bumpalo" -version = "3.14.0" +version = "3.15.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7f30e7476521f6f8af1a1c4c0b8cc94f0bee37d91763d0ca2665f299b6cd8aec" +checksum = "8ea184aa71bb362a1157c896979544cc23974e08fd265f29ea96b59f0b4a555b" [[package]] name = "bytes" @@ -494,12 +486,9 @@ dependencies = [ [[package]] name = "cc" -version = "1.0.83" +version = "1.0.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1174fb0b6ec23863f8b971027804a42614e347eafb0a95bf0b12cdae21fc4d0" -dependencies = [ - "libc", -] +checksum = "02f341c093d19155a6e41631ce5971aac4e9a868262212153124c15fa22d1cdc" [[package]] name = "cfg-if" @@ -509,15 +498,15 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" [[package]] name = "chrono" -version = "0.4.31" +version = "0.4.34" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7f2c685bad3eb3d45a01354cedb7d5faa66194d1d58ba6e267a8de788f79db38" +checksum = "5bc015644b92d5890fab7489e49d21f879d5c990186827d42ec511919404f38b" dependencies = [ "android-tzdata", "iana-time-zone", "num-traits", "serde", - "windows-targets 0.48.5", + "windows-targets 0.52.4", ] [[package]] @@ -553,18 +542,18 @@ checksum = "06ea2b9bc92be3c2baa9334a323ebca2d6f074ff852cd1d7b11064035cd3868f" [[package]] name = "cpufeatures" -version = "0.2.11" +version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ce420fe07aecd3e67c5f910618fe65e94158f6dcc0adf44e00d69ce2bdfe0fd0" +checksum = "53fe5e26ff1b7aef8bca9c6080520cfb8d9333c7568e1829cef191a9723e5504" dependencies = [ "libc", ] [[package]] name = "crc32fast" -version = "1.3.2" +version = "1.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b540bd8bc810d3885c6ea91e2018302f68baba2129ab3e88f32389ee9370880d" +checksum = "b3855a8a784b474f333699ef2bbca9db2c4a1f6d9088a90a2d25b1eb53111eaa" dependencies = [ "cfg-if", ] @@ -581,9 +570,9 @@ dependencies = [ [[package]] name = "crypto-mac" -version = "0.11.1" +version = "0.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b1d1a86f49236c215f271d40892d5fc950490551400b02ef360692c29815c714" +checksum = "25fab6889090c8133f3deb8f73ba3c65a7f456f66436fc012a1b1e272b1e103e" dependencies = [ "generic-array", "subtle", @@ -591,9 +580,9 @@ dependencies = [ [[package]] name = "deranged" -version = "0.3.9" +version = "0.3.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0f32d04922c60427da6f9fef14d042d9edddef64cb9d4ce0d64d0685fbeb1fd3" +checksum = "b42b6fa04a440b495c8b04d0e71b707c585f83cb9cb28cf8cd0d976c315e31b4" dependencies = [ "powerfmt", ] @@ -647,9 +636,9 @@ dependencies = [ [[package]] name = "either" -version = "1.9.0" +version = "1.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a26ae43d7bcc3b814de94796a5e736d4029efb0ee900c12e2d54c993ad1a1e07" +checksum = "11157ac094ffbdde99aa67b23417ebdd801842852b500e395a45a9c0aac03e4a" [[package]] name = "equivalent" @@ -711,9 +700,9 @@ checksum = "a06f77d526c1a601b7c4cdd98f54b5eaabffc14d5f2f0296febdc7f357c6d3ba" [[package]] name = "futures" -version = "0.3.29" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "da0290714b38af9b4a7b094b8a37086d1b4e61f2df9122c3cad2577669145335" +checksum = "645c6916888f6cb6350d2550b80fb63e734897a8498abe35cfb732b6487804b0" dependencies = [ "futures-channel", "futures-core", @@ -726,9 +715,9 @@ dependencies = [ [[package]] name = "futures-channel" -version = "0.3.29" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ff4dd66668b557604244583e3e1e1eada8c5c2e96a6d0d6653ede395b78bbacb" +checksum = "eac8f7d7865dcb88bd4373ab671c8cf4508703796caa2b1985a9ca867b3fcb78" dependencies = [ "futures-core", "futures-sink", @@ -736,15 +725,15 @@ dependencies = [ [[package]] name = "futures-core" -version = "0.3.29" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eb1d22c66e66d9d72e1758f0bd7d4fd0bee04cad842ee34587d68c07e45d088c" +checksum = "dfc6580bb841c5a68e9ef15c77ccc837b40a7504914d52e47b8b0e9bbda25a1d" [[package]] name = "futures-executor" -version = "0.3.29" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0f4fb8693db0cf099eadcca0efe2a5a22e4550f98ed16aba6c48700da29597bc" +checksum = "a576fc72ae164fca6b9db127eaa9a9dda0d61316034f33a0a0d4eda41f02b01d" dependencies = [ "futures-core", "futures-task", @@ -753,38 +742,38 @@ dependencies = [ [[package]] name = "futures-io" -version = "0.3.29" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8bf34a163b5c4c52d0478a4d757da8fb65cabef42ba90515efee0f6f9fa45aaa" +checksum = "a44623e20b9681a318efdd71c299b6b222ed6f231972bfe2f224ebad6311f0c1" [[package]] name = "futures-macro" -version = "0.3.29" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "53b153fd91e4b0147f4aced87be237c98248656bb01050b96bf3ee89220a8ddb" +checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" dependencies = [ "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", ] [[package]] name = "futures-sink" -version = "0.3.29" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e36d3378ee38c2a36ad710c5d30c2911d752cb941c00c72dbabfb786a7970817" +checksum = "9fb8e00e87438d937621c1c6269e53f536c14d3fbd6a042bb24879e57d474fb5" [[package]] name = "futures-task" -version = "0.3.29" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "efd193069b0ddadc69c46389b740bbccdd97203899b48d09c5f7969591d6bae2" +checksum = "38d84fa142264698cdce1a9f9172cf383a0c82de1bddcf3092901442c4097004" [[package]] name = "futures-util" -version = "0.3.29" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a19526d624e703a3179b3d322efec918b6246ea0fa51d41124525f00f1cc8104" +checksum = "3d6401deb83407ab3da39eba7e33987a73c3df0c82b4bb5813ee871c19c41d48" dependencies = [ "futures-channel", "futures-core", @@ -827,9 +816,9 @@ dependencies = [ [[package]] name = "getrandom" -version = "0.2.11" +version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fe9006bed769170c11f845cf00c7c1e9092aeb3f268e007c3e760ac68008070f" +checksum = "190092ea657667030ac6a35e305e62fc4dd69fd98ac98631e5d3a2b1575a12b5" dependencies = [ "cfg-if", "libc", @@ -844,16 +833,16 @@ checksum = "4271d37baee1b8c7e4b708028c57d816cf9d2434acb33a549475f78c181f6253" [[package]] name = "h2" -version = "0.3.22" +version = "0.3.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4d6250322ef6e60f93f9a2162799302cd6f68f79f6e5d85c8c16f14d1d958178" +checksum = "bb2c4422095b67ee78da96fbb51a4cc413b3b25883c7717ff7ca1ab31022c9c9" dependencies = [ "bytes", "fnv", "futures-core", "futures-sink", "futures-util", - "http", + "http 0.2.11", "indexmap", "slab", "tokio", @@ -869,9 +858,9 @@ checksum = "290f1a1d9242c78d09ce40a5e87e7554ee637af1351968159f4952f028f75604" [[package]] name = "hermit-abi" -version = "0.3.3" +version = "0.3.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d77f7ec81a6d05a3abb01ab6eb7590f6083d08449fe5a1c8b1e620283546ccb7" +checksum = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024" [[package]] name = "hex" @@ -909,14 +898,25 @@ dependencies = [ "itoa", ] +[[package]] +name = "http" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b32afd38673a8016f7c9ae69e5af41a58f81b1d31689040f2f1959594ce194ea" +dependencies = [ + "bytes", + "fnv", + "itoa", +] + [[package]] name = "http-body" -version = "0.4.5" +version = "0.4.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d5f38f16d184e36f2408a55281cd658ecbd3ca05cce6d6510a176eca393e26d1" +checksum = "7ceab25649e9960c0311ea418d17bee82c0dcec1bd053b5f9a66e265a693bed2" dependencies = [ "bytes", - "http", + "http 0.2.11", "pin-project-lite", ] @@ -934,22 +934,22 @@ checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9" [[package]] name = "hyper" -version = "0.14.27" +version = "0.14.28" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ffb1cfd654a8219eaef89881fdb3bb3b1cdc5fa75ded05d6933b2b382e395468" +checksum = "bf96e135eb83a2a8ddf766e426a841d8ddd7449d5f00d34ea02b41d2f19eef80" dependencies = [ "bytes", "futures-channel", "futures-core", "futures-util", "h2", - "http", + "http 0.2.11", "http-body", "httparse", "httpdate", "itoa", "pin-project-lite", - "socket2 0.4.10", + "socket2", "tokio", "tower-service", "tracing", @@ -962,11 +962,11 @@ version = "0.23.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1788965e61b367cd03a62950836d5cd41560c3577d90e40e0819373194d1661c" dependencies = [ - "http", + "http 0.2.11", "hyper", "log", "rustls 0.20.9", - "rustls-native-certs", + "rustls-native-certs 0.6.3", "tokio", "tokio-rustls 0.23.4", ] @@ -978,15 +978,31 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ec3efd23720e2049821a693cbc7e65ea87c72f1c58ff2f9522ff332b1491e590" dependencies = [ "futures-util", - "http", + "http 0.2.11", "hyper", "log", - "rustls 0.21.9", - "rustls-native-certs", + "rustls 0.21.10", + "rustls-native-certs 0.6.3", "tokio", "tokio-rustls 0.24.1", ] +[[package]] +name = "hyper-rustls" +version = "0.25.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "399c78f9338483cb7e630c8474b07268983c6bd5acee012e4211f9f7bb21b070" +dependencies = [ + "futures-util", + "http 0.2.11", + "hyper", + "rustls 0.22.2", + "rustls-native-certs 0.7.0", + "rustls-pki-types", + "tokio", + "tokio-rustls 0.25.0", +] + [[package]] name = "hyper-tls" version = "0.5.0" @@ -1002,9 +1018,9 @@ dependencies = [ [[package]] name = "iana-time-zone" -version = "0.1.58" +version = "0.1.60" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8326b86b6cff230b97d0d312a6c40a60726df3332e721f72a1b035f451663b20" +checksum = "e7ffbb5a1b541ea2561f8c41c087286cc091e21e556a4f09a8f6cbf17b69b141" dependencies = [ "android_system_properties", "core-foundation-sys", @@ -1031,9 +1047,9 @@ checksum = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39" [[package]] name = "indexmap" -version = "2.1.0" +version = "2.2.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d530e1a18b1cb4c484e6e34556a0d948706958449fca0cab753d649f2bce3d1f" +checksum = "967d6dd42f16dbf0eb8040cb9e477933562684d3918f7d253f2ff9087fb3e7a3" dependencies = [ "equivalent", "hashbrown", @@ -1050,15 +1066,15 @@ dependencies = [ [[package]] name = "itoa" -version = "1.0.9" +version = "1.0.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" +checksum = "b1a46d1a171d865aa5f83f92695765caa047a9b4cbae2cbf37dbd613a793fd4c" [[package]] name = "js-sys" -version = "0.3.66" +version = "0.3.68" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cee9c64da59eae3b50095c18d3e74f8b73c0b86d2792824ff01bbce68ba229ca" +checksum = "406cda4b368d531c842222cf9d2600a9a4acce8d29423695379c6868a143a9ee" dependencies = [ "wasm-bindgen", ] @@ -1071,9 +1087,9 @@ checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646" [[package]] name = "libc" -version = "0.2.150" +version = "0.2.153" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "89d92a4743f9a61002fae18374ed11e7973f530cb3a3255fb354818118b2203c" +checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd" [[package]] name = "libredox" @@ -1081,16 +1097,16 @@ version = "0.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "85c833ca1e66078851dba29046874e38f08b2c883700aa29a03ddd3b23814ee8" dependencies = [ - "bitflags 2.4.1", + "bitflags 2.4.2", "libc", "redox_syscall 0.4.1", ] [[package]] name = "linux-raw-sys" -version = "0.4.12" +version = "0.4.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c4cd1a83af159aa67994778be9070f0ae1bd732942279cabb14f86f986a21456" +checksum = "01cda141df6706de531b6c46c3a33ecca755538219bd484262fa09410c13539c" [[package]] name = "lock_api" @@ -1104,9 +1120,9 @@ dependencies = [ [[package]] name = "log" -version = "0.4.20" +version = "0.4.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b5e6163cb8c49088c2c36f57875e58ccd8c87c7427f7fbd50ea6710b2f3f2e8f" +checksum = "90ed8c1e510134f979dbc4f070f87d4313098b704861a105fe34231c70a3901c" [[package]] name = "matchers" @@ -1130,24 +1146,24 @@ dependencies = [ [[package]] name = "memchr" -version = "2.6.4" +version = "2.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f665ee40bc4a3c5590afb1e9677db74a508659dfd71e126420da8274909a0167" +checksum = "523dc4f511e55ab87b694dc30d0f820d60906ef06413f93d4d7a1385599cc149" [[package]] name = "miniz_oxide" -version = "0.7.1" +version = "0.7.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e7810e0be55b428ada41041c41f32c9f1a42817901b4ccf45fa3d4b6561e74c7" +checksum = "9d811f3e15f28568be3407c8e7fdb6514c1cda3cb30683f15b6a1a1dc4ea14a7" dependencies = [ "adler", ] [[package]] name = "mio" -version = "0.8.9" +version = "0.8.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3dce281c5e46beae905d4de1870d8b1509a9142b62eedf18b443b011ca8343d0" +checksum = "8f3d0b296e374a4e6f3c7b0a1f5a51d748a0d34c85e7dc48fc3fa9a87657fe09" dependencies = [ "libc", "wasi 0.11.0+wasi-snapshot-preview1", @@ -1182,21 +1198,26 @@ dependencies = [ "winapi", ] +[[package]] +name = "num-conv" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "51d515d32fb182ee37cda2ccdcb92950d6a3c2893aa280e540671c2cd0f3b1d9" + [[package]] name = "num-integer" -version = "0.1.45" +version = "0.1.46" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "225d3389fb3509a24c93f5c29eb6bde2586b98d9f016636dff58d7c6f7569cd9" +checksum = "7969661fd2958a5cb096e56c8e1ad0444ac2bbcd0061bd28660485a44879858f" dependencies = [ - "autocfg", "num-traits", ] [[package]] name = "num-traits" -version = "0.2.17" +version = "0.2.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39e3200413f237f41ab11ad6d161bc7239c84dcb631773ccd7de3dfe4b5c267c" +checksum = "da0df0e5185db44f69b44f26786fe401b6c293d1907744beaa7fa62b2e5a517a" dependencies = [ "autocfg", ] @@ -1213,18 +1234,18 @@ dependencies = [ [[package]] name = "object" -version = "0.32.1" +version = "0.32.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9cf5f9dd3933bd50a9e1f149ec995f39ae2c496d31fd772c1fd45ebc27e902b0" +checksum = "a6a622008b6e321afc04970976f62ee297fdbaa6f95318ca343e3eebb9648441" dependencies = [ "memchr", ] [[package]] name = "once_cell" -version = "1.18.0" +version = "1.19.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" +checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" [[package]] name = "opaque-debug" @@ -1234,11 +1255,11 @@ checksum = "624a8340c38c1b80fd549087862da4ba43e08858af025b236e509b6649fc13d5" [[package]] name = "openssl" -version = "0.10.60" +version = "0.10.64" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "79a4c6c3a2b158f7f8f2a2fc5a969fa3a068df6fc9dbb4a43845436e3af7c800" +checksum = "95a0481286a310808298130d22dd1fef0fa571e05a8f44ec801801e84b216b1f" dependencies = [ - "bitflags 2.4.1", + "bitflags 2.4.2", "cfg-if", "foreign-types", "libc", @@ -1255,7 +1276,7 @@ checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", ] [[package]] @@ -1266,9 +1287,9 @@ checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" [[package]] name = "openssl-sys" -version = "0.9.96" +version = "0.9.101" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3812c071ba60da8b5677cc12bcb1d42989a65553772897a7e0355545a819838f" +checksum = "dda2b0f344e78efc2facf7d195d098df0dd72151b26ab98da807afc26c198dff" dependencies = [ "cc", "libc", @@ -1315,9 +1336,9 @@ dependencies = [ [[package]] name = "paste" -version = "1.0.14" +version = "1.0.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "de3145af08024dea9fa9914f381a17b8fc6034dfb00f3a84013f7ff43f29ed4c" +checksum = "57c0d7b74b563b49d38dae00a0c37d4d6de9b432382b2892f0574ddcae73fd0a" [[package]] name = "percent-encoding" @@ -1339,9 +1360,9 @@ checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" [[package]] name = "pkg-config" -version = "0.3.27" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26072860ba924cbfa98ea39c8c19b4dd6a4a25423dbdf219c1eca91aa0cf6964" +checksum = "d231b230927b5e4ad203db57bbcbee2802f6bce620b1e4a9024a07d94e2907ec" [[package]] name = "powerfmt" @@ -1373,9 +1394,9 @@ checksum = "dc375e1527247fe1a97d8b7156678dfe7c1af2fc075c9a4db3690ecd2a148068" [[package]] name = "proc-macro2" -version = "1.0.70" +version = "1.0.84" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39278fbbf5fb4f646ce651690877f89d1c5811a3d4acb27700c1cb3cdb78fd3b" +checksum = "ec96c6a92621310b51366f1e28d05ef11489516e93be030060e5fc12024a49d6" dependencies = [ "unicode-ident", ] @@ -1406,9 +1427,9 @@ dependencies = [ [[package]] name = "quote" -version = "1.0.33" +version = "1.0.36" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5267fca4496028628a95160fc423a33e8b2e6af8a5302579e322e4b520293cae" +checksum = "0fa76aaf39101c457836aec0ce2316dbdc3ab723cdda1c6bd4e6ad4208acaca7" dependencies = [ "proc-macro2", ] @@ -1423,8 +1444,8 @@ dependencies = [ "aws-sdk-dynamodb", "aws-smithy-runtime", "aws-smithy-runtime-api", - "base64 0.21.5", - "hyper-rustls 0.24.2", + "base64 0.22.1", + "hyper-rustls 0.25.0", "paste", "pretty_assertions", "raiden", @@ -1438,7 +1459,7 @@ dependencies = [ "serde_derive", "serde_json", "thiserror", - "time 0.3.30", + "time 0.3.36", "tokio", "tracing", "tracing-subscriber", @@ -1453,7 +1474,7 @@ dependencies = [ "ident_case", "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", ] [[package]] @@ -1568,20 +1589,20 @@ version = "0.4.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a18479200779601e498ada4e8c1e1f50e3ee19deb0259c25825a98b5603b2cb4" dependencies = [ - "getrandom 0.2.11", + "getrandom 0.2.12", "libredox", "thiserror", ] [[package]] name = "regex" -version = "1.10.2" +version = "1.10.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "380b951a9c5e80ddfd6136919eef32310721aa4aacd4889a8d39124b026ab343" +checksum = "b62dbe01f0b06f9d8dc7d49e05a0785f153b00b2c227856282f671e0318c9b15" dependencies = [ "aho-corasick", "memchr", - "regex-automata 0.4.3", + "regex-automata 0.4.5", "regex-syntax 0.8.2", ] @@ -1596,15 +1617,21 @@ dependencies = [ [[package]] name = "regex-automata" -version = "0.4.3" +version = "0.4.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f804c7828047e88b2d32e2d7fe5a105da8ee3264f01902f796c8e067dc2483f" +checksum = "5bb987efffd3c6d0d8f5f89510bb458559eab11e4f869acb20bf845e016259cd" dependencies = [ "aho-corasick", "memchr", "regex-syntax 0.8.2", ] +[[package]] +name = "regex-lite" +version = "0.1.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "30b661b2f27137bdbc16f00eda72866a92bb28af1753ffbd56744fb6e2e9cd8e" + [[package]] name = "regex-syntax" version = "0.6.29" @@ -1634,16 +1661,17 @@ dependencies = [ [[package]] name = "ring" -version = "0.17.6" +version = "0.17.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "684d5e6e18f669ccebf64a92236bb7db9a34f07be010e3627368182027180866" +checksum = "c17fa4cb658e3583423e915b9f3acc01cceaee1860e33d59ebae66adc3a2dc0d" dependencies = [ "cc", - "getrandom 0.2.11", + "cfg-if", + "getrandom 0.2.12", "libc", "spin 0.9.8", "untrusted 0.9.0", - "windows-sys 0.48.0", + "windows-sys 0.52.0", ] [[package]] @@ -1657,7 +1685,7 @@ dependencies = [ "bytes", "crc32fast", "futures", - "http", + "http 0.2.11", "hyper", "hyper-rustls 0.23.2", "hyper-tls", @@ -1717,7 +1745,7 @@ dependencies = [ "futures", "hex", "hmac 0.11.0", - "http", + "http 0.2.11", "hyper", "log", "md-5", @@ -1766,11 +1794,11 @@ dependencies = [ [[package]] name = "rustix" -version = "0.38.26" +version = "0.38.31" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9470c4bf8246c8daf25f9598dca807fb6510347b1e1cfa55749113850c79d88a" +checksum = "6ea3e1a662af26cd7a3ba09c0297a31af215563ecf42817c98df621387f4e949" dependencies = [ - "bitflags 2.4.1", + "bitflags 2.4.2", "errno", "libc", "linux-raw-sys", @@ -1791,16 +1819,28 @@ dependencies = [ [[package]] name = "rustls" -version = "0.21.9" +version = "0.21.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "629648aced5775d558af50b2b4c7b02983a04b312126d45eeead26e7caa498b9" +checksum = "f9d5a6813c0759e4609cd494e8e725babae6a2ca7b62a5536a13daaec6fcb7ba" dependencies = [ "log", - "ring 0.17.6", - "rustls-webpki", + "ring 0.17.8", + "rustls-webpki 0.101.7", "sct", ] +[[package]] +name = "rustls" +version = "0.22.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e87c9956bd9807afa1f77e0f7594af32566e830e088a5576d27c5b6f30f49d41" +dependencies = [ + "rustls-pki-types", + "rustls-webpki 0.102.2", + "subtle", + "zeroize", +] + [[package]] name = "rustls-native-certs" version = "0.6.3" @@ -1808,7 +1848,20 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a9aace74cb666635c918e9c12bc0d348266037aa8eb599b5cba565709a8dff00" dependencies = [ "openssl-probe", - "rustls-pemfile", + "rustls-pemfile 1.0.4", + "schannel", + "security-framework", +] + +[[package]] +name = "rustls-native-certs" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f1fb85efa936c42c6d5fc28d2629bb51e4b2f4b8a5211e297d599cc5a093792" +dependencies = [ + "openssl-probe", + "rustls-pemfile 2.1.0", + "rustls-pki-types", "schannel", "security-framework", ] @@ -1819,24 +1872,51 @@ version = "1.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1c74cae0a4cf6ccbbf5f359f08efdf8ee7e1dc532573bf0db71968cb56b1448c" dependencies = [ - "base64 0.21.5", + "base64 0.21.7", ] +[[package]] +name = "rustls-pemfile" +version = "2.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c333bb734fcdedcea57de1602543590f545f127dc8b533324318fd492c5c70b" +dependencies = [ + "base64 0.21.7", + "rustls-pki-types", +] + +[[package]] +name = "rustls-pki-types" +version = "1.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5ede67b28608b4c60685c7d54122d4400d90f62b40caee7700e700380a390fa8" + [[package]] name = "rustls-webpki" version = "0.101.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8b6275d1ee7a1cd780b64aca7726599a1dbc893b1e64144529e55c3c2f745765" dependencies = [ - "ring 0.17.6", + "ring 0.17.8", + "untrusted 0.9.0", +] + +[[package]] +name = "rustls-webpki" +version = "0.102.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "faaa0a62740bedb9b2ef5afa303da42764c012f743917351dc9a237ea1663610" +dependencies = [ + "ring 0.17.8", + "rustls-pki-types", "untrusted 0.9.0", ] [[package]] name = "ryu" -version = "1.0.15" +version = "1.0.17" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1ad4cc8da4ef723ed60bced201181d83791ad433213d8c24efffda1eec85d741" +checksum = "e86697c916019a8588c99b5fac3cead74ec0b4b819707a682fd4d23fa0ce1ba1" [[package]] name = "safe-builder" @@ -1860,11 +1940,11 @@ dependencies = [ [[package]] name = "schannel" -version = "0.1.22" +version = "0.1.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0c3733bf4cf7ea0880754e19cb5a462007c4a8c1914bff372ccc95b464f1df88" +checksum = "fbc91545643bcf3a0bbb6569265615222618bdf33ce4ffbbd13c4bbd4c093534" dependencies = [ - "windows-sys 0.48.0", + "windows-sys 0.52.0", ] [[package]] @@ -1879,7 +1959,7 @@ version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "da046153aa2352493d6cb7da4b6e5c0c057d8a1d0a9aa8560baffdd945acd414" dependencies = [ - "ring 0.17.6", + "ring 0.17.8", "untrusted 0.9.0", ] @@ -1908,35 +1988,35 @@ dependencies = [ [[package]] name = "semver" -version = "1.0.20" +version = "1.0.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "836fa6a3e1e547f9a2c4040802ec865b5d85f4014efe00555d7090a3dcaa1090" +checksum = "92d43fe69e652f3df9bdc2b85b2854a0825b86e4fb76bc44d945137d053639ca" [[package]] name = "serde" -version = "1.0.193" +version = "1.0.197" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "25dd9975e68d0cb5aa1120c288333fc98731bd1dd12f561e468ea4728c042b89" +checksum = "3fb1c873e1b9b056a4dc4c0c198b24c3ffa059243875552b2bd0933b1aee4ce2" dependencies = [ "serde_derive", ] [[package]] name = "serde_derive" -version = "1.0.193" +version = "1.0.197" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "43576ca501357b9b071ac53cdc7da8ef0cbd9493d8df094cd821777ea6e894d3" +checksum = "7eb0b34b42edc17f6b7cac84a52a1c5f0e1bb2227e997ca9011ea3dd34e8610b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", ] [[package]] name = "serde_json" -version = "1.0.108" +version = "1.0.114" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3d1c7e3eac408d115102c4c24ad393e0821bb3a5df4d506a80f85f7a742a526b" +checksum = "c5f09b1bd632ef549eaa9f60a1f8de742bdbc698e6cee2095fc84dde5f549ae0" dependencies = [ "itoa", "ryu", @@ -1978,9 +2058,9 @@ dependencies = [ [[package]] name = "shlex" -version = "1.2.0" +version = "1.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a7cee0529a6d40f580e7a5e6c495c8fbfe21b7b52795ed4bb5e62cdf92bc6380" +checksum = "0fda2ff0d084019ba4d7c6f371c95d8fd75ce3524c3cb8fb653a3023f6323e64" [[package]] name = "signal-hook-registry" @@ -2002,28 +2082,18 @@ dependencies = [ [[package]] name = "smallvec" -version = "1.11.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4dccd0940a2dcdf68d092b8cbab7dc0ad8fa938bf95787e1b916b0e3d0e8e970" - -[[package]] -name = "socket2" -version = "0.4.10" +version = "1.13.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9f7916fc008ca5542385b89a3d3ce689953c143e9304a9bf8beec1de48994c0d" -dependencies = [ - "libc", - "winapi", -] +checksum = "e6ecd384b10a64542d77071bd64bd7b231f4ed5940fba55e98c3de13824cf3d7" [[package]] name = "socket2" -version = "0.5.5" +version = "0.5.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b5fac59a5cb5dd637972e5fca70daf0523c9067fcdc4842f053dae04a18f8e9" +checksum = "05ffd9c0a93b7543e062e759284fcf5f5e3b098501104bfbdde4d404db792871" dependencies = [ "libc", - "windows-sys 0.48.0", + "windows-sys 0.52.0", ] [[package]] @@ -2040,9 +2110,9 @@ checksum = "6980e8d7511241f8acf4aebddbb1ff938df5eebe98691418c4468d0b72a96a67" [[package]] name = "subtle" -version = "2.4.1" +version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6bdef32e8150c2a081110b42772ffe7d7c9032b606bc226c8260fd97e0976601" +checksum = "81cdd64d312baedb58e21336b31bc043b77e01cc99033ce76ef539f78e965ebc" [[package]] name = "syn" @@ -2057,9 +2127,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.39" +version = "2.0.66" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "23e78b90f2fcf45d3e842032ce32e3f2d1545ba6636271dcbf24fa306d87be7a" +checksum = "c42f3f41a2de00b01c0aaad383c5a45241efc8b2d1eda5661812fda5f3cdcff5" dependencies = [ "proc-macro2", "quote", @@ -2068,42 +2138,41 @@ dependencies = [ [[package]] name = "tempfile" -version = "3.8.1" +version = "3.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7ef1adac450ad7f4b3c28589471ade84f25f731a7a0fe30d71dfa9f60fd808e5" +checksum = "85b77fafb263dd9d05cbeac119526425676db3784113aa9295c88498cbf8bff1" dependencies = [ "cfg-if", "fastrand", - "redox_syscall 0.4.1", "rustix", - "windows-sys 0.48.0", + "windows-sys 0.52.0", ] [[package]] name = "thiserror" -version = "1.0.50" +version = "1.0.57" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f9a7210f5c9a7156bb50aa36aed4c95afb51df0df00713949448cf9e97d382d2" +checksum = "1e45bcbe8ed29775f228095caf2cd67af7a4ccf756ebff23a306bf3e8b47b24b" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.50" +version = "1.0.57" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "266b2e40bc00e5a6c09c3584011e08b06f123c00362c92b975ba9843aaaa14b8" +checksum = "a953cb265bef375dae3de6663da4d3804eee9682ea80d8e2542529b73c531c81" dependencies = [ "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", ] [[package]] name = "thread_local" -version = "1.1.7" +version = "1.1.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3fdd6f064ccff2d6567adcb3873ca630700f00b5ad3f060c25b5dcfd9a4ce152" +checksum = "8b9ef9bad013ada3808854ceac7b46812a6465ba368859a37e2100283d2d719c" dependencies = [ "cfg-if", "once_cell", @@ -2122,12 +2191,13 @@ dependencies = [ [[package]] name = "time" -version = "0.3.30" +version = "0.3.36" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c4a34ab300f2dee6e562c10a046fc05e358b29f9bf92277f30c3c8d82275f6f5" +checksum = "5dfd88e563464686c916c7e46e623e520ddc6d79fa6641390f2e3fa86e83e885" dependencies = [ "deranged", "itoa", + "num-conv", "powerfmt", "serde", "time-core", @@ -2142,18 +2212,19 @@ checksum = "ef927ca75afb808a4d64dd374f00a2adf8d0fcff8e7b184af886c3c87ec4a3f3" [[package]] name = "time-macros" -version = "0.2.15" +version = "0.2.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4ad70d68dba9e1f8aceda7aa6711965dfec1cac869f311a51bd08b3a2ccbce20" +checksum = "3f252a68540fde3a3877aeea552b832b40ab9a69e318efd078774a01ddee1ccf" dependencies = [ + "num-conv", "time-core", ] [[package]] name = "tokio" -version = "1.34.0" +version = "1.36.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d0c014766411e834f7af5b8f4cf46257aab4036ca95e9d2c144a10f59ad6f5b9" +checksum = "61285f6515fa018fb2d1e46eb21223fff441ee8db5d0f1435e8ab4f5cdb80931" dependencies = [ "backtrace", "bytes", @@ -2162,7 +2233,7 @@ dependencies = [ "num_cpus", "pin-project-lite", "signal-hook-registry", - "socket2 0.5.5", + "socket2", "tokio-macros", "windows-sys 0.48.0", ] @@ -2175,7 +2246,7 @@ checksum = "5b8a1e28f2deaa14e508979454cb3a223b10b938b45af148bc0986de36f1923b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", ] [[package]] @@ -2205,7 +2276,18 @@ version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c28327cf380ac148141087fbfb9de9d7bd4e84ab5d2c28fbc911d753de8a7081" dependencies = [ - "rustls 0.21.9", + "rustls 0.21.10", + "tokio", +] + +[[package]] +name = "tokio-rustls" +version = "0.25.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "775e0c0f0adb3a2f22a00c4745d728b479985fc15ee7ca6a2608388c5569860f" +dependencies = [ + "rustls 0.22.2", + "rustls-pki-types", "tokio", ] @@ -2248,7 +2330,7 @@ checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", ] [[package]] @@ -2285,7 +2367,7 @@ dependencies = [ "sharded-slab", "smallvec", "thread_local", - "time 0.3.30", + "time 0.3.36", "tracing", "tracing-core", "tracing-log", @@ -2293,9 +2375,9 @@ dependencies = [ [[package]] name = "try-lock" -version = "0.2.4" +version = "0.2.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3528ecfd12c466c6f163363caf2d02a71161dd5e1cc6ae7b34207ea2d42d81ed" +checksum = "e421abadd41a4225275504ea4d6566923418b7f05506fbc9c0fe86ba7396114b" [[package]] name = "typenum" @@ -2311,9 +2393,9 @@ checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" [[package]] name = "unicode-segmentation" -version = "1.10.1" +version = "1.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1dd624098567895118886609431a7c3b8f516e41d30e0643f03d94592a147e36" +checksum = "d4c87d22b6e3f4a18d4d40ef354e97c90fcb14dd91d7dc0aa9d8a1172ebf7202" [[package]] name = "untrusted" @@ -2335,11 +2417,11 @@ checksum = "daf8dba3b7eb870caf1ddeed7bc9d2a049f3cfdfae7cb521b087cc33ae4c49da" [[package]] name = "uuid" -version = "1.6.1" +version = "1.8.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5e395fcf16a7a3d8127ec99782007af141946b4795001f876d54fb0d55978560" +checksum = "a183cf7feeba97b4dd1c0d46788634f6221d87fa961b305bed08c851829efcc0" dependencies = [ - "getrandom 0.2.11", + "getrandom 0.2.12", ] [[package]] @@ -2395,9 +2477,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.89" +version = "0.2.91" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0ed0d4f68a3015cc185aff4db9506a015f4b96f95303897bfa23f846db54064e" +checksum = "c1e124130aee3fb58c5bdd6b639a0509486b0338acaaae0c84a5124b0f588b7f" dependencies = [ "cfg-if", "wasm-bindgen-macro", @@ -2405,24 +2487,24 @@ dependencies = [ [[package]] name = "wasm-bindgen-backend" -version = "0.2.89" +version = "0.2.91" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1b56f625e64f3a1084ded111c4d5f477df9f8c92df113852fa5a374dbda78826" +checksum = "c9e7e1900c352b609c8488ad12639a311045f40a35491fb69ba8c12f758af70b" dependencies = [ "bumpalo", "log", "once_cell", "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-futures" -version = "0.4.39" +version = "0.4.41" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ac36a15a220124ac510204aec1c3e5db8a22ab06fd6706d881dc6149f8ed9a12" +checksum = "877b9c3f61ceea0e56331985743b13f3d25c406a7098d45180fb5f09bc19ed97" dependencies = [ "cfg-if", "js-sys", @@ -2432,9 +2514,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro" -version = "0.2.89" +version = "0.2.91" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0162dbf37223cd2afce98f3d0785506dcb8d266223983e4b5b525859e6e182b2" +checksum = "b30af9e2d358182b5c7449424f017eba305ed32a7010509ede96cdc4696c46ed" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -2442,22 +2524,22 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.89" +version = "0.2.91" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f0eb82fcb7930ae6219a7ecfd55b217f5f0893484b7a13022ebb2b2bf20b5283" +checksum = "642f325be6301eb8107a83d12a8ac6c1e1c54345a7ef1a9261962dfefda09e66" dependencies = [ "proc-macro2", "quote", - "syn 2.0.39", + "syn 2.0.66", "wasm-bindgen-backend", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-shared" -version = "0.2.89" +version = "0.2.91" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7ab9b36309365056cd639da3134bf87fa8f3d86008abf99e612384a6eecd459f" +checksum = "4f186bd2dcf04330886ce82d6f33dd75a7bfcf69ecf5763b89fcde53b6ac9838" [[package]] name = "wasm-timer" @@ -2476,9 +2558,9 @@ dependencies = [ [[package]] name = "web-sys" -version = "0.3.66" +version = "0.3.68" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "50c24a44ec86bb68fbecd1b3efed7e85ea5621b39b35ef2766b66cd984f8010f" +checksum = "96565907687f7aceb35bc5fc03770a8a0471d82e479f25832f54a0e3f4b28446" dependencies = [ "js-sys", "wasm-bindgen", @@ -2490,7 +2572,7 @@ version = "0.22.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ed63aea5ce73d0ff405984102c42de94fc55a6b75765d621c65262469b3c9b53" dependencies = [ - "ring 0.17.6", + "ring 0.17.8", "untrusted 0.9.0", ] @@ -2518,11 +2600,11 @@ checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" [[package]] name = "windows-core" -version = "0.51.1" +version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1f8cf84f35d2db49a46868f947758c7a1138116f7fac3bc844f43ade1292e64" +checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" dependencies = [ - "windows-targets 0.48.5", + "windows-targets 0.52.4", ] [[package]] @@ -2540,7 +2622,7 @@ version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" dependencies = [ - "windows-targets 0.52.0", + "windows-targets 0.52.4", ] [[package]] @@ -2560,17 +2642,17 @@ dependencies = [ [[package]] name = "windows-targets" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a18201040b24831fbb9e4eb208f8892e1f50a37feb53cc7ff887feb8f50e7cd" +checksum = "7dd37b7e5ab9018759f893a1952c9420d060016fc19a472b4bb20d1bdd694d1b" dependencies = [ - "windows_aarch64_gnullvm 0.52.0", - "windows_aarch64_msvc 0.52.0", - "windows_i686_gnu 0.52.0", - "windows_i686_msvc 0.52.0", - "windows_x86_64_gnu 0.52.0", - "windows_x86_64_gnullvm 0.52.0", - "windows_x86_64_msvc 0.52.0", + "windows_aarch64_gnullvm 0.52.4", + "windows_aarch64_msvc 0.52.4", + "windows_i686_gnu 0.52.4", + "windows_i686_msvc 0.52.4", + "windows_x86_64_gnu 0.52.4", + "windows_x86_64_gnullvm 0.52.4", + "windows_x86_64_msvc 0.52.4", ] [[package]] @@ -2581,9 +2663,9 @@ checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" [[package]] name = "windows_aarch64_gnullvm" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cb7764e35d4db8a7921e09562a0304bf2f93e0a51bfccee0bd0bb0b666b015ea" +checksum = "bcf46cf4c365c6f2d1cc93ce535f2c8b244591df96ceee75d8e83deb70a9cac9" [[package]] name = "windows_aarch64_msvc" @@ -2593,9 +2675,9 @@ checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" [[package]] name = "windows_aarch64_msvc" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bbaa0368d4f1d2aaefc55b6fcfee13f41544ddf36801e793edbbfd7d7df075ef" +checksum = "da9f259dd3bcf6990b55bffd094c4f7235817ba4ceebde8e6d11cd0c5633b675" [[package]] name = "windows_i686_gnu" @@ -2605,9 +2687,9 @@ checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" [[package]] name = "windows_i686_gnu" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a28637cb1fa3560a16915793afb20081aba2c92ee8af57b4d5f28e4b3e7df313" +checksum = "b474d8268f99e0995f25b9f095bc7434632601028cf86590aea5c8a5cb7801d3" [[package]] name = "windows_i686_msvc" @@ -2617,9 +2699,9 @@ checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" [[package]] name = "windows_i686_msvc" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ffe5e8e31046ce6230cc7215707b816e339ff4d4d67c65dffa206fd0f7aa7b9a" +checksum = "1515e9a29e5bed743cb4415a9ecf5dfca648ce85ee42e15873c3cd8610ff8e02" [[package]] name = "windows_x86_64_gnu" @@ -2629,9 +2711,9 @@ checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" [[package]] name = "windows_x86_64_gnu" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3d6fa32db2bc4a2f5abeacf2b69f7992cd09dca97498da74a151a3132c26befd" +checksum = "5eee091590e89cc02ad514ffe3ead9eb6b660aedca2183455434b93546371a03" [[package]] name = "windows_x86_64_gnullvm" @@ -2641,9 +2723,9 @@ checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" [[package]] name = "windows_x86_64_gnullvm" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1a657e1e9d3f514745a572a6846d3c7aa7dbe1658c056ed9c3344c4109a6949e" +checksum = "77ca79f2451b49fa9e2af39f0747fe999fcda4f5e241b2898624dca97a1f2177" [[package]] name = "windows_x86_64_msvc" @@ -2653,9 +2735,9 @@ checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" [[package]] name = "windows_x86_64_msvc" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dff9641d1cd4be8d1a070daf9e3773c5f67e78b4d9d42263020c057706765c04" +checksum = "32b752e52a2da0ddfbdbcc6fceadfeede4c939ed16d13e648833a61dfb611ed8" [[package]] name = "xml-rs" diff --git a/raiden-derive/Cargo.toml b/raiden-derive/Cargo.toml index efda9bd5..dbdcb15d 100644 --- a/raiden-derive/Cargo.toml +++ b/raiden-derive/Cargo.toml @@ -12,9 +12,9 @@ proc-macro = true [dependencies] convert_case = "^0.6.0" ident_case = "^1.0.1" -proc-macro2 = "^1.0.70" -quote = "^1.0.33" -syn = "^2.0.39" +proc-macro2 = "^1.0.84" +quote = "^1.0.36" +syn = "^2.0.66" [features] default = ["rusoto"] diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index d8eeef14..e18491dd 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -11,19 +11,12 @@ again = "0.1" aws-config = { version = "^1", optional = true } aws-sdk-dynamodb = { version = "^1", optional = true } aws-smithy-runtime-api = { version = "^1", optional = true } -base64 = "^0.21" -paste = { version = "1.0.14", optional = true } +base64 = "^0.22" +paste = { version = "1.0.15", optional = true } raiden-derive = { version = "*", path = "../raiden-derive", default_features = false } -rusoto_core_default = { package = "rusoto_core", version = "0.48", optional = true } -rusoto_core_rustls = { package = "rusoto_core", version = "0.48", default_features = false, features = [ - "rustls", -], optional = true } +rusoto_core = { package = "rusoto_core", version = "0.48", default_features = false, optional = true } rusoto_credential = { version = "0.48", optional = true } -rusoto_dynamodb_default = { package = "rusoto_dynamodb", version = "0.48", features = [ - "serialize_structs", -], optional = true } -rusoto_dynamodb_rustls = { package = "rusoto_dynamodb", version = "0.48", default_features = false, features = [ - "rustls", +rusoto_dynamodb = { package = "rusoto_dynamodb", version = "0.48", default_features = false, features = [ "serialize_structs", ], optional = true } rust-crypto = "^0.2.36" @@ -33,24 +26,23 @@ serde_derive = "^1" serde_json = "^1" thiserror = "^1" tracing = { version = "0.1", optional = true } -uuid = { version = "^1.6", features = ["v4"] } +uuid = { version = "^1.8", features = ["v4"] } [dev-dependencies] -aws-credential-types = "1.0.1" +aws-credential-types = "1.2.0" aws-smithy-runtime = { version = "^1" } -hyper-rustls = { version = "0.24", default-features = false, features = [ +hyper-rustls = { version = "0.25", default-features = false, features = [ "http1", "http2", "native-tokio", ] } pretty_assertions = "1.4.0" raiden = { path = "./", features = ["tracing"], default_features = false } -time = "0.3.30" +time = "0.3.36" tokio = { version = "^1", features = ["rt-multi-thread", "macros"] } tracing-subscriber = { version = "0.3", features = ["env-filter", "time"] } - [features] default = ["rusoto"] aws-sdk = [ @@ -61,15 +53,15 @@ aws-sdk = [ "raiden-derive/aws-sdk", ] rusoto = [ - "dep:rusoto_core_default", - "dep:rusoto_credential", - "dep:rusoto_dynamodb_default", + "rusoto_core/default", + "rusoto_credential", + "rusoto_dynamodb/default", "raiden-derive/rusoto", ] rusoto_rustls = [ - "dep:rusoto_core_rustls", - "dep:rusoto_credential", - "dep:rusoto_dynamodb_rustls", + "rusoto_core/rustls", + "rusoto_credential", + "rusoto_dynamodb/rustls", "raiden-derive/rusoto", ] rustls = ["rusoto_rustls"] diff --git a/raiden/src/rusoto/mod.rs b/raiden/src/rusoto/mod.rs index 66749eab..a1ba962b 100644 --- a/raiden/src/rusoto/mod.rs +++ b/raiden/src/rusoto/mod.rs @@ -1,17 +1,11 @@ mod errors; mod ops; -#[cfg(feature = "rusoto")] -pub use rusoto_dynamodb_default::*; +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +pub use rusoto_dynamodb::*; -#[cfg(feature = "rusoto")] -pub use rusoto_core_default::*; - -#[cfg(feature = "rusoto_rustls")] -pub use rusoto_dynamodb_rustls::*; - -#[cfg(feature = "rusoto_rustls")] -pub use rusoto_core_rustls::*; +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +pub use rusoto_core::*; pub use self::{errors::*, ops::*}; pub use rusoto_credential::*; diff --git a/rust-toolchain b/rust-toolchain index ee2f4ca9..7c7053aa 100644 --- a/rust-toolchain +++ b/rust-toolchain @@ -1 +1 @@ -1.68.0 +1.75.0 From c5a3c98e984d1465bf2677ebdc668a001565aea0 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Wed, 29 May 2024 18:45:29 +0900 Subject: [PATCH 09/22] fix: clippy warnings --- Cargo.lock | 29 ++++++++++--------- makefile | 2 +- raiden-derive/src/finder/mod.rs | 8 ++--- raiden/Cargo.toml | 13 +++++---- .../transact_write_with_http_client.rs | 1 + raiden/examples/with_http_client.rs | 1 + raiden/src/aws_sdk/mod.rs | 2 +- raiden/src/aws_sdk/ops/mod.rs | 7 ----- raiden/src/retry/mod.rs | 4 ++- raiden/src/rusoto/mod.rs | 2 +- 10 files changed, 35 insertions(+), 34 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 23f873ac..e11d0bd8 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -996,7 +996,8 @@ dependencies = [ "futures-util", "http 0.2.11", "hyper", - "rustls 0.22.2", + "log", + "rustls 0.22.4", "rustls-native-certs 0.7.0", "rustls-pki-types", "tokio", @@ -1831,12 +1832,14 @@ dependencies = [ [[package]] name = "rustls" -version = "0.22.2" +version = "0.22.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e87c9956bd9807afa1f77e0f7594af32566e830e088a5576d27c5b6f30f49d41" +checksum = "bf4ef73721ac7bcd79b2b315da7779d8fc09718c6b3d2d1b2d94850eb8c18432" dependencies = [ + "log", + "ring 0.17.8", "rustls-pki-types", - "rustls-webpki 0.102.2", + "rustls-webpki 0.102.4", "subtle", "zeroize", ] @@ -1860,7 +1863,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8f1fb85efa936c42c6d5fc28d2629bb51e4b2f4b8a5211e297d599cc5a093792" dependencies = [ "openssl-probe", - "rustls-pemfile 2.1.0", + "rustls-pemfile 2.1.2", "rustls-pki-types", "schannel", "security-framework", @@ -1877,19 +1880,19 @@ dependencies = [ [[package]] name = "rustls-pemfile" -version = "2.1.0" +version = "2.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c333bb734fcdedcea57de1602543590f545f127dc8b533324318fd492c5c70b" +checksum = "29993a25686778eb88d4189742cd713c9bce943bc54251a33509dc63cbacf73d" dependencies = [ - "base64 0.21.7", + "base64 0.22.1", "rustls-pki-types", ] [[package]] name = "rustls-pki-types" -version = "1.3.1" +version = "1.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5ede67b28608b4c60685c7d54122d4400d90f62b40caee7700e700380a390fa8" +checksum = "976295e77ce332211c0d24d92c0e83e50f5c5f046d11082cea19f3df13a3562d" [[package]] name = "rustls-webpki" @@ -1903,9 +1906,9 @@ dependencies = [ [[package]] name = "rustls-webpki" -version = "0.102.2" +version = "0.102.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "faaa0a62740bedb9b2ef5afa303da42764c012f743917351dc9a237ea1663610" +checksum = "ff448f7e92e913c4b7d4c6d8e4540a1724b319b4152b8aef6d4cf8339712b33e" dependencies = [ "ring 0.17.8", "rustls-pki-types", @@ -2286,7 +2289,7 @@ version = "0.25.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "775e0c0f0adb3a2f22a00c4745d728b479985fc15ee7ca6a2608388c5569860f" dependencies = [ - "rustls 0.22.2", + "rustls 0.22.4", "rustls-pki-types", "tokio", ] diff --git a/makefile b/makefile index d1a312ac..c57a0732 100644 --- a/makefile +++ b/makefile @@ -21,7 +21,7 @@ lint: .PHONY: check-deps check-deps: - cargo machete || echo + cargo machete cargo +nightly udeps --all-targets --features tracing cargo +nightly udeps --all-targets --no-default-features --features aws-sdk cargo +nightly udeps --all-targets --no-default-features --features rusoto diff --git a/raiden-derive/src/finder/mod.rs b/raiden-derive/src/finder/mod.rs index 4b2243fd..26fcad15 100644 --- a/raiden-derive/src/finder/mod.rs +++ b/raiden-derive/src/finder/mod.rs @@ -105,28 +105,28 @@ pub(crate) fn find_partition_key_field(fields: &syn::FieldsNamed) -> Option = fields .named .iter() - .cloned() .filter(|f| include_unary_attr(&f.attrs, "partition_key")) + .cloned() .collect(); if fields.len() > 1 { panic!("partition key should be only one.") } - fields.get(0).cloned() + fields.first().cloned() } pub(crate) fn find_sort_key_field(fields: &syn::FieldsNamed) -> Option { let fields: Vec = fields .named .iter() - .cloned() .filter(|f| include_unary_attr(&f.attrs, "sort_key")) + .cloned() .collect(); if fields.len() > 1 { panic!("sort key should be only one.") } - fields.get(0).cloned() + fields.first().cloned() } pub(crate) fn is_option(ty: &syn::Type) -> bool { diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index e18491dd..3c5969c8 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -28,15 +28,10 @@ thiserror = "^1" tracing = { version = "0.1", optional = true } uuid = { version = "^1.8", features = ["v4"] } - [dev-dependencies] aws-credential-types = "1.2.0" aws-smithy-runtime = { version = "^1" } -hyper-rustls = { version = "0.25", default-features = false, features = [ - "http1", - "http2", - "native-tokio", -] } +hyper-rustls = { version = "0.25", features = ["http2"] } pretty_assertions = "1.4.0" raiden = { path = "./", features = ["tracing"], default_features = false } time = "0.3.36" @@ -66,3 +61,9 @@ rusoto_rustls = [ ] rustls = ["rusoto_rustls"] tracing = ["dep:tracing", "raiden-derive/tracing"] + +[package.metadata.cargo-machete] +ignored = ["rust-crypto"] + +[package.metadata.cargo-udeps.ignore] +development = ["aws-credential-types", "aws-smithy-runtime", "hyper-rustls"] diff --git a/raiden/examples/transact_write_with_http_client.rs b/raiden/examples/transact_write_with_http_client.rs index cdfc5cb0..43e281ec 100644 --- a/raiden/examples/transact_write_with_http_client.rs +++ b/raiden/examples/transact_write_with_http_client.rs @@ -47,6 +47,7 @@ async fn example() { async fn example() { let https_connector = hyper_rustls::HttpsConnectorBuilder::new() .with_native_roots() + .expect("should be success") .https_or_http() .enable_http1() .enable_http2() diff --git a/raiden/examples/with_http_client.rs b/raiden/examples/with_http_client.rs index 196ba6dc..7160609e 100644 --- a/raiden/examples/with_http_client.rs +++ b/raiden/examples/with_http_client.rs @@ -40,6 +40,7 @@ async fn example() { async fn example() { let https_connector = hyper_rustls::HttpsConnectorBuilder::new() .with_native_roots() + .expect("should be success") .https_or_http() .enable_http1() .enable_http2() diff --git a/raiden/src/aws_sdk/mod.rs b/raiden/src/aws_sdk/mod.rs index 54cfb255..72de11f5 100644 --- a/raiden/src/aws_sdk/mod.rs +++ b/raiden/src/aws_sdk/mod.rs @@ -4,7 +4,7 @@ pub(crate) mod serialize; use std::collections::{BTreeSet, HashMap, HashSet}; -pub use self::{errors::*, ops::*}; +pub use self::ops::*; pub use aws_config as config; pub use aws_sdk_dynamodb::{ client::*, diff --git a/raiden/src/aws_sdk/ops/mod.rs b/raiden/src/aws_sdk/ops/mod.rs index d24fe9fb..868c061c 100644 --- a/raiden/src/aws_sdk/ops/mod.rs +++ b/raiden/src/aws_sdk/ops/mod.rs @@ -7,11 +7,4 @@ mod scan; mod transact_write; mod update; -pub use batch_delete::*; -pub use batch_get::*; -pub use get::*; -pub use put::*; -pub use query::*; -pub use scan::*; pub use transact_write::*; -pub use update::*; diff --git a/raiden/src/retry/mod.rs b/raiden/src/retry/mod.rs index ad1ddd87..8778b15e 100644 --- a/raiden/src/retry/mod.rs +++ b/raiden/src/retry/mod.rs @@ -1,4 +1,6 @@ -pub use again::{Condition, RetryPolicy}; +pub use again::RetryPolicy; + +use again::Condition; use std::time::Duration; use super::RaidenError; diff --git a/raiden/src/rusoto/mod.rs b/raiden/src/rusoto/mod.rs index a1ba962b..5c284f44 100644 --- a/raiden/src/rusoto/mod.rs +++ b/raiden/src/rusoto/mod.rs @@ -7,7 +7,7 @@ pub use rusoto_dynamodb::*; #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] pub use rusoto_core::*; -pub use self::{errors::*, ops::*}; +pub use self::ops::*; pub use rusoto_credential::*; use std::collections::{BTreeSet, HashSet}; From 3a764265768a139a686f55f9fdc1f2c06ebeb617 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Wed, 29 May 2024 23:00:55 +0900 Subject: [PATCH 10/22] chore: allow ambiguous glob re-exports for aws-sdk feature. --- raiden/src/lib.rs | 3 +++ raiden/src/ops/mod.rs | 3 +-- raiden/src/rusoto/ops.rs | 3 ++- 3 files changed, 6 insertions(+), 3 deletions(-) diff --git a/raiden/src/lib.rs b/raiden/src/lib.rs index daf44876..9749bb39 100644 --- a/raiden/src/lib.rs +++ b/raiden/src/lib.rs @@ -1,3 +1,6 @@ +// NOTE: allow to re-export aws_sdk_dynamodb. +#![cfg_attr(feature = "aws-sdk", allow(ambiguous_glob_reexports))] + #[cfg(all(feature = "rusoto", feature = "rusoto_rustls"))] compile_error!("feature \"rusoto\" and \"rusoto_rustls\" cannot be enabled at the same time."); diff --git a/raiden/src/ops/mod.rs b/raiden/src/ops/mod.rs index 6319914c..1be3fc2b 100644 --- a/raiden/src/ops/mod.rs +++ b/raiden/src/ops/mod.rs @@ -4,8 +4,7 @@ pub mod get; pub mod put; pub mod query; pub mod scan; -pub mod update; - pub mod transact_write; +pub mod update; pub use transact_write::*; diff --git a/raiden/src/rusoto/ops.rs b/raiden/src/rusoto/ops.rs index cd1c50fd..1482dc01 100644 --- a/raiden/src/rusoto/ops.rs +++ b/raiden/src/rusoto/ops.rs @@ -1,5 +1,6 @@ pub use transact_write::*; -pub mod transact_write { + +mod transact_write { use crate::{ DynamoDb, TransactWriteConditionCheckBuilder, TransactWriteDeleteBuilder, TransactWriteItem, TransactWritePutBuilder, TransactWriteUpdateBuilder, From 01410d89a16fe78060a070e213ba21a5cdb2ef42 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Fri, 31 May 2024 18:24:33 +0900 Subject: [PATCH 11/22] Some updates - chore: change import path on feature aws-sdk. - chore: add nop retry settings and use it on feature aws-sdk. - fix: run delete/scan api with retry policy. --- .github/workflows/ci.yml | 2 +- Cargo.lock | 141 ++++++++++++++---- README.md | 6 +- makefile | 5 +- raiden-derive/src/aws_sdk/client.rs | 14 +- raiden-derive/src/aws_sdk/ops/batch_delete.rs | 16 +- raiden-derive/src/aws_sdk/ops/batch_get.rs | 18 +-- raiden-derive/src/aws_sdk/ops/delete.rs | 20 +-- raiden-derive/src/aws_sdk/ops/get.rs | 18 +-- raiden-derive/src/aws_sdk/ops/put.rs | 12 +- raiden-derive/src/aws_sdk/ops/query.rs | 8 +- raiden-derive/src/aws_sdk/ops/scan.rs | 8 +- .../src/aws_sdk/ops/transact_write.rs | 40 ++--- raiden-derive/src/aws_sdk/ops/update.rs | 26 ++-- raiden-derive/src/condition/builder.rs | 9 +- raiden-derive/src/lib.rs | 4 +- raiden-derive/src/rusoto/ops/delete.rs | 24 ++- raiden-derive/src/rusoto/ops/scan.rs | 23 ++- raiden/Cargo.toml | 2 +- raiden/examples/delete.rs | 15 +- raiden/examples/get_with_reserved.rs | 26 ++-- raiden/examples/get_with_retries.rs | 28 ++-- raiden/examples/hello.rs | 50 ++++--- raiden/examples/last_key.rs | 25 ++-- raiden/examples/put.rs | 28 ++-- raiden/examples/query.rs | 27 +++- raiden/examples/query_rename.rs | 27 ++-- raiden/examples/scan.rs | 19 ++- raiden/examples/scan_with_filter.rs | 29 ++-- raiden/examples/transact_write.rs | 32 ++-- .../transact_write_with_http_client.rs | 46 +++--- raiden/examples/update.rs | 37 ++--- raiden/examples/with_http_client.rs | 46 +++--- raiden/src/aws_sdk/errors.rs | 15 +- raiden/src/aws_sdk/mod.rs | 26 +--- raiden/src/aws_sdk/ops/transact_write.rs | 19 ++- .../src/aws_sdk/serialize/attribute_value.rs | 3 +- .../aws_sdk/serialize/consumed_capacity.rs | 17 ++- .../src/aws_sdk/serialize/delete_request.rs | 11 +- .../serialize/item_collection_metrics.rs | 15 +- .../aws_sdk/serialize/keys_and_attributes.rs | 11 +- raiden/src/errors/mod.rs | 2 +- raiden/src/lib.rs | 9 +- raiden/src/ops/batch_delete.rs | 10 +- raiden/src/ops/batch_get.rs | 10 +- raiden/src/ops/get.rs | 8 +- raiden/src/ops/put.rs | 8 +- raiden/src/ops/query.rs | 8 +- raiden/src/ops/scan.rs | 10 +- raiden/src/ops/transact_write.rs | 14 +- raiden/src/ops/update.rs | 10 +- raiden/src/retry/mod.rs | 19 +++ raiden/tests/all/mod.rs | 32 ++-- raiden/tests/all/put.rs | 2 +- raiden/tests/all/transact_write.rs | 14 +- setup/fixtures/hello.ts | 26 ++++ setup/setup.ts | 102 ++++++------- 57 files changed, 761 insertions(+), 471 deletions(-) create mode 100644 setup/fixtures/hello.ts diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 41d573c5..4164cac8 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -53,4 +53,4 @@ jobs: port: 8000 cors: "*" - name: test - run: AWS_ACCESS_KEY_ID=dummy AWS_SECRET_ACCESS_KEY=dummy make test + run: make test diff --git a/Cargo.lock b/Cargo.lock index e11d0bd8..99bf9bbb 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -71,9 +71,9 @@ checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" [[package]] name = "aws-config" -version = "1.1.7" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b96342ea8948ab9bef3e6234ea97fc32e2d8a88d8fb6a084e52267317f94b6b" +checksum = "e2a89e0000cde82447155d64eeb71720b933b4396a6fbbebad3f8b4f88ca7b54" dependencies = [ "aws-credential-types", "aws-runtime", @@ -96,6 +96,7 @@ dependencies = [ "time 0.3.36", "tokio", "tracing", + "url", "zeroize", ] @@ -113,9 +114,9 @@ dependencies = [ [[package]] name = "aws-runtime" -version = "1.1.7" +version = "1.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6e38bab716c8bf07da24be07ecc02e0f5656ce8f30a891322ecdcb202f943b85" +checksum = "75588e7ee5e8496eed939adac2035a6dbab9f7eb2acdd9ab2d31856dab6f3955" dependencies = [ "aws-credential-types", "aws-sigv4", @@ -127,7 +128,7 @@ dependencies = [ "bytes", "fastrand", "http 0.2.11", - "http-body", + "http-body 0.4.6", "percent-encoding", "pin-project-lite", "tracing", @@ -136,9 +137,9 @@ dependencies = [ [[package]] name = "aws-sdk-dynamodb" -version = "1.16.0" +version = "1.28.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "785c15d901cb8c3a85817902221cc9ba3d51b2c65483ff51112f2ed9fe54815a" +checksum = "e1da0290e57949a362d3f106285bb539e8a282e6c1b0053f6e02b3fc14f2d730" dependencies = [ "aws-credential-types", "aws-runtime", @@ -159,9 +160,9 @@ dependencies = [ [[package]] name = "aws-sdk-sso" -version = "1.15.0" +version = "1.25.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d84bd3925a17c9adbf6ec65d52104a44a09629d8f70290542beeee69a95aee7f" +checksum = "fef2d9ca2b43051224ed326ed9960a85e277b7d554a2cd0397e57c0553d86e64" dependencies = [ "aws-credential-types", "aws-runtime", @@ -181,9 +182,9 @@ dependencies = [ [[package]] name = "aws-sdk-ssooidc" -version = "1.15.0" +version = "1.26.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2c2dae39e997f58bc4d6292e6244b26ba630c01ab671b6f9f44309de3eb80ab8" +checksum = "c869d1f5c4ee7437b79c3c1664ddbf7a60231e893960cf82b2b299a5ccf2cc5d" dependencies = [ "aws-credential-types", "aws-runtime", @@ -203,9 +204,9 @@ dependencies = [ [[package]] name = "aws-sdk-sts" -version = "1.15.0" +version = "1.25.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "17fd9a53869fee17cea77e352084e1aa71e2c5e323d974c13a9c2bcfd9544c7f" +checksum = "9e2b4a632a59e4fab7abf1db0d94a3136ad7871aba46bebd1fdb95c7054afcdb" dependencies = [ "aws-credential-types", "aws-runtime", @@ -226,9 +227,9 @@ dependencies = [ [[package]] name = "aws-sigv4" -version = "1.1.7" +version = "1.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8ada00a4645d7d89f296fe0ddbc3fe3554f03035937c849a05d37ddffc1f29a1" +checksum = "58b56f1cbe6fd4d0c2573df72868f20ab1c125ca9c9dbce17927a463433a2e57" dependencies = [ "aws-credential-types", "aws-smithy-http", @@ -260,9 +261,9 @@ dependencies = [ [[package]] name = "aws-smithy-http" -version = "0.60.6" +version = "0.60.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b6ca214a6a26f1b7ebd63aa8d4f5e2194095643023f9608edf99a58247b9d80d" +checksum = "4a7de001a1b9a25601016d8057ea16e31a45fdca3751304c8edf4ad72e706c08" dependencies = [ "aws-smithy-runtime-api", "aws-smithy-types", @@ -270,7 +271,7 @@ dependencies = [ "bytes-utils", "futures-core", "http 0.2.11", - "http-body", + "http-body 0.4.6", "once_cell", "percent-encoding", "pin-project-lite", @@ -280,18 +281,18 @@ dependencies = [ [[package]] name = "aws-smithy-json" -version = "0.60.6" +version = "0.60.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1af80ecf3057fb25fe38d1687e94c4601a7817c6a1e87c1b0635f7ecb644ace5" +checksum = "4683df9469ef09468dad3473d129960119a0d3593617542b7d52086c8486f2d6" dependencies = [ "aws-smithy-types", ] [[package]] name = "aws-smithy-query" -version = "0.60.6" +version = "0.60.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eb27084f72ea5fc20033efe180618677ff4a2f474b53d84695cfe310a6526cbc" +checksum = "f2fbd61ceb3fe8a1cb7352e42689cec5335833cd9f94103a61e98f9bb61c64bb" dependencies = [ "aws-smithy-types", "urlencoding", @@ -299,9 +300,9 @@ dependencies = [ [[package]] name = "aws-smithy-runtime" -version = "1.1.7" +version = "1.5.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fbb5fca54a532a36ff927fbd7407a7c8eb9c3b4faf72792ba2965ea2cad8ed55" +checksum = "607e8b53aeb2bc23fb332159d72a69650cd9643c161d76cd3b7f88ac00b5a1bb" dependencies = [ "aws-smithy-async", "aws-smithy-http", @@ -311,7 +312,8 @@ dependencies = [ "fastrand", "h2", "http 0.2.11", - "http-body", + "http-body 0.4.6", + "http-body 1.0.0", "hyper", "hyper-rustls 0.24.2", "once_cell", @@ -350,7 +352,10 @@ dependencies = [ "bytes-utils", "futures-core", "http 0.2.11", - "http-body", + "http 1.0.0", + "http-body 0.4.6", + "http-body 1.0.0", + "http-body-util", "itoa", "num-integer", "pin-project-lite", @@ -364,18 +369,18 @@ dependencies = [ [[package]] name = "aws-smithy-xml" -version = "0.60.6" +version = "0.60.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0fccd8f595d0ca839f9f2548e66b99514a85f92feb4c01cf2868d93eb4888a42" +checksum = "d123fbc2a4adc3c301652ba8e149bf4bc1d1725affb9784eb20c953ace06bf55" dependencies = [ "xmlparser", ] [[package]] name = "aws-types" -version = "1.1.7" +version = "1.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d07c63521aa1ea9a9f92a701f1a08ce3fd20b46c6efc0d5c8947c1fd879e3df1" +checksum = "02fa328e19c849b20ef7ada4c9b581dd12351ff35ecc7642d06e69de4f98407c" dependencies = [ "aws-credential-types", "aws-smithy-async", @@ -920,6 +925,29 @@ dependencies = [ "pin-project-lite", ] +[[package]] +name = "http-body" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1cac85db508abc24a2e48553ba12a996e87244a0395ce011e62b37158745d643" +dependencies = [ + "bytes", + "http 1.0.0", +] + +[[package]] +name = "http-body-util" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0475f8b2ac86659c21b64320d5d653f9efe42acd2a4e560073ec61a155a34f1d" +dependencies = [ + "bytes", + "futures-core", + "http 1.0.0", + "http-body 1.0.0", + "pin-project-lite", +] + [[package]] name = "httparse" version = "1.8.0" @@ -944,7 +972,7 @@ dependencies = [ "futures-util", "h2", "http 0.2.11", - "http-body", + "http-body 0.4.6", "httparse", "httpdate", "itoa", @@ -1046,6 +1074,16 @@ version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39" +[[package]] +name = "idna" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "634d9b1461af396cad843f47fdba5597a4f9e6ddd4bfb6ff5d85028c25cb12f6" +dependencies = [ + "unicode-bidi", + "unicode-normalization", +] + [[package]] name = "indexmap" version = "2.2.4" @@ -2223,6 +2261,21 @@ dependencies = [ "time-core", ] +[[package]] +name = "tinyvec" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "87cc5ceb3875bb20c2890005a4e226a4651264a5c75edb2421b52861a0a0cb50" +dependencies = [ + "tinyvec_macros", +] + +[[package]] +name = "tinyvec_macros" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" + [[package]] name = "tokio" version = "1.36.0" @@ -2388,12 +2441,27 @@ version = "1.17.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "42ff0bf0c66b8238c6f3b578df37d0b7848e55df8577b3f74f92a69acceeb825" +[[package]] +name = "unicode-bidi" +version = "0.3.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "08f95100a766bf4f8f28f90d77e0a5461bbdb219042e7679bebe79004fed8d75" + [[package]] name = "unicode-ident" version = "1.0.12" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" +[[package]] +name = "unicode-normalization" +version = "0.1.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a56d1686db2308d901306f92a263857ef59ea39678a5458e7cb17f01415101f5" +dependencies = [ + "tinyvec", +] + [[package]] name = "unicode-segmentation" version = "1.11.0" @@ -2412,6 +2480,17 @@ version = "0.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1" +[[package]] +name = "url" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "31e6302e3bb753d46e83516cae55ae196fc0c309407cf11ab35cc51a4c2a4633" +dependencies = [ + "form_urlencoded", + "idna", + "percent-encoding", +] + [[package]] name = "urlencoding" version = "2.1.3" diff --git a/README.md b/README.md index 90ed08e1..22f58984 100644 --- a/README.md +++ b/README.md @@ -97,7 +97,7 @@ tracing = "0.1" ### Setup ``` -AWS_ACCESS_KEY_ID=awsdummy AWS_SECRET_ACCESS_KEY=awsdummy make dynamo +make dynamo ``` This starts up DynamoDB on Docker container, and then arranges test fixtures. @@ -105,7 +105,7 @@ This starts up DynamoDB on Docker container, and then arranges test fixtures. ### Test ``` -AWS_ACCESS_KEY_ID=awsdummy AWS_SECRET_ACCESS_KEY=awsdummy make test +make test ``` NOTE: Don't recommend to use `cargo test` because our test suite doesn't support running tests in parallel. Use `cargo test -- --test-threads=1` instead of it. @@ -113,7 +113,7 @@ NOTE: Don't recommend to use `cargo test` because our test suite doesn't support ### Example ``` -AWS_ACCESS_KEY_ID=awsdummy AWS_SECRET_ACCESS_KEY=awsdummy cargo run --example EXAMPLE_NAME +AWS_ACCESS_KEY_ID=dummy AWS_SECRET_ACCESS_KEY=dummy cargo run --example EXAMPLE_NAME ``` ### Utility diff --git a/makefile b/makefile index c57a0732..f8739b6c 100644 --- a/makefile +++ b/makefile @@ -1,3 +1,6 @@ +export AWS_ACCESS_KEY_ID := dummy +export AWS_SECRET_ACCESS_KEY := dummy + .PHONY: dynamo dynamo: docker compose down --volumes @@ -22,7 +25,7 @@ lint: .PHONY: check-deps check-deps: cargo machete - cargo +nightly udeps --all-targets --features tracing cargo +nightly udeps --all-targets --no-default-features --features aws-sdk cargo +nightly udeps --all-targets --no-default-features --features rusoto cargo +nightly udeps --all-targets --no-default-features --features rusoto_rustls + cargo +nightly udeps --all-targets --features tracing diff --git a/raiden-derive/src/aws_sdk/client.rs b/raiden-derive/src/aws_sdk/client.rs index dd06350c..ce5d5b2e 100644 --- a/raiden-derive/src/aws_sdk/client.rs +++ b/raiden-derive/src/aws_sdk/client.rs @@ -23,10 +23,9 @@ pub(crate) fn expand_client_constructor( quote! { impl #client_name { - - pub fn new(region: ::raiden::Region) -> Self { - let config = ::raiden::Config::builder() - .behavior_version(::raiden::BehaviorVersion::latest()) + pub fn new(region: ::raiden::aws_sdk::config::Region) -> Self { + let config = ::raiden::aws_sdk::config::Config::builder() + .behavior_version(::raiden::aws_sdk::config::BehaviorVersion::latest()) .region(region) .build(); let client = ::raiden::#dynamodb_client_name::from_conf(config); @@ -50,7 +49,10 @@ pub(crate) fn expand_client_constructor( table_prefix: "".to_owned(), table_suffix: "".to_owned(), client, - retry_condition: ::raiden::RetryCondition::new(), + // NOTE: + // Since the AWS SDK provides a retry option, + // configure it to not retry by default. + retry_condition: ::raiden::RetryCondition::never(), attribute_names: Some(names), projection_expression } @@ -77,7 +79,7 @@ pub(crate) fn expand_client_constructor( } impl #struct_name { - pub fn client(region: ::raiden::Region) -> #client_name { + pub fn client(region: ::raiden::aws_sdk::config::Region) -> #client_name { #client_name::new(region) } diff --git a/raiden-derive/src/aws_sdk/ops/batch_delete.rs b/raiden-derive/src/aws_sdk/ops/batch_delete.rs index 01369fe5..acb82d10 100644 --- a/raiden-derive/src/aws_sdk/ops/batch_delete.rs +++ b/raiden-derive/src/aws_sdk/ops/batch_delete.rs @@ -28,7 +28,7 @@ pub(crate) fn expand_batch_delete( let pk_attr_value = pk.into().into_attr(); let sk_attr_value = sk.into().into_attr(); let write_request = { - let delete_request = ::raiden::DeleteRequest::builder() + let delete_request = ::raiden::aws_sdk::types::DeleteRequest::builder() .set_key(Some(::std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_string(), pk_attr_value), (stringify!(#sort_key_ident).to_string(), sk_attr_value), @@ -36,7 +36,7 @@ pub(crate) fn expand_batch_delete( .build() .expect("should be built"); - ::raiden::WriteRequest::builder() + ::raiden::aws_sdk::types::WriteRequest::builder() .delete_request(delete_request) .build() }; @@ -69,14 +69,14 @@ pub(crate) fn expand_batch_delete( for pk in keys.into_iter() { let pk_attr_value = pk.into().into_attr(); let write_request = { - let delete_request = ::raiden::DeleteRequest::builder() + let delete_request = ::raiden::aws_sdk::types::DeleteRequest::builder() .set_key(Some(::std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_string(), pk_attr_value), ]))) .build() .expect("should be built"); - ::raiden::WriteRequest::builder() + ::raiden::aws_sdk::types::WriteRequest::builder() .delete_request(delete_request) .build() }; @@ -114,7 +114,7 @@ pub(crate) fn expand_batch_delete( pub struct #builder_name<'a> { pub client: &'a ::raiden::Client, - pub write_requests: ::std::vec::Vec<::raiden::WriteRequest>, + pub write_requests: ::std::vec::Vec<::raiden::aws_sdk::types::WriteRequest>, pub table_name: String, } @@ -140,7 +140,7 @@ pub(crate) fn expand_batch_delete( let request_items = vec![(self.table_name.clone(), req)] .into_iter() .collect::>(); - let builder = ::raiden::BatchWriteItemInput::builder() + let builder = ::raiden::aws_sdk::operation::batch_write_item::BatchWriteItemInput::builder() .set_request_items(Some(request_items)); let result = #call_inner_run; @@ -185,8 +185,8 @@ pub(crate) fn expand_batch_delete( async fn inner_run( #inner_run_args client: &::raiden::Client, - builder: ::raiden::BatchWriteItemInputBuilder, - ) -> Result<::raiden::BatchWriteItemOutput, ::raiden::RaidenError> { + builder: ::raiden::operation::batch_write_item::builders::BatchWriteItemInputBuilder, + ) -> Result<::raiden::operation::batch_write_item::BatchWriteItemOutput, ::raiden::RaidenError> { Ok(#api_call_token?) } } diff --git a/raiden-derive/src/aws_sdk/ops/batch_get.rs b/raiden-derive/src/aws_sdk/ops/batch_get.rs index 520a97f5..b32de9a3 100644 --- a/raiden-derive/src/aws_sdk/ops/batch_get.rs +++ b/raiden-derive/src/aws_sdk/ops/batch_get.rs @@ -18,9 +18,9 @@ pub(crate) fn expand_batch_get( let (partition_key_ident, partition_key_type) = partition_key; let builder_keys_type = if sort_key.is_none() { - quote! { std::vec::Vec<::raiden::AttributeValue> } + quote! { std::vec::Vec<::raiden::aws_sdk::types::AttributeValue> } } else { - quote! { std::vec::Vec<(::raiden::AttributeValue, ::raiden::AttributeValue)> } + quote! { std::vec::Vec<(::raiden::aws_sdk::types::AttributeValue, ::raiden::aws_sdk::types::AttributeValue)> } }; let insertion_attribute_name = fields.named.iter().map(|f| { @@ -87,7 +87,7 @@ pub(crate) fn expand_batch_get( let (sort_key_ident, _sort_key_type) = sort_key; quote! { for (pk_attr, sk_attr) in keys.into_iter() { - let key_val: std::collections::HashMap = ::std::collections::HashMap::from_iter([ + let key_val: std::collections::HashMap = ::std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), pk_attr), (stringify!(#sort_key_ident).to_owned(), sk_attr), ]); @@ -98,7 +98,7 @@ pub(crate) fn expand_batch_get( } else { quote! { for key_attr in keys.into_iter() { - let key_val: std::collections::HashMap = ::std::collections::HashMap::from_iter([ + let key_val: std::collections::HashMap = ::std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), key_attr), ]); @@ -138,7 +138,7 @@ pub(crate) fn expand_batch_get( use ::std::iter::FromIterator; let mut items: std::vec::Vec<#struct_name> = vec![]; - let mut unprocessed_keys = ::raiden::KeysAndAttributes::builder() + let mut unprocessed_keys = ::raiden::aws_sdk::types::KeysAndAttributes::builder() .set_keys(Some(vec![])) .build() .expect("should be built"); @@ -147,7 +147,7 @@ pub(crate) fn expand_batch_get( let mut unprocessed_retry = 5; loop { let unprocessed_key_len = unprocessed_keys.keys().len(); - let mut item_builder = ::raiden::KeysAndAttributes::builder() + let mut item_builder = ::raiden::aws_sdk::types::KeysAndAttributes::builder() .set_expression_attribute_names(self.attribute_names.clone()) .set_projection_expression(self.projection_expression.clone()) .set_keys(Some(unprocessed_keys.keys)); @@ -157,7 +157,7 @@ pub(crate) fn expand_batch_get( #convert_to_external_proc } - let builder = ::raiden::BatchGetItemInput::builder() + let builder = ::raiden::aws_sdk::operation::batch_get_item::BatchGetItemInput::builder() .request_items( self.table_name.to_string(), item_builder.build().expect("should be built"), @@ -209,8 +209,8 @@ pub(crate) fn expand_batch_get( async fn inner_run( #inner_run_args client: &::raiden::Client, - builder: ::raiden::BatchGetItemInputBuilder, - ) -> Result<::raiden::BatchGetItemOutput, ::raiden::RaidenError> { + builder: ::raiden::aws_sdk::operation::batch_get_item::builders::BatchGetItemInputBuilder, + ) -> Result<::raiden::aws_sdk::operation::batch_get_item::BatchGetItemOutput, ::raiden::RaidenError> { Ok(#api_call_token?) } } diff --git a/raiden-derive/src/aws_sdk/ops/delete.rs b/raiden-derive/src/aws_sdk/ops/delete.rs index c815eb1a..395de6b9 100644 --- a/raiden-derive/src/aws_sdk/ops/delete.rs +++ b/raiden-derive/src/aws_sdk/ops/delete.rs @@ -24,15 +24,15 @@ pub(crate) fn expand_delete_item( fn delete(&self, pk: impl Into<#partition_key_type>, sk: impl Into<#sort_key_type>) -> #builder_name { use ::std::iter::FromIterator; - let pk_attr: ::raiden::AttributeValue = pk.into().into_attr(); - let sk_attr: ::raiden::AttributeValue = sk.into().into_attr(); - let key_set: std::collections::HashMap = + let pk_attr: ::raiden::aws_sdk::types::AttributeValue = pk.into().into_attr(); + let sk_attr: ::raiden::aws_sdk::types::AttributeValue = sk.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), pk_attr), (stringify!(#sort_key_ident).to_owned(), sk_attr), ]); - let mut builder = ::raiden::DeleteItemInput::builder() + let mut builder = ::raiden::aws_sdk::operation::delete_item::DeleteItemInput::builder() .set_key(Some(key_set)) .table_name(self.table_name()); @@ -53,13 +53,13 @@ pub(crate) fn expand_delete_item( fn delete(&self, key: impl Into<#partition_key_type>) -> #builder_name { use ::std::iter::FromIterator; - let key_attr: ::raiden::AttributeValue = key.into().into_attr(); - let key_set: std::collections::HashMap = + let key_attr: ::raiden::aws_sdk::types::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), key_attr), ]); - let mut builder = ::raiden::DeleteItemInput::builder() + let mut builder = ::raiden::aws_sdk::operation::delete_item::DeleteItemInput::builder() .set_key(Some(key_set)) .table_name(self.table_name()); @@ -98,11 +98,11 @@ pub(crate) fn expand_delete_item( pub struct #builder_name<'a> { pub client: &'a ::raiden::Client, - pub builder: ::raiden::DeleteItemInputBuilder, + pub builder: ::raiden::aws_sdk::operation::delete_item::builders::DeleteItemInputBuilder, } impl<'a> #builder_name<'a> { - pub fn raw_input(mut self, builder: ::raiden::DeleteItemInputBuilder) -> Self { + pub fn raw_input(mut self, builder: ::raiden::aws_sdk::operation::delete_item::builders::DeleteItemInputBuilder) -> Self { self.builder = builder; self } @@ -132,7 +132,7 @@ pub(crate) fn expand_delete_item( async fn inner_run( #inner_run_args client: &::raiden::Client, - builder: ::raiden::DeleteItemInputBuilder, + builder: ::raiden::aws_sdk::operation::delete_item::builders::DeleteItemInputBuilder, ) -> Result<(), ::raiden::RaidenError> { #api_call_token?; Ok(()) diff --git a/raiden-derive/src/aws_sdk/ops/get.rs b/raiden-derive/src/aws_sdk/ops/get.rs index 211ec984..ccebda57 100644 --- a/raiden-derive/src/aws_sdk/ops/get.rs +++ b/raiden-derive/src/aws_sdk/ops/get.rs @@ -26,14 +26,14 @@ pub(crate) fn expand_get_item( fn get(&self, pk: impl Into<#partition_key_type>, sk: impl Into<#sort_key_type>) -> #builder_name { use ::std::iter::FromIterator; - let pk_attr: ::raiden::AttributeValue = pk.into().into_attr(); - let sk_attr: ::raiden::AttributeValue = sk.into().into_attr(); - let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + let pk_attr: ::raiden::aws_sdk::types::AttributeValue = pk.into().into_attr(); + let sk_attr: ::raiden::aws_sdk::types::AttributeValue = sk.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), pk_attr), (stringify!(#sort_key_ident).to_owned(), sk_attr), ]); - let mut builder = ::raiden::GetItemInput::builder() + let mut builder = ::raiden::aws_sdk::operation::get_item::GetItemInput::builder() .set_expression_attribute_names(self.attribute_names.clone()) .set_key(Some(key_set)) .table_name(self.table_name()); @@ -61,12 +61,12 @@ pub(crate) fn expand_get_item( fn get(&self, key: impl Into<#partition_key_type>) -> #builder_name { use ::std::iter::FromIterator; - let key_attr: ::raiden::AttributeValue = key.into().into_attr(); - let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + let key_attr: ::raiden::aws_sdk::types::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), key_attr), ]); - let mut builder = ::raiden::GetItemInput::builder() + let mut builder = ::raiden::aws_sdk::operation::get_item::GetItemInput::builder() .set_expression_attribute_names(self.attribute_names.clone()) .set_key(Some(key_set)) .table_name(self.table_name()); @@ -111,7 +111,7 @@ pub(crate) fn expand_get_item( pub struct #builder_name<'a> { pub client: &'a ::raiden::Client, - pub builder: ::raiden::GetItemInputBuilder, + pub builder: ::raiden::aws_sdk::operation::get_item::builders::GetItemInputBuilder, pub policy: ::raiden::Policy, pub condition: &'a ::raiden::retry::RetryCondition, } @@ -136,7 +136,7 @@ pub(crate) fn expand_get_item( async fn inner_run( #inner_run_args client: ::raiden::Client, - builder: ::raiden::GetItemInputBuilder, + builder: ::raiden::aws_sdk::operation::get_item::builders::GetItemInputBuilder, ) -> Result<::raiden::get::GetOutput<#struct_name>, ::raiden::RaidenError> { let res = #api_call_token?; if res.item.is_none() { diff --git a/raiden-derive/src/aws_sdk/ops/put.rs b/raiden-derive/src/aws_sdk/ops/put.rs index f86f9829..bbf403d6 100644 --- a/raiden-derive/src/aws_sdk/ops/put.rs +++ b/raiden-derive/src/aws_sdk/ops/put.rs @@ -81,7 +81,7 @@ pub(crate) fn expand_put_item( }); quote! { - let mut input_item: std::collections::HashMap = std::collections::HashMap::new(); + let mut input_item: std::collections::HashMap = std::collections::HashMap::new(); #(#insertion)* } }; @@ -147,7 +147,7 @@ pub(crate) fn expand_put_item( #(#output_values)* }; - let builder = ::raiden::PutItemInput::builder() + let builder = ::raiden::aws_sdk::operation::put_item::PutItemInput::builder() .set_item(Some(input_item)) .table_name(self.table_name()); @@ -163,7 +163,7 @@ pub(crate) fn expand_put_item( pub struct #builder_name<'a> { pub client: &'a ::raiden::Client, - pub builder: ::raiden::PutItemInputBuilder, + pub builder: ::raiden::aws_sdk::operation::put_item::builders::PutItemInputBuilder, pub item: #item_output_name, pub policy: ::raiden::Policy, pub condition: &'a ::raiden::retry::RetryCondition, @@ -171,7 +171,7 @@ pub(crate) fn expand_put_item( impl<'a> #builder_name<'a> { - pub fn raw_input(mut self, builder: ::raiden::PutItemInputBuilder) -> Self { + pub fn raw_input(mut self, builder: ::raiden::aws_sdk::operation::put_item::builders::PutItemInputBuilder) -> Self { self.builder = builder; self } @@ -213,8 +213,8 @@ pub(crate) fn expand_put_item( async fn inner_run( #inner_run_args client: ::raiden::Client, - builder: ::raiden::PutItemInputBuilder, - ) -> Result<::raiden::PutItemOutput, ::raiden::RaidenError> { + builder: ::raiden::aws_sdk::operation::put_item::builders::PutItemInputBuilder, + ) -> Result<::raiden::aws_sdk::operation::put_item::PutItemOutput, ::raiden::RaidenError> { Ok(#api_call_token?) } } diff --git a/raiden-derive/src/aws_sdk/ops/query.rs b/raiden-derive/src/aws_sdk/ops/query.rs index 2b9c6227..488c5160 100644 --- a/raiden-derive/src/aws_sdk/ops/query.rs +++ b/raiden-derive/src/aws_sdk/ops/query.rs @@ -41,7 +41,7 @@ pub(crate) fn expand_query( pub struct #builder_name<'a> { pub client: &'a ::raiden::Client, - pub builder: ::raiden::QueryInputBuilder, + pub builder: ::raiden::aws_sdk::operation::query::builders::QueryInputBuilder, pub next_token: Option<::raiden::NextToken>, pub limit: Option, pub policy: ::raiden::Policy, @@ -49,7 +49,7 @@ pub(crate) fn expand_query( } struct #query_output_item { - consumed_capacity: Option<::raiden::ConsumedCapacity>, + consumed_capacity: Option<::raiden::aws_sdk::types::ConsumedCapacity>, count: Option, items: Option>>, last_evaluated_key: Option<::std::collections::HashMap>, @@ -60,7 +60,7 @@ pub(crate) fn expand_query( #![allow(clippy::field_reassign_with_default)] fn query(&self) -> #builder_name { - let builder = ::raiden::QueryInput::builder() + let builder = ::raiden::aws_sdk::operation::query::QueryInput::builder() .table_name(self.table_name()) .set_projection_expression(self.projection_expression.clone()) .set_expression_attribute_names(self.attribute_names.clone()); @@ -207,7 +207,7 @@ pub(crate) fn expand_query( async fn inner_run( #inner_run_args client: ::raiden::Client, - builder: ::raiden::QueryInputBuilder, + builder: ::raiden::aws_sdk::operation::query::builders::QueryInputBuilder, ) -> Result<#query_output_item, ::raiden::RaidenError> { let res = #api_call_token?; Ok(#query_output_item { diff --git a/raiden-derive/src/aws_sdk/ops/scan.rs b/raiden-derive/src/aws_sdk/ops/scan.rs index eccab50f..dfe4fddc 100644 --- a/raiden-derive/src/aws_sdk/ops/scan.rs +++ b/raiden-derive/src/aws_sdk/ops/scan.rs @@ -34,7 +34,7 @@ pub(crate) fn expand_scan( pub struct #builder_name<'a> { pub client: &'a ::raiden::Client, - pub builder: ::raiden::ScanInputBuilder, + pub builder: ::raiden::aws_sdk::operation::scan::builders::ScanInputBuilder, pub next_token: Option<::raiden::NextToken>, pub limit: Option } @@ -42,7 +42,7 @@ pub(crate) fn expand_scan( impl #trait_name for #client_name { #![allow(clippy::field_reassign_with_default)] fn scan(&self) -> #builder_name { - let builder = ::raiden::ScanInput::builder() + let builder = ::raiden::aws_sdk::operation::scan::ScanInput::builder() .table_name(self.table_name()) .set_projection_expression(self.projection_expression.clone()) .set_expression_attribute_names(self.attribute_names.clone()); @@ -143,8 +143,8 @@ pub(crate) fn expand_scan( async fn inner_run( #inner_run_args client: &::raiden::Client, - builder: ::raiden::ScanInputBuilder, - ) -> Result<::raiden::ScanOutput, ::raiden::RaidenError> { + builder: ::raiden::aws_sdk::operation::scan::builders::ScanInputBuilder, + ) -> Result<::raiden::aws_sdk::operation::scan::ScanOutput, ::raiden::RaidenError> { Ok(#api_call_token?) } } diff --git a/raiden-derive/src/aws_sdk/ops/transact_write.rs b/raiden-derive/src/aws_sdk/ops/transact_write.rs index d95c2220..340a49de 100644 --- a/raiden-derive/src/aws_sdk/ops/transact_write.rs +++ b/raiden-derive/src/aws_sdk/ops/transact_write.rs @@ -52,7 +52,7 @@ pub(crate) fn expand_transact_write( }); quote! { - let mut input_item: std::collections::HashMap = std::collections::HashMap::new(); + let mut input_item: std::collections::HashMap = std::collections::HashMap::new(); #(#insertion)* } }; @@ -61,12 +61,12 @@ pub(crate) fn expand_transact_write( impl #struct_name { pub fn put(item: #item_input_name) -> #put_builder { let mut attribute_names: std::collections::HashMap = std::collections::HashMap::new(); - let mut attribute_values: std::collections::HashMap = std::collections::HashMap::new(); + let mut attribute_values: std::collections::HashMap = std::collections::HashMap::new(); let mut uuid_map: std::collections::HashMap = std::collections::HashMap::new(); #input_items - let builder = ::raiden::Put::builder().set_item(Some(input_item)); + let builder = ::raiden::aws_sdk::types::Put::builder().set_item(Some(input_item)); #put_builder { builder, @@ -80,11 +80,11 @@ pub(crate) fn expand_transact_write( pub fn condition_check(key: impl Into<#partition_key_type>) -> #condition_check_builder { use std::iter::FromIterator; - let key_attr: ::raiden::AttributeValue = key.into().into_attr(); - let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + let key_attr: ::raiden::aws_sdk::types::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), key_attr), ]); - let builder = ::raiden::ConditionCheck::builder() + let builder = ::raiden::aws_sdk::types::ConditionCheck::builder() .set_key(Some(key_set)); #condition_check_builder { @@ -99,11 +99,11 @@ pub(crate) fn expand_transact_write( pub fn delete(key: impl Into<#partition_key_type>) -> #delete_builder { use std::iter::FromIterator; - let key_attr: ::raiden::AttributeValue = key.into().into_attr(); - let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + let key_attr: ::raiden::aws_sdk::types::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), key_attr), ]); - let builder = ::raiden::Delete::builder().set_key(Some(key_set)); + let builder = ::raiden::aws_sdk::types::Delete::builder().set_key(Some(key_set)); #delete_builder { builder, @@ -117,11 +117,11 @@ pub(crate) fn expand_transact_write( pub fn update(key: impl Into<#partition_key_type>) -> #update_builder { use std::iter::FromIterator; - let key_attr: ::raiden::AttributeValue = key.into().into_attr(); - let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + let key_attr: ::raiden::aws_sdk::types::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), key_attr), ]); - let builder = ::raiden::Update::builder().set_key(Some(key_set)); + let builder = ::raiden::aws_sdk::types::Update::builder().set_key(Some(key_set)); #update_builder { builder, @@ -141,11 +141,11 @@ pub(crate) fn expand_transact_write( pub table_name: String, pub table_prefix: String, pub table_suffix: String, - pub builder: ::raiden::PutBuilder, + pub builder: ::raiden::aws_sdk::types::builders::PutBuilder, } impl ::raiden::TransactWritePutBuilder for #put_builder { - fn build(self) -> ::raiden::Put { + fn build(self) -> ::raiden::aws_sdk::types::Put { self.builder .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)) .build() @@ -187,7 +187,7 @@ pub(crate) fn expand_transact_write( pub table_name: String, pub table_prefix: String, pub table_suffix: String, - pub builder: ::raiden::UpdateBuilder, + pub builder: ::raiden::aws_sdk::types::builders::UpdateBuilder, pub add_items: Vec<(String, ::raiden::AttributeNames, ::raiden::AttributeValues)>, pub set_items: Vec<::raiden::update_expression::SetOrRemove>, @@ -196,7 +196,7 @@ pub(crate) fn expand_transact_write( } impl ::raiden::TransactWriteUpdateBuilder for #update_builder { - fn build(mut self) -> ::raiden::Update { + fn build(mut self) -> ::raiden::aws_sdk::types::Update { // TODO: Refactor later let mut attr_names: ::raiden::AttributeNames = std::collections::HashMap::new(); let mut attr_values: ::raiden::AttributeValues = std::collections::HashMap::new(); @@ -347,11 +347,11 @@ pub(crate) fn expand_transact_write( pub table_name: String, pub table_prefix: String, pub table_suffix: String, - pub builder: ::raiden::DeleteBuilder, + pub builder: ::raiden::aws_sdk::types::builders::DeleteBuilder, } impl ::raiden::TransactWriteDeleteBuilder for #delete_builder { - fn build(self) -> ::raiden::Delete { + fn build(self) -> ::raiden::aws_sdk::types::Delete { self.builder .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)) .build() @@ -392,11 +392,11 @@ pub(crate) fn expand_transact_write( pub table_name: String, pub table_prefix: String, pub table_suffix: String, - pub builder: ::raiden::ConditionCheckBuilder, + pub builder: ::raiden::aws_sdk::types::builders::ConditionCheckBuilder, } impl ::raiden::TransactWriteConditionCheckBuilder for #condition_check_builder { - fn build(self) -> ::raiden::ConditionCheck { + fn build(self) -> ::raiden::aws_sdk::types::ConditionCheck { self.builder .table_name(format!("{}{}{}", self.table_prefix, self.table_name, self.table_suffix)) .build() diff --git a/raiden-derive/src/aws_sdk/ops/update.rs b/raiden-derive/src/aws_sdk/ops/update.rs index 6126c746..546afbbc 100644 --- a/raiden-derive/src/aws_sdk/ops/update.rs +++ b/raiden-derive/src/aws_sdk/ops/update.rs @@ -30,14 +30,14 @@ pub(crate) fn expand_update_item( fn update(&self, pk: impl Into<#partition_key_type>, sk: impl Into<#sort_key_type>) -> #builder_name { use std::iter::FromIterator; - let pk_attr: ::raiden::AttributeValue = pk.into().into_attr(); - let sk_attr: ::raiden::AttributeValue = sk.into().into_attr(); - let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + let pk_attr: ::raiden::aws_sdk::types::AttributeValue = pk.into().into_attr(); + let sk_attr: ::raiden::aws_sdk::types::AttributeValue = sk.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), pk_attr), (stringify!(#sort_key_ident).to_owned(), sk_attr), ]); - let builder = ::raiden::UpdateItemInput::builder() + let builder = ::raiden::aws_sdk::operation::update_item::UpdateItemInput::builder() .set_key(Some(key_set)) .table_name(self.table_name()); @@ -64,12 +64,12 @@ pub(crate) fn expand_update_item( fn update(&self, key: impl Into<#partition_key_type>) -> #builder_name { use std::iter::FromIterator; - let key_attr: ::raiden::AttributeValue = key.into().into_attr(); - let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ + let key_attr: ::raiden::aws_sdk::types::AttributeValue = key.into().into_attr(); + let key_set: std::collections::HashMap = std::collections::HashMap::from_iter([ (stringify!(#partition_key_ident).to_owned(), key_attr), ]); - let builder = ::raiden::UpdateItemInput::builder() + let builder = ::raiden::aws_sdk::operation::update_item::UpdateItemInput::builder() .set_key(Some(key_set)) .table_name(self.table_name()); @@ -136,7 +136,7 @@ pub(crate) fn expand_update_item( pub struct #builder_name<'a> { pub client: &'a ::raiden::Client, - pub builder: ::raiden::UpdateItemInputBuilder, + pub builder: ::raiden::aws_sdk::operation::update_item::builders::UpdateItemInputBuilder, pub add_items: Vec<(String, ::raiden::AttributeNames, ::raiden::AttributeValues)>, pub set_items: Vec<::raiden::update_expression::SetOrRemove>, pub remove_items: Vec<#attr_enum_name>, @@ -146,7 +146,7 @@ pub(crate) fn expand_update_item( } impl<'a> #builder_name<'a> { - pub fn raw_input(mut self, builder: ::raiden::UpdateItemInputBuilder) -> Self { + pub fn raw_input(mut self, builder: ::raiden::aws_sdk::operation::update_item::builders::UpdateItemInputBuilder) -> Self { self.builder = builder; self } @@ -173,13 +173,13 @@ pub(crate) fn expand_update_item( // INFO: raiden supports only none, all_old and all_new to map response to struct. pub fn return_all_old(mut self) -> Self { - self.builder = self.builder.return_values(::raiden::ReturnValue::AllOld); + self.builder = self.builder.return_values(::raiden::aws_sdk::types::ReturnValue::AllOld); self } // INFO: raiden supports only none, all_old and all_new to map response to struct. pub fn return_all_new(mut self) -> Self { - self.builder = self.builder.return_values(::raiden::ReturnValue::AllNew); + self.builder = self.builder.return_values(::raiden::aws_sdk::types::ReturnValue::AllNew); self } @@ -350,8 +350,8 @@ pub(crate) fn expand_update_item( async fn inner_run( #inner_run_args client: ::raiden::Client, - builder: ::raiden::UpdateItemInputBuilder, - ) -> Result<::raiden::UpdateItemOutput, ::raiden::RaidenError> { + builder: ::raiden::aws_sdk::operation::update_item::builders::UpdateItemInputBuilder, + ) -> Result<::raiden::aws_sdk::operation::update_item::UpdateItemOutput, ::raiden::RaidenError> { Ok(#api_call_token?) } } diff --git a/raiden-derive/src/condition/builder.rs b/raiden-derive/src/condition/builder.rs index da96ce3c..4aa6ae10 100644 --- a/raiden-derive/src/condition/builder.rs +++ b/raiden-derive/src/condition/builder.rs @@ -8,6 +8,13 @@ pub fn expand_condition_builder( let condition_name = format_ident!("{}Condition", struct_name); let condition_token_name = format_ident!("{}ConditionToken", struct_name); let wait_attr_op_name = format_ident!("{}LeftAttrAndWaitOp", struct_name); + let attribute_value_path = if cfg!(feature = "rusoto") { + quote! { ::raiden::AttributeValue } + } else if cfg!(feature = "aws-sdk") { + quote! { ::raiden::aws_sdk::types::AttributeValue } + } else { + unreachable!(); + }; quote! { @@ -96,7 +103,7 @@ pub fn expand_condition_builder( pub struct #wait_attr_op_name { not: bool, attr_or_placeholder: ::raiden::AttrOrPlaceholder, - attr_value: Option<::raiden::AttributeValue> + attr_value: Option<#attribute_value_path>, } impl #wait_attr_op_name { diff --git a/raiden-derive/src/lib.rs b/raiden-derive/src/lib.rs index 001abbc2..4dc5b003 100644 --- a/raiden-derive/src/lib.rs +++ b/raiden-derive/src/lib.rs @@ -18,12 +18,12 @@ mod rename; #[cfg(feature = "rusoto")] mod rusoto; #[cfg(feature = "rusoto")] -use rusoto::{client, ops}; +use rusoto::*; #[cfg(feature = "aws-sdk")] mod aws_sdk; #[cfg(feature = "aws-sdk")] -use aws_sdk::{client, ops}; +use aws_sdk::*; use crate::rename::*; use std::str::FromStr; diff --git a/raiden-derive/src/rusoto/ops/delete.rs b/raiden-derive/src/rusoto/ops/delete.rs index 23a7cacb..5d71d984 100644 --- a/raiden-derive/src/rusoto/ops/delete.rs +++ b/raiden-derive/src/rusoto/ops/delete.rs @@ -33,6 +33,8 @@ pub(crate) fn expand_delete_item( #builder_name { client: &self.client, input, + policy: self.retry_condition.strategy.policy(), + condition: &self.retry_condition, } } } @@ -54,6 +56,8 @@ pub(crate) fn expand_delete_item( #builder_name { client: &self.client, input, + policy: self.retry_condition.strategy.policy(), + condition: &self.retry_condition, } } } @@ -63,12 +67,12 @@ pub(crate) fn expand_delete_item( let api_call_token = super::api_call_token!("delete_item"); let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { ( - quote! { #builder_name::inner_run(&self.input.table_name.clone(), &self.client, self.input).await? }, - quote! { table_name: &str, }, + quote! { #builder_name::inner_run(input.table_name.clone(), client, input).await }, + quote! { table_name: String, }, ) } else { ( - quote! { #builder_name::inner_run(&self.client, self.input).await? }, + quote! { #builder_name::inner_run(client, input).await }, quote! {}, ) }; @@ -79,6 +83,8 @@ pub(crate) fn expand_delete_item( pub struct #builder_name<'a> { pub client: &'a ::raiden::DynamoDbClient, pub input: ::raiden::DeleteItemInput, + pub policy: ::raiden::Policy, + pub condition: &'a ::raiden::retry::RetryCondition, } impl<'a> #builder_name<'a> { @@ -100,13 +106,21 @@ pub(crate) fn expand_delete_item( } pub async fn run(self) -> Result<(), ::raiden::RaidenError> { - #call_inner_run; + let policy: ::raiden::RetryPolicy = self.policy.into(); + let client = self.client; + let input = self.input; + policy.retry_if(move || { + let client = client.clone(); + let input = input.clone(); + async { #call_inner_run } + }, self.condition).await?; + Ok(()) } async fn inner_run( #inner_run_args - client: &::raiden::DynamoDbClient, + client: ::raiden::DynamoDbClient, input: ::raiden::DeleteItemInput, ) -> Result<(), ::raiden::RaidenError> { #api_call_token?; diff --git a/raiden-derive/src/rusoto/ops/scan.rs b/raiden-derive/src/rusoto/ops/scan.rs index 039c7b9f..987d11df 100644 --- a/raiden-derive/src/rusoto/ops/scan.rs +++ b/raiden-derive/src/rusoto/ops/scan.rs @@ -14,12 +14,12 @@ pub(crate) fn expand_scan( let api_call_token = super::api_call_token!("scan"); let (call_inner_run, inner_run_args) = if cfg!(feature = "tracing") { ( - quote! { #builder_name::inner_run(&self.input.table_name, &self.client, self.input.clone()).await? }, - quote! { table_name: &str, }, + quote! { #builder_name::inner_run(input.table_name.clone(), client, input).await }, + quote! { table_name: String, }, ) } else { ( - quote! { #builder_name::inner_run(&self.client, self.input.clone()).await? }, + quote! { #builder_name::inner_run(client, input).await }, quote! {}, ) }; @@ -32,6 +32,8 @@ pub(crate) fn expand_scan( pub struct #builder_name<'a> { pub client: &'a ::raiden::DynamoDbClient, pub input: ::raiden::ScanInput, + pub policy: ::raiden::Policy, + pub condition: &'a ::raiden::retry::RetryCondition, pub next_token: Option<::raiden::NextToken>, pub limit: Option } @@ -46,6 +48,8 @@ pub(crate) fn expand_scan( #builder_name { client: &self.client, input, + policy: self.retry_condition.strategy.policy(), + condition: &self.retry_condition, next_token: None, limit: None, } @@ -98,7 +102,16 @@ pub(crate) fn expand_scan( self.input.limit = Some(limit); } - let res = #call_inner_run; + let res = { + let policy: ::raiden::RetryPolicy = self.policy.clone().into(); + let client = self.client; + let input = self.input.clone(); + policy.retry_if(move || { + let client = client.clone(); + let input = input.clone(); + async { #call_inner_run } + }, self.condition).await? + }; if let Some(res_items) = res.items { for res_item in res_items.into_iter() { @@ -131,7 +144,7 @@ pub(crate) fn expand_scan( async fn inner_run( #inner_run_args - client: &::raiden::DynamoDbClient, + client: ::raiden::DynamoDbClient, input: ::raiden::ScanInput, ) -> Result<::raiden::ScanOutput, ::raiden::RaidenError> { Ok(#api_call_token?) diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index 3c5969c8..03171c0f 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -29,7 +29,7 @@ tracing = { version = "0.1", optional = true } uuid = { version = "^1.8", features = ["v4"] } [dev-dependencies] -aws-credential-types = "1.2.0" +aws-credential-types = { version = "^1" } aws-smithy-runtime = { version = "^1" } hyper-rustls = { version = "0.25", features = ["http2"] } pretty_assertions = "1.4.0" diff --git a/raiden/examples/delete.rs b/raiden/examples/delete.rs index ef980bf5..a0fe621f 100644 --- a/raiden/examples/delete.rs +++ b/raiden/examples/delete.rs @@ -4,9 +4,8 @@ use tracing_subscriber::{ EnvFilter, }; -#[derive(Raiden)] +#[derive(Raiden, Debug, Clone)] #[raiden(table_name = "QueryTestData0")] -#[derive(Debug, Clone)] #[allow(dead_code)] pub struct Test { #[raiden(partition_key)] @@ -22,23 +21,25 @@ async fn example() { endpoint: "http://localhost:8000".into(), name: "ap-northeast-1".into(), }); - let res = client.delete("id1", 2003_usize).run().await; + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) + let sdk_config = aws_config::defaults(aws_config::BehaviorVersion::latest()) .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) + .region(raiden::config::Region::from_static("ap-northeast-1")) .load() .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_client = raiden::Client::new(&sdk_config); let client = Test::client_with(sdk_client); let res = client.delete("id1", 2003_usize).run().await; + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/get_with_reserved.rs b/raiden/examples/get_with_reserved.rs index 31bfa6d4..1c4425a7 100644 --- a/raiden/examples/get_with_reserved.rs +++ b/raiden/examples/get_with_reserved.rs @@ -4,7 +4,7 @@ use tracing_subscriber::{ EnvFilter, }; -#[derive(Raiden)] +#[derive(Raiden, Debug)] #[raiden(table_name = "ReservedTestData0")] pub struct Reserved { #[raiden(partition_key)] @@ -18,21 +18,27 @@ async fn example() { endpoint: "http://localhost:8000".into(), name: "ap-northeast-1".into(), }); + let res = client.get("id0").run().await; - let _ = client.get("id0").run().await; + dbg!(&res); + assert!(res.is_err()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = Reserved::client_with(sdk_client); - let _ = client.get("id0").run().await; + let res = client.get("id0").run().await; + + dbg!(&res); + assert!(res.is_err()); } fn main() { diff --git a/raiden/examples/get_with_retries.rs b/raiden/examples/get_with_retries.rs index bb4bc1c5..568b0277 100644 --- a/raiden/examples/get_with_retries.rs +++ b/raiden/examples/get_with_retries.rs @@ -4,7 +4,7 @@ use tracing_subscriber::{ EnvFilter, }; -#[derive(Raiden)] +#[derive(Raiden, Debug)] #[raiden(table_name = "user")] pub struct User { #[raiden(partition_key)] @@ -29,29 +29,35 @@ async fn example() { endpoint: "http://localhost:8000".into(), name: "ap-northeast-1".into(), }); - - let _ = client + let res = client .with_retries(Box::new(MyRetryStrategy)) .get("anonymous") .run() .await; + + dbg!(&res); + assert!(res.is_err()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = User::client_with(sdk_client); - let _ = client + let res = client .with_retries(Box::new(MyRetryStrategy)) .get("anonymous") .run() .await; + + dbg!(&res); + assert!(res.is_err()); } fn main() { diff --git a/raiden/examples/hello.rs b/raiden/examples/hello.rs index de164ec8..7918fb95 100644 --- a/raiden/examples/hello.rs +++ b/raiden/examples/hello.rs @@ -4,51 +4,55 @@ use tracing_subscriber::{ EnvFilter, }; -#[derive(Raiden)] -#[raiden(table_name = "user")] -pub struct User { +#[derive(Raiden, Debug)] +#[raiden(table_name = "hello")] +pub struct Hello { #[raiden(partition_key)] pub id: String, #[raiden(sort_key)] pub year: usize, - #[raiden(uuid)] - pub uuid: String, - pub name: String, } #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] async fn example() { - let client = User::client(Region::Custom { + let client = Hello::client(Region::Custom { endpoint: "http://localhost:8000".into(), name: "ap-northeast-1".into(), }); - //let user = UserPutItemInput { + //let user = HelloPutItemInput { // id: "a".to_owned(), // name: "bokuweb".to_owned(), // // uuid: "aa".to_owned(), //}; - //let cond = User::condition() - // .attr(User::name()) - // .eq_attr(User::name()); + //let cond = Hello::condition() + // .attr(Hello::name()) + // .eq_attr(Hello::name()); // - //// let cond = User::condition().not().attr_type(User::name(), AttributeType::N); - //// .and(User::condition().not().attribute_exists(User::id())); + //// let cond = Hello::condition().not().attr_type(Hello::name(), AttributeType::N); + //// .and(Hello::condition().not().attribute_exists(Hello::id())); let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; - let _ = client.batch_get(keys).run().await; + let res = client.batch_get(keys).run().await; + + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - - let client = User::client_with(sdk_client); + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); + let client = Hello::client_with(sdk_client); let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; - let _ = client.batch_get(keys).run().await; + let res = client.batch_get(keys).run().await; + + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/last_key.rs b/raiden/examples/last_key.rs index 65efa789..ed58a986 100644 --- a/raiden/examples/last_key.rs +++ b/raiden/examples/last_key.rs @@ -4,7 +4,7 @@ use tracing_subscriber::{ EnvFilter, }; -#[derive(Raiden)] +#[derive(Raiden, Debug)] #[raiden(table_name = "LastEvaluateKeyData")] pub struct Test { #[raiden(partition_key)] @@ -20,7 +20,6 @@ async fn example() { name: "ap-northeast-1".into(), }); let cond = Test::key_condition(Test::ref_id()).eq("id0"); - let res = client .query() .index("testGSI") @@ -28,17 +27,21 @@ async fn example() { .key_condition(cond) .run() .await; - dbg!(&res.unwrap().items.len()); + + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = Test::client_with(sdk_client); let cond = Test::key_condition(Test::ref_id()).eq("id0"); @@ -49,7 +52,9 @@ async fn example() { .key_condition(cond) .run() .await; - dbg!(&res.unwrap().items.len()); + + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/put.rs b/raiden/examples/put.rs index 8703d15b..372aadeb 100644 --- a/raiden/examples/put.rs +++ b/raiden/examples/put.rs @@ -48,7 +48,7 @@ impl raiden::FromAttribute for CustomId { } } -#[derive(Raiden)] +#[derive(Raiden, Debug)] #[raiden(table_name = "user")] pub struct User { #[raiden(partition_key)] @@ -64,29 +64,35 @@ async fn example() { endpoint: "http://localhost:8000".into(), name: "ap-northeast-1".into(), }); - let input = User::put_item_builder() .id("testId".to_owned()) .name("bokuweb".to_owned()) .build(); - let _ = client.put(input).run().await; + let res = client.put(input).run().await; + + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = User::client_with(sdk_client); let input = User::put_item_builder() .id("testId".to_owned()) .name("bokuweb".to_owned()) .build(); - let _ = client.put(input).run().await; + let res = client.put(input).run().await; + + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/query.rs b/raiden/examples/query.rs index d1193621..96caefd0 100644 --- a/raiden/examples/query.rs +++ b/raiden/examples/query.rs @@ -25,13 +25,17 @@ async fn example() { .eq("id0") .and(QueryTestData0::key_condition(QueryTestData0::year()).eq(1999)); let res = client.query().key_condition(cond).run().await; + dbg!(&res); + assert!(res.is_ok()); let cond = QueryTestData0::key_condition(QueryTestData0::id()) .eq("id0") .and(QueryTestData0::key_condition(QueryTestData0::year()).eq(1999)); let res = client.query().key_condition(cond).run().await; + dbg!(&res); + assert!(res.is_ok()); let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id0"); let filter = QueryTestData0::filter_expression(QueryTestData0::num()).eq(1000); @@ -41,30 +45,37 @@ async fn example() { .filter(filter) .run() .await; + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = QueryTestData0::client_with(sdk_client); let cond = QueryTestData0::key_condition(QueryTestData0::id()) .eq("id0") .and(QueryTestData0::key_condition(QueryTestData0::year()).eq(1999)); let res = client.query().key_condition(cond).run().await; + dbg!(&res); + assert!(res.is_ok()); let cond = QueryTestData0::key_condition(QueryTestData0::id()) .eq("id0") .and(QueryTestData0::key_condition(QueryTestData0::year()).eq(1999)); let res = client.query().key_condition(cond).run().await; + dbg!(&res); + assert!(res.is_ok()); let cond = QueryTestData0::key_condition(QueryTestData0::id()).eq("id0"); let filter = QueryTestData0::filter_expression(QueryTestData0::num()).eq(1000); @@ -74,7 +85,9 @@ async fn example() { .filter(filter) .run() .await; + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/query_rename.rs b/raiden/examples/query_rename.rs index 947cebb3..68718ce3 100644 --- a/raiden/examples/query_rename.rs +++ b/raiden/examples/query_rename.rs @@ -4,7 +4,7 @@ use tracing_subscriber::{ EnvFilter, }; -#[derive(Raiden)] +#[derive(Raiden, Debug)] #[raiden(table_name = "Project")] #[raiden(rename_all = "camelCase")] pub struct Project { @@ -21,33 +21,40 @@ async fn example() { name: "ap-northeast-1".into(), }); let cond = Project::key_condition(Project::org_id()).eq("myOrg"); - let _res = client + let res = client .query() .index("orgIndex") .limit(11) .key_condition(cond) .run() .await; + + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = Project::client_with(sdk_client); let cond = Project::key_condition(Project::org_id()).eq("myOrg"); - let _res = client + let res = client .query() .index("orgIndex") .limit(11) .key_condition(cond) .run() .await; + + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/scan.rs b/raiden/examples/scan.rs index a12c70a3..33e941f4 100644 --- a/raiden/examples/scan.rs +++ b/raiden/examples/scan.rs @@ -22,21 +22,26 @@ async fn example() { name: "ap-northeast-1".into(), }); let res = client.scan().run().await; + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = ScanTestData0::client_with(sdk_client); let res = client.scan().run().await; + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/scan_with_filter.rs b/raiden/examples/scan_with_filter.rs index 05cf7c7a..f5fee17e 100644 --- a/raiden/examples/scan_with_filter.rs +++ b/raiden/examples/scan_with_filter.rs @@ -22,23 +22,30 @@ async fn example() { name: "ap-northeast-1".into(), }); let filter = Scan::filter_expression(Scan::num()).eq(1000); - let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 50); + let res = client.scan().filter(filter).run().await; + + dbg!(&res); + assert!(res.is_ok()); + assert_eq!(res.unwrap().items.len(), 50); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = Scan::client_with(sdk_client); let filter = Scan::filter_expression(Scan::num()).eq(1000); - let res = client.scan().filter(filter).run().await.unwrap(); - assert_eq!(res.items.len(), 50); + let res = client.scan().filter(filter).run().await; + + dbg!(&res); + assert!(res.is_ok()); + assert_eq!(res.unwrap().items.len(), 50); } fn main() { diff --git a/raiden/examples/transact_write.rs b/raiden/examples/transact_write.rs index 182cc231..b9fb8202 100644 --- a/raiden/examples/transact_write.rs +++ b/raiden/examples/transact_write.rs @@ -27,21 +27,26 @@ async fn example() { .id("testId2".to_owned()) .name("bokuweb".to_owned()) .build(); - tx.put(User::put(input).condition(cond)) + let res = tx + .put(User::put(input).condition(cond)) .put(User::put(input2)) .run() - .await - .unwrap(); + .await; + + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let tx = ::raiden::WriteTx::new_with_client(sdk_client); let cond = User::condition().attr_not_exists(User::id()); @@ -53,11 +58,14 @@ async fn example() { .id("testId2".to_owned()) .name("bokuweb".to_owned()) .build(); - tx.put(User::put(input).condition(cond)) + let res = tx + .put(User::put(input).condition(cond)) .put(User::put(input2)) .run() - .await - .unwrap(); + .await; + + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/transact_write_with_http_client.rs b/raiden/examples/transact_write_with_http_client.rs index 43e281ec..4e6675dd 100644 --- a/raiden/examples/transact_write_with_http_client.rs +++ b/raiden/examples/transact_write_with_http_client.rs @@ -19,7 +19,6 @@ async fn example() { let credentials_provider = raiden::credential::DefaultCredentialsProvider::new() .expect("failed to create credentials provider"); let core_client = raiden::Client::new_with(credentials_provider, dispatcher); - let tx = ::raiden::WriteTx::new_with_client( core_client, Region::Custom { @@ -36,11 +35,14 @@ async fn example() { .id("testId2".to_owned()) .name("bokuweb".to_owned()) .build(); - tx.put(User::put(input).condition(cond)) + let res = tx + .put(User::put(input).condition(cond)) .put(User::put(input2)) .run() - .await - .unwrap(); + .await; + + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] @@ -54,19 +56,20 @@ async fn example() { .build(); let http_client = aws_smithy_runtime::client::http::hyper_014::HyperClientBuilder::new() .build(https_connector); - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .http_client(http_client) - .region(raiden::Region::from_static("ap-northeast-1")) - .timeout_config( - aws_config::timeout::TimeoutConfig::builder() - .connect_timeout(std::time::Duration::from_secs(5)) - .build(), - ) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .http_client(http_client) + .region(raiden::config::Region::from_static("ap-northeast-1")) + .timeout_config( + raiden::config::timeout::TimeoutConfig::builder() + .connect_timeout(std::time::Duration::from_secs(5)) + .build(), + ) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let tx = ::raiden::WriteTx::new_with_client(sdk_client); let cond = User::condition().attr_not_exists(User::id()); let input = User::put_item_builder() @@ -77,11 +80,14 @@ async fn example() { .id("testId2".to_owned()) .name("bokuweb".to_owned()) .build(); - tx.put(User::put(input).condition(cond)) + let res = tx + .put(User::put(input).condition(cond)) .put(User::put(input2)) .run() - .await - .unwrap(); + .await; + + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/update.rs b/raiden/examples/update.rs index 9a1ff24e..d59f982b 100644 --- a/raiden/examples/update.rs +++ b/raiden/examples/update.rs @@ -23,35 +23,30 @@ async fn example() { let set_expression = Example::update_expression() .set(Example::name()) .value("updated!!"); - let res = client - .update("id0") - .set(set_expression) - .run() - .await - .unwrap(); - dbg!(res.item); + let res = client.update("id0").set(set_expression).run().await; + + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] async fn example() { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = Example::client_with(sdk_client); let set_expression = Example::update_expression() .set(Example::name()) .value("updated!!"); - let res = client - .update("id0") - .set(set_expression) - .run() - .await - .unwrap(); - dbg!(res.item); + let res = client.update("id0").set(set_expression).run().await; + + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/examples/with_http_client.rs b/raiden/examples/with_http_client.rs index 7160609e..71cdc7e5 100644 --- a/raiden/examples/with_http_client.rs +++ b/raiden/examples/with_http_client.rs @@ -4,16 +4,13 @@ use tracing_subscriber::{ EnvFilter, }; -#[derive(Raiden)] -#[raiden(table_name = "user")] +#[derive(Raiden, Debug)] +#[raiden(table_name = "hello")] pub struct User { #[raiden(partition_key)] pub id: String, #[raiden(sort_key)] pub year: usize, - #[raiden(uuid)] - pub uuid: String, - pub name: String, } #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] @@ -23,7 +20,6 @@ async fn example() { let credentials_provider = raiden::credential::DefaultCredentialsProvider::new() .expect("failed to create credentials provider"); let core_client = raiden::Client::new_with(credentials_provider, dispatcher); - let client = User::client_with( core_client, Region::Custom { @@ -31,9 +27,11 @@ async fn example() { name: "ap-northeast-1".into(), }, ); - let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; - let _ = client.batch_get(keys).run().await; + let res = client.batch_get(keys).run().await; + + dbg!(&res); + assert!(res.is_ok()); } #[cfg(feature = "aws-sdk")] @@ -47,22 +45,26 @@ async fn example() { .build(); let http_client = aws_smithy_runtime::client::http::hyper_014::HyperClientBuilder::new() .build(https_connector); - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .http_client(http_client) - .region(raiden::Region::from_static("ap-northeast-1")) - .timeout_config( - aws_config::timeout::TimeoutConfig::builder() - .connect_timeout(std::time::Duration::from_secs(5)) - .build(), - ) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); - + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .http_client(http_client) + .region(raiden::config::Region::from_static("ap-northeast-1")) + .timeout_config( + raiden::config::timeout::TimeoutConfig::builder() + .connect_timeout(std::time::Duration::from_secs(5)) + .build(), + ) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); let client = User::client_with(sdk_client); let keys: Vec<(&str, usize)> = vec![("bokuweb", 2019), ("raiden", 2020)]; - let _ = client.batch_get(keys).run().await; + let res = client.batch_get(keys).run().await; + + dbg!(&res); + assert!(res.is_ok()); } fn main() { diff --git a/raiden/src/aws_sdk/errors.rs b/raiden/src/aws_sdk/errors.rs index 4dba8d38..b7082802 100644 --- a/raiden/src/aws_sdk/errors.rs +++ b/raiden/src/aws_sdk/errors.rs @@ -1,9 +1,14 @@ -use aws_sdk_dynamodb::error::SdkError; - use crate::{ - BatchGetItemError, BatchWriteItemError, DeleteItemError, GetItemError, PutItemError, - QueryError, RaidenError, RaidenTransactionCancellationReasons, ScanError, - TransactWriteItemsError, UpdateItemError, + aws_sdk::{ + error::SdkError, + operation::{ + batch_get_item::BatchGetItemError, batch_write_item::BatchWriteItemError, + delete_item::DeleteItemError, get_item::GetItemError, put_item::PutItemError, + query::QueryError, scan::ScanError, transact_write_items::TransactWriteItemsError, + update_item::UpdateItemError, + }, + }, + RaidenError, RaidenTransactionCancellationReasons, }; fn into_raiden_error(error: SdkError) -> RaidenError { diff --git a/raiden/src/aws_sdk/mod.rs b/raiden/src/aws_sdk/mod.rs index 72de11f5..30123b67 100644 --- a/raiden/src/aws_sdk/mod.rs +++ b/raiden/src/aws_sdk/mod.rs @@ -5,30 +5,12 @@ pub(crate) mod serialize; use std::collections::{BTreeSet, HashMap, HashSet}; pub use self::ops::*; -pub use aws_config as config; -pub use aws_sdk_dynamodb::{ - client::*, - config::*, - error::*, - meta::*, - operation::{ - batch_get_item::{builders::*, *}, - batch_write_item::{builders::*, *}, - delete_item::{builders::*, *}, - get_item::{builders::*, *}, - put_item::{builders::*, *}, - query::{builders::*, *}, - scan::{builders::*, *}, - transact_write_items::{builders::*, *}, - update_item::{builders::*, *}, - }, - primitives::*, - types::{builders::*, *}, -}; +pub use aws_config; +pub use aws_sdk_dynamodb::*; use crate::{ - AttributeType, AttributeValues, ConversionError, FromAttribute, FromStringSetItem, - IntoAttribute, IntoStringSetItem, RaidenError, + aws_sdk::types::AttributeValue, AttributeType, AttributeValues, ConversionError, FromAttribute, + FromStringSetItem, IntoAttribute, IntoStringSetItem, RaidenError, }; impl IntoAttribute for AttributeType { diff --git a/raiden/src/aws_sdk/ops/transact_write.rs b/raiden/src/aws_sdk/ops/transact_write.rs index 0a0b41aa..ea541177 100644 --- a/raiden/src/aws_sdk/ops/transact_write.rs +++ b/raiden/src/aws_sdk/ops/transact_write.rs @@ -1,8 +1,11 @@ // DynamoDb, DynamoDbClient, TransactWriteItem, TransactWriteItemsInput use crate::{ - Client, Config, RaidenError, Region, RetryCondition, RetryStrategy, - TransactWriteConditionCheckBuilder, TransactWriteDeleteBuilder, TransactWriteItem, - TransactWriteItemsFluentBuilder, TransactWritePutBuilder, TransactWriteUpdateBuilder, + aws_sdk::{ + config::Region, operation::transact_write_items::builders::TransactWriteItemsFluentBuilder, + types::TransactWriteItem, + }, + Client, Config, RaidenError, RetryCondition, RetryStrategy, TransactWriteConditionCheckBuilder, + TransactWriteDeleteBuilder, TransactWritePutBuilder, TransactWriteUpdateBuilder, }; pub struct WriteTx { @@ -18,7 +21,10 @@ impl WriteTx { Self { items: vec![], client: Client::from_conf(config), - retry_condition: RetryCondition::new(), + // NOTE: + // Since the AWS SDK provides a retry option, + // configure it to not retry by default. + retry_condition: RetryCondition::never(), } } @@ -26,7 +32,10 @@ impl WriteTx { Self { items: vec![], client, - retry_condition: RetryCondition::new(), + // NOTE: + // Since the AWS SDK provides a retry option, + // configure it to not retry by default. + retry_condition: RetryCondition::never(), } } diff --git a/raiden/src/aws_sdk/serialize/attribute_value.rs b/raiden/src/aws_sdk/serialize/attribute_value.rs index 83f3ae60..8740d9d3 100644 --- a/raiden/src/aws_sdk/serialize/attribute_value.rs +++ b/raiden/src/aws_sdk/serialize/attribute_value.rs @@ -1,11 +1,10 @@ use std::collections::HashMap; -use aws_sdk_dynamodb::primitives::Blob; use base64::{engine::general_purpose::STANDARD, Engine}; use serde::de::{self, Error as _}; use serde_json::{json, Error, Value}; -use crate::AttributeValue; +use crate::aws_sdk::{primitives::Blob, types::AttributeValue}; pub fn attribute_value_to_value(value: &AttributeValue) -> Value { match value { diff --git a/raiden/src/aws_sdk/serialize/consumed_capacity.rs b/raiden/src/aws_sdk/serialize/consumed_capacity.rs index a4ead907..03b2d225 100644 --- a/raiden/src/aws_sdk/serialize/consumed_capacity.rs +++ b/raiden/src/aws_sdk/serialize/consumed_capacity.rs @@ -3,9 +3,12 @@ use std::collections::HashMap; use serde::de; use serde_json::{json, Error, Map, Value}; -use crate::aws_sdk::serialize::set_optional_value; +use crate::aws_sdk::{ + serialize::set_optional_value, + types::{Capacity, ConsumedCapacity}, +}; -pub fn consumed_capacity_to_value(v: &crate::ConsumedCapacity) -> Value { +pub fn consumed_capacity_to_value(v: &ConsumedCapacity) -> Value { json!({ "table_name": v.table_name, "capacity_units": v.capacity_units, @@ -29,12 +32,12 @@ pub fn consumed_capacity_to_value(v: &crate::ConsumedCapacity) -> Value { }) } -pub fn value_to_consumed_capacity(value: Value) -> Result { +pub fn value_to_consumed_capacity(value: Value) -> Result { let Value::Object(m) = value else { return Err(de::Error::custom("value is not type of ConsumedCapacity")); }; - let mut builder = crate::ConsumedCapacity::builder(); + let mut builder = ConsumedCapacity::builder(); set_optional_value!(builder, m, table_name, String); set_optional_value!(builder, m, capacity_units, f64); @@ -80,7 +83,7 @@ pub fn value_to_consumed_capacity(value: Value) -> Result Value { +pub fn capacity_to_value(v: &Capacity) -> Value { json!({ "read_capacity_units": v.read_capacity_units, "write_capacity_units": v.write_capacity_units, @@ -88,12 +91,12 @@ pub fn capacity_to_value(v: &crate::Capacity) -> Value { }) } -pub fn value_to_capacity(value: Value) -> Result { +pub fn value_to_capacity(value: Value) -> Result { let Value::Object(m) = value else { return Err(de::Error::custom("value is not type of Capacity")); }; - let mut builder = crate::Capacity::builder(); + let mut builder = Capacity::builder(); set_optional_value!(builder, m, read_capacity_units, f64); set_optional_value!(builder, m, write_capacity_units, f64); diff --git a/raiden/src/aws_sdk/serialize/delete_request.rs b/raiden/src/aws_sdk/serialize/delete_request.rs index 22be631f..4bb691bf 100644 --- a/raiden/src/aws_sdk/serialize/delete_request.rs +++ b/raiden/src/aws_sdk/serialize/delete_request.rs @@ -3,11 +3,12 @@ use std::collections::HashMap; use serde::de::{self, Error as _}; use serde_json::{json, Error, Map, Value}; -use crate::aws_sdk::serialize::{ - attribute_value_to_value, set_optional_value, value_to_attribute_value, +use crate::aws_sdk::{ + serialize::{attribute_value_to_value, set_optional_value, value_to_attribute_value}, + types::DeleteRequest, }; -pub fn delete_request_to_value(v: &crate::DeleteRequest) -> Value { +pub fn delete_request_to_value(v: &DeleteRequest) -> Value { json!({ "key": v.key.iter().map(|(k, v)| { (k.clone(), attribute_value_to_value(v)) @@ -15,9 +16,9 @@ pub fn delete_request_to_value(v: &crate::DeleteRequest) -> Value { }) } -pub fn value_to_delete_request(value: Value) -> Result { +pub fn value_to_delete_request(value: Value) -> Result { if let Value::Object(m) = value { - let mut builder = crate::DeleteRequest::builder(); + let mut builder = DeleteRequest::builder(); set_optional_value!(builder, m, key, object, |m: &Map<_, _>| -> Result<_, _> { let mut map = HashMap::new(); diff --git a/raiden/src/aws_sdk/serialize/item_collection_metrics.rs b/raiden/src/aws_sdk/serialize/item_collection_metrics.rs index 1bf334d7..070e07ae 100644 --- a/raiden/src/aws_sdk/serialize/item_collection_metrics.rs +++ b/raiden/src/aws_sdk/serialize/item_collection_metrics.rs @@ -3,11 +3,14 @@ use std::collections::HashMap; use serde::de; use serde_json::{json, Error, Map, Value}; -use crate::aws_sdk::serialize::{ - attribute_value_to_value, parse_value, set_optional_value, value_to_attribute_value, +use crate::aws_sdk::{ + serialize::{ + attribute_value_to_value, parse_value, set_optional_value, value_to_attribute_value, + }, + types::ItemCollectionMetrics, }; -pub fn item_collection_metrics_to_value(v: &crate::ItemCollectionMetrics) -> Value { +pub fn item_collection_metrics_to_value(v: &ItemCollectionMetrics) -> Value { json!({ "item_collection_key": v.item_collection_key.as_ref().map(|v| { v @@ -19,11 +22,9 @@ pub fn item_collection_metrics_to_value(v: &crate::ItemCollectionMetrics) -> Val }) } -pub fn value_to_item_collection_metrics( - value: Value, -) -> Result { +pub fn value_to_item_collection_metrics(value: Value) -> Result { if let Value::Object(m) = value { - let mut builder = crate::ItemCollectionMetrics::builder(); + let mut builder = ItemCollectionMetrics::builder(); set_optional_value!( builder, diff --git a/raiden/src/aws_sdk/serialize/keys_and_attributes.rs b/raiden/src/aws_sdk/serialize/keys_and_attributes.rs index 8cdcd55c..07a580a0 100644 --- a/raiden/src/aws_sdk/serialize/keys_and_attributes.rs +++ b/raiden/src/aws_sdk/serialize/keys_and_attributes.rs @@ -4,11 +4,14 @@ use serde::de::{self, Error as _}; use serde_json::{json, Error, Map, Value}; use crate::{ - aws_sdk::serialize::{attribute_value_to_value, parse_value, set_optional_value}, + aws_sdk::{ + serialize::{attribute_value_to_value, parse_value, set_optional_value}, + types::KeysAndAttributes, + }, serialize::value_to_attribute_value, }; -pub fn keys_and_attributes_to_value(v: &crate::KeysAndAttributes) -> Value { +pub fn keys_and_attributes_to_value(v: &KeysAndAttributes) -> Value { json!({ "keys": v.keys.iter().map(|v| v.iter().map(|(k, v)| { (k.clone(), attribute_value_to_value(v)) @@ -20,9 +23,9 @@ pub fn keys_and_attributes_to_value(v: &crate::KeysAndAttributes) -> Value { }) } -pub fn value_to_keys_and_attributes(value: Value) -> Result { +pub fn value_to_keys_and_attributes(value: Value) -> Result { if let Value::Object(m) = value { - let mut builder = crate::KeysAndAttributes::builder(); + let mut builder = KeysAndAttributes::builder(); set_optional_value!(builder, m, keys, array, |vs: &Vec<_>| -> Result<_, _> { let mut values = vec![]; diff --git a/raiden/src/errors/mod.rs b/raiden/src/errors/mod.rs index 69def363..819287cf 100644 --- a/raiden/src/errors/mod.rs +++ b/raiden/src/errors/mod.rs @@ -70,7 +70,7 @@ pub enum RaidenError { #[error("`transaction canceled error {reasons}: {raw_reasons:?}`")] TransactionCanceled { reasons: RaidenTransactionCancellationReasons, - raw_reasons: Vec, + raw_reasons: Vec, }, #[cfg(feature = "aws-sdk")] #[error("unknown error")] diff --git a/raiden/src/lib.rs b/raiden/src/lib.rs index 9749bb39..1364caa8 100644 --- a/raiden/src/lib.rs +++ b/raiden/src/lib.rs @@ -1,6 +1,3 @@ -// NOTE: allow to re-export aws_sdk_dynamodb. -#![cfg_attr(feature = "aws-sdk", allow(ambiguous_glob_reexports))] - #[cfg(all(feature = "rusoto", feature = "rusoto_rustls"))] compile_error!("feature \"rusoto\" and \"rusoto_rustls\" cannot be enabled at the same time."); @@ -31,13 +28,13 @@ pub mod value_id; mod rusoto; #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] -pub use rusoto::*; +pub use self::rusoto::*; #[cfg(feature = "aws-sdk")] -mod aws_sdk; +pub mod aws_sdk; #[cfg(feature = "aws-sdk")] -pub use aws_sdk::*; +pub use self::aws_sdk::{types::AttributeValue, *}; pub use condition::*; pub use errors::*; diff --git a/raiden/src/ops/batch_delete.rs b/raiden/src/ops/batch_delete.rs index 20eece32..b82a3c8f 100644 --- a/raiden/src/ops/batch_delete.rs +++ b/raiden/src/ops/batch_delete.rs @@ -1,3 +1,9 @@ +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +use crate::{ConsumedCapacity, DeleteRequest}; + +#[cfg(feature = "aws-sdk")] +use crate::aws_sdk::types::{ConsumedCapacity, DeleteRequest}; + // See. https://github.com/rusoto/rusoto/blob/69e7c9150d98916ef8fc814f5cd17eb0e4dee3d3/rusoto/services/dynamodb/src/generated.rs#L395 #[derive(Default, Debug, Clone, PartialEq)] #[cfg_attr( @@ -5,6 +11,6 @@ derive(serde::Deserialize, serde::Serialize) )] pub struct BatchDeleteOutput { - pub consumed_capacity: Option>, - pub unprocessed_items: Vec, + pub consumed_capacity: Option>, + pub unprocessed_items: Vec, } diff --git a/raiden/src/ops/batch_get.rs b/raiden/src/ops/batch_get.rs index 77727259..7d8a9461 100644 --- a/raiden/src/ops/batch_get.rs +++ b/raiden/src/ops/batch_get.rs @@ -1,3 +1,9 @@ +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +use crate::{ConsumedCapacity, KeysAndAttributes}; + +#[cfg(feature = "aws-sdk")] +use crate::aws_sdk::types::{ConsumedCapacity, KeysAndAttributes}; + // See. https://github.com/rusoto/rusoto/blob/69e7c9150d98916ef8fc814f5cd17eb0e4dee3d3/rusoto/services/dynamodb/src/generated.rs#L356 #[derive(Default, Debug, Clone, PartialEq)] #[cfg_attr( @@ -5,7 +11,7 @@ derive(serde::Deserialize, serde::Serialize) )] pub struct BatchGetOutput { - pub consumed_capacity: Option>, + pub consumed_capacity: Option>, pub items: Vec, - pub unprocessed_keys: Option, + pub unprocessed_keys: Option, } diff --git a/raiden/src/ops/get.rs b/raiden/src/ops/get.rs index 77814491..52be363a 100644 --- a/raiden/src/ops/get.rs +++ b/raiden/src/ops/get.rs @@ -1,3 +1,9 @@ +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +use crate::ConsumedCapacity; + +#[cfg(feature = "aws-sdk")] +use crate::aws_sdk::types::ConsumedCapacity; + // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L1168 #[derive(Default, Debug, Clone, PartialEq)] #[cfg_attr( @@ -5,6 +11,6 @@ derive(serde::Deserialize, serde::Serialize) )] pub struct GetOutput { - pub consumed_capacity: Option, + pub consumed_capacity: Option, pub item: T, } diff --git a/raiden/src/ops/put.rs b/raiden/src/ops/put.rs index d9d75b31..7309b3ed 100644 --- a/raiden/src/ops/put.rs +++ b/raiden/src/ops/put.rs @@ -1,3 +1,9 @@ +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +use crate::ConsumedCapacity; + +#[cfg(feature = "aws-sdk")] +use crate::aws_sdk::types::ConsumedCapacity; + // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L1168 #[derive(Default, Debug, Clone, PartialEq)] #[cfg_attr( @@ -5,6 +11,6 @@ derive(serde::Deserialize, serde::Serialize) )] pub struct PutOutput { - pub consumed_capacity: Option, + pub consumed_capacity: Option, pub item: T, } diff --git a/raiden/src/ops/query.rs b/raiden/src/ops/query.rs index 539f9cb9..8b07ec19 100644 --- a/raiden/src/ops/query.rs +++ b/raiden/src/ops/query.rs @@ -1,3 +1,9 @@ +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +use crate::ConsumedCapacity; + +#[cfg(feature = "aws-sdk")] +use crate::aws_sdk::types::ConsumedCapacity; + // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L1168 #[derive(Default, Debug, Clone, PartialEq)] #[cfg_attr( @@ -5,7 +11,7 @@ derive(serde::Deserialize, serde::Serialize) )] pub struct QueryOutput { - pub consumed_capacity: Option, + pub consumed_capacity: Option, pub items: Vec, pub count: Option, pub next_token: Option, diff --git a/raiden/src/ops/scan.rs b/raiden/src/ops/scan.rs index 6d2a5641..cfe097cb 100644 --- a/raiden/src/ops/scan.rs +++ b/raiden/src/ops/scan.rs @@ -1,3 +1,9 @@ +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +use crate::{AttributeValue, ConsumedCapacity}; + +#[cfg(feature = "aws-sdk")] +use crate::aws_sdk::types::{AttributeValue, ConsumedCapacity}; + // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L2406 #[derive(Default, Debug, Clone, PartialEq)] #[cfg_attr( @@ -5,9 +11,9 @@ derive(serde::Deserialize, serde::Serialize) )] pub struct ScanOutput { - pub consumed_capacity: Option, + pub consumed_capacity: Option, pub items: Vec, pub count: Option, - pub last_evaluated_key: Option<::std::collections::HashMap>, + pub last_evaluated_key: Option<::std::collections::HashMap>, pub scanned_count: Option, } diff --git a/raiden/src/ops/transact_write.rs b/raiden/src/ops/transact_write.rs index bf38d8ce..65183127 100644 --- a/raiden/src/ops/transact_write.rs +++ b/raiden/src/ops/transact_write.rs @@ -1,15 +1,21 @@ +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +use crate::{ConditionCheck, Delete, Put, Update}; + +#[cfg(feature = "aws-sdk")] +use crate::aws_sdk::types::{ConditionCheck, Delete, Put, Update}; + pub trait TransactWritePutBuilder { - fn build(self) -> crate::Put; + fn build(self) -> Put; } pub trait TransactWriteUpdateBuilder { - fn build(self) -> crate::Update; + fn build(self) -> Update; } pub trait TransactWriteDeleteBuilder { - fn build(self) -> crate::Delete; + fn build(self) -> Delete; } pub trait TransactWriteConditionCheckBuilder { - fn build(self) -> crate::ConditionCheck; + fn build(self) -> ConditionCheck; } diff --git a/raiden/src/ops/update.rs b/raiden/src/ops/update.rs index 9c7087c2..8ce01ab5 100644 --- a/raiden/src/ops/update.rs +++ b/raiden/src/ops/update.rs @@ -1,3 +1,9 @@ +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +use crate::{ConsumedCapacity, ItemCollectionMetrics}; + +#[cfg(feature = "aws-sdk")] +use crate::aws_sdk::types::{ConsumedCapacity, ItemCollectionMetrics}; + // See. https://github.com/rusoto/rusoto/blob/cf22a4348ae717a20760bb9934cfd118ddb4437e/rusoto/services/dynamodb/src/generated.rs#L2971 #[derive(Default, Debug, Clone, PartialEq)] #[cfg_attr( @@ -5,7 +11,7 @@ derive(serde::Deserialize, serde::Serialize) )] pub struct UpdateOutput { - pub consumed_capacity: Option, + pub consumed_capacity: Option, pub item: Option, - pub item_collection_metrics: Option, + pub item_collection_metrics: Option, } diff --git a/raiden/src/retry/mod.rs b/raiden/src/retry/mod.rs index 8778b15e..53f681b3 100644 --- a/raiden/src/retry/mod.rs +++ b/raiden/src/retry/mod.rs @@ -45,6 +45,12 @@ impl RetryCondition { pub fn new() -> Self { Default::default() } + + pub fn never() -> Self { + Self { + strategy: Box::new(NopRetryStrategy), + } + } } impl Default for RetryCondition { @@ -106,3 +112,16 @@ impl RetryStrategy for DefaultRetryStrategy { Policy::default() } } + +#[derive(Clone, Copy, PartialEq, Debug)] +pub struct NopRetryStrategy; + +impl RetryStrategy for NopRetryStrategy { + fn should_retry(&self, _: &RaidenError) -> bool { + false + } + + fn policy(&self) -> Policy { + Policy::None + } +} diff --git a/raiden/tests/all/mod.rs b/raiden/tests/all/mod.rs index 623d2edb..1d66fa1f 100644 --- a/raiden/tests/all/mod.rs +++ b/raiden/tests/all/mod.rs @@ -36,12 +36,14 @@ macro_rules! create_client_from_struct { #[cfg(feature = "aws-sdk")] macro_rules! create_client { ($ty: ty) => {{ - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); <$ty>::new_with_client(sdk_client) }}; @@ -50,12 +52,14 @@ macro_rules! create_client { #[cfg(feature = "aws-sdk")] macro_rules! create_client_from_struct { ($ty: ty) => {{ - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); <$ty>::client_with(sdk_client) }}; @@ -75,8 +79,8 @@ fn default_key_and_attributes() -> raiden::KeysAndAttributes { } #[cfg(feature = "aws-sdk")] -fn default_key_and_attributes() -> raiden::KeysAndAttributes { - let mut v = raiden::KeysAndAttributes::builder() +fn default_key_and_attributes() -> raiden::aws_sdk::types::KeysAndAttributes { + let mut v = raiden::aws_sdk::types::KeysAndAttributes::builder() .keys(std::collections::HashMap::new()) .build() .expect("should be built"); diff --git a/raiden/tests/all/put.rs b/raiden/tests/all/put.rs index cfc2578e..60a96c55 100644 --- a/raiden/tests/all/put.rs +++ b/raiden/tests/all/put.rs @@ -64,7 +64,7 @@ mod tests { }; #[cfg(feature = "aws-sdk")] - let expected = ::raiden::PutItemInput::builder() + let expected = ::raiden::operation::put_item::PutItemInput::builder() .condition_expression("attribute_not_exists(#name)") .set_expression_attribute_names(Some(attribute_names)) .set_item(Some(item)) diff --git a/raiden/tests/all/transact_write.rs b/raiden/tests/all/transact_write.rs index aca43ba4..85abef49 100644 --- a/raiden/tests/all/transact_write.rs +++ b/raiden/tests/all/transact_write.rs @@ -10,12 +10,14 @@ mod tests { #[cfg(feature = "aws-sdk")] async fn create_client() -> ::raiden::WriteTx { - let sdk_config = raiden::config::defaults(raiden::BehaviorVersion::latest()) - .endpoint_url("http://localhost:8000") - .region(raiden::Region::from_static("ap-northeast-1")) - .load() - .await; - let sdk_client = aws_sdk_dynamodb::Client::new(&sdk_config); + let sdk_config = ::raiden::aws_sdk::aws_config::defaults( + ::raiden::aws_sdk::config::BehaviorVersion::latest(), + ) + .endpoint_url("http://localhost:8000") + .region(::raiden::config::Region::from_static("ap-northeast-1")) + .load() + .await; + let sdk_client = ::raiden::Client::new(&sdk_config); ::raiden::WriteTx::new_with_client(sdk_client) } diff --git a/setup/fixtures/hello.ts b/setup/fixtures/hello.ts new file mode 100644 index 00000000..e70d1ada --- /dev/null +++ b/setup/fixtures/hello.ts @@ -0,0 +1,26 @@ +import type { CreateAndPut } from "../dynamo_util.ts"; + +export const hello: CreateAndPut = { + table: { + TableName: "hello", + KeySchema: [ + { AttributeName: "id", KeyType: "HASH" }, + { AttributeName: "year", KeyType: "RANGE" }, + ], + AttributeDefinitions: [ + { AttributeName: "id", AttributeType: "S" }, + { AttributeName: "year", AttributeType: "N" }, + ], + ProvisionedThroughput: { ReadCapacityUnits: 5, WriteCapacityUnits: 5 }, + }, + items: [ + { + id: { S: "bokuweb" }, + year: { N: "2019" }, + }, + { + id: { S: "raiden" }, + year: { N: "2020" }, + }, + ], +}; diff --git a/setup/setup.ts b/setup/setup.ts index eb632aaf..09c77bd7 100644 --- a/setup/setup.ts +++ b/setup/setup.ts @@ -1,42 +1,43 @@ import { DynamoDBClient } from "./deps.ts"; -import { createTableAndPutItems, getCredFromEnv } from "./dynamo_util.ts"; -import { user } from "./fixtures/user.ts"; -import { floatTest } from "./fixtures/float_test.ts"; -import { queryTestData0 } from "./fixtures/query_test_data_0.ts"; -import { queryTestData1 } from "./fixtures/query_test_data_1.ts"; -import { renameTestData0 } from "./fixtures/rename_test_data_0.ts"; -import { renameAllCamelCaseTestData0 } from "./fixtures/rename_all_camel_case_test_data_0.ts"; -import { renameAllPascalCaseTestData0 } from "./fixtures/rename_all_pascal_case_test_data_0.ts"; -import { updateTestData0 } from "./fixtures/update_test_data_0.ts"; -import { updateTestData1 } from "./fixtures/update_test_data_1.ts"; -import { putItemConditionData0 } from "./fixtures/put_item_condition_data_0.ts"; -import { lastEvaluateKeyData } from "./fixtures/last_evaluate_key_data.ts"; -import { project } from "./fixtures/project.ts"; +import { batchDeleteTest0 } from "./fixtures/batch_delete_test_0.ts"; +import { batchDeleteTest1 } from "./fixtures/batch_delete_test_1.ts"; import { batchTest0 } from "./fixtures/batch_test_0.ts"; import { batchTest1 } from "./fixtures/batch_test_1.ts"; import { batchTest2 } from "./fixtures/batch_test_2.ts"; -import { batchDeleteTest0 } from "./fixtures/batch_delete_test_0.ts"; -import { batchDeleteTest1 } from "./fixtures/batch_delete_test_1.ts"; -import { testUserStaging } from "./fixtures/test_user_staging.ts"; +import { createTableAndPutItems, getCredFromEnv } from "./dynamo_util.ts"; import { deleteTest0 } from "./fixtures/delete_test_0.ts"; import { deleteTest1 } from "./fixtures/delete_test_1.ts"; -import { scanTestData0 } from "./fixtures/scan_test_data_0.ts"; -import { scanWithFilterTestData0 } from "./fixtures/scan_with_filter_test_data_0.ts"; +import { emptyPutTestData0 } from "./fixtures/empty_put_test_data_0.ts"; import { emptySetTestData0 } from "./fixtures/empty_set_test_data_0.ts"; import { emptyStringTestData0 } from "./fixtures/empty_string_test_data_0.ts"; -import { useDefaultForNull } from "./fixtures/use_default_for_null_data.ts"; -import { updateDeleteTestData0 } from "./fixtures/update_delete_test_data_0.ts"; -import { updateAddTestData0 } from "./fixtures/update_add_test_data_0.ts"; -import { emptyPutTestData0 } from "./fixtures/empty_put_test_data_0.ts"; +import { floatTest } from "./fixtures/float_test.ts"; +import { hello } from "./fixtures/hello.ts"; +import { lastEvaluateKeyData } from "./fixtures/last_evaluate_key_data.ts"; +import { project } from "./fixtures/project.ts"; +import { putItemConditionData0 } from "./fixtures/put_item_condition_data_0.ts"; +import { queryLargeDataTest } from "./fixtures/query_large_data_test.ts"; +import { queryTestData0 } from "./fixtures/query_test_data_0.ts"; +import { queryTestData1 } from "./fixtures/query_test_data_1.ts"; +import { renameAllCamelCaseTestData0 } from "./fixtures/rename_all_camel_case_test_data_0.ts"; +import { renameAllPascalCaseTestData0 } from "./fixtures/rename_all_pascal_case_test_data_0.ts"; +import { renameTestData0 } from "./fixtures/rename_test_data_0.ts"; import { reservedTestData0 } from "./fixtures/reserved_test_data_0.ts"; -import { useDefaultTestData0 } from "./fixtures/use_default_test_data_0.ts"; -import { txDeleteTestData0 } from "./fixtures/tx_delete_test_data_0.ts"; +import { scanLargeDataTest } from "./fixtures/scan_large_data_test.ts"; +import { scanTestData0 } from "./fixtures/scan_test_data_0.ts"; +import { scanWithFilterTestData0 } from "./fixtures/scan_with_filter_test_data_0.ts"; +import { testUserStaging } from "./fixtures/test_user_staging.ts"; import { txConditionalCheckTestData0 } from "./fixtures/tx_conditional_check_test_data_0.ts"; import { txConditionalCheckTestData1 } from "./fixtures/tx_conditional_check_test_data_1.ts"; +import { txDeleteTestData0 } from "./fixtures/tx_delete_test_data_0.ts"; +import { updateAddTestData0 } from "./fixtures/update_add_test_data_0.ts"; +import { updateDeleteTestData0 } from "./fixtures/update_delete_test_data_0.ts"; import { updateRemoveTestData0 } from "./fixtures/update_remove_test_data_0.ts"; +import { updateTestData0 } from "./fixtures/update_test_data_0.ts"; +import { updateTestData1 } from "./fixtures/update_test_data_1.ts"; import { updateWithContainsInSetCondition } from "./fixtures/update_with_contains_in_set_condition.ts"; -import { queryLargeDataTest } from "./fixtures/query_large_data_test.ts"; -import { scanLargeDataTest } from "./fixtures/scan_large_data_test.ts"; +import { useDefaultForNull } from "./fixtures/use_default_for_null_data.ts"; +import { useDefaultTestData0 } from "./fixtures/use_default_test_data_0.ts"; +import { user } from "./fixtures/user.ts"; const client = new DynamoDBClient({ region: "ap-northeast-1", @@ -45,43 +46,44 @@ const client = new DynamoDBClient({ }); const data = [ - user, - floatTest, - queryTestData0, - queryTestData1, - renameTestData0, - renameAllCamelCaseTestData0, - renameAllPascalCaseTestData0, - updateTestData0, - updateTestData1, - putItemConditionData0, - lastEvaluateKeyData, - project, + batchDeleteTest0, + batchDeleteTest1, batchTest0, batchTest1, batchTest2, - batchDeleteTest0, - batchDeleteTest1, - testUserStaging, deleteTest0, deleteTest1, - scanTestData0, - scanWithFilterTestData0, + emptyPutTestData0, emptySetTestData0, emptyStringTestData0, - updateDeleteTestData0, - updateAddTestData0, - emptyPutTestData0, + floatTest, + hello, + lastEvaluateKeyData, + project, + putItemConditionData0, + queryLargeDataTest, + queryTestData0, + queryTestData1, + renameAllCamelCaseTestData0, + renameAllPascalCaseTestData0, + renameTestData0, reservedTestData0, - useDefaultTestData0, - txDeleteTestData0, + scanLargeDataTest, + scanTestData0, + scanWithFilterTestData0, + testUserStaging, txConditionalCheckTestData0, txConditionalCheckTestData1, + txDeleteTestData0, + updateAddTestData0, + updateDeleteTestData0, updateRemoveTestData0, + updateTestData0, + updateTestData1, updateWithContainsInSetCondition, - queryLargeDataTest, - scanLargeDataTest, useDefaultForNull, + useDefaultTestData0, + user, ]; // NOTE: Running these operations concurrently with `Promise.all` would lead to running out of write buffer. From fcb32f27c1029c60c6ec2f95d4ef07861a6b6249 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Fri, 31 May 2024 20:14:38 +0900 Subject: [PATCH 12/22] fix: handling optional value. add module path for idents. --- raiden-derive/src/aws_sdk/ops/query.rs | 4 ++-- raiden-derive/src/aws_sdk/ops/shared.rs | 2 +- raiden-derive/src/rusoto/ops/shared.rs | 2 +- raiden/src/aws_sdk/mod.rs | 10 +++++----- raiden/src/rusoto/mod.rs | 10 +++++----- 5 files changed, 14 insertions(+), 14 deletions(-) diff --git a/raiden-derive/src/aws_sdk/ops/query.rs b/raiden-derive/src/aws_sdk/ops/query.rs index 488c5160..85362175 100644 --- a/raiden-derive/src/aws_sdk/ops/query.rs +++ b/raiden-derive/src/aws_sdk/ops/query.rs @@ -51,8 +51,8 @@ pub(crate) fn expand_query( struct #query_output_item { consumed_capacity: Option<::raiden::aws_sdk::types::ConsumedCapacity>, count: Option, - items: Option>>, - last_evaluated_key: Option<::std::collections::HashMap>, + items: Option>>, + last_evaluated_key: Option<::std::collections::HashMap>, scanned_count: Option, } diff --git a/raiden-derive/src/aws_sdk/ops/shared.rs b/raiden-derive/src/aws_sdk/ops/shared.rs index fa531226..4a7cb380 100644 --- a/raiden-derive/src/aws_sdk/ops/shared.rs +++ b/raiden-derive/src/aws_sdk/ops/shared.rs @@ -19,7 +19,7 @@ pub(crate) fn expand_attr_to_item( let ty = &f.ty; let item = quote! { - let item = <#ty as ResolveAttribute>::resolve_attr(&#attr_key, &mut #item_ident); + let item = <#ty as ::raiden::ResolveAttribute>::resolve_attr(&#attr_key, &mut #item_ident); }; if crate::finder::is_option(ty) { quote! { diff --git a/raiden-derive/src/rusoto/ops/shared.rs b/raiden-derive/src/rusoto/ops/shared.rs index 2b926f81..c355ad65 100644 --- a/raiden-derive/src/rusoto/ops/shared.rs +++ b/raiden-derive/src/rusoto/ops/shared.rs @@ -19,7 +19,7 @@ pub(crate) fn expand_attr_to_item( let ty = &f.ty; let item = quote! { - let item = <#ty as ResolveAttribute>::resolve_attr(&#attr_key, &mut #item_ident); + let item = <#ty as ::raiden::ResolveAttribute>::resolve_attr(&#attr_key, &mut #item_ident); }; if crate::finder::is_option(ty) { diff --git a/raiden/src/aws_sdk/mod.rs b/raiden/src/aws_sdk/mod.rs index 30123b67..3f20c745 100644 --- a/raiden/src/aws_sdk/mod.rs +++ b/raiden/src/aws_sdk/mod.rs @@ -104,11 +104,11 @@ impl IntoAttribute for Option { impl FromAttribute for Option { fn from_attr(value: Option) -> Result { - Ok(if let Some(v) = value { - Some(FromAttribute::from_attr(Some(v))?) - } else { - None - }) + match value { + None => Ok(None), + Some(v) if v.is_null() => Ok(None), + _ => Ok(Some(FromAttribute::from_attr(value)?)), + } } } diff --git a/raiden/src/rusoto/mod.rs b/raiden/src/rusoto/mod.rs index 5c284f44..e80fad74 100644 --- a/raiden/src/rusoto/mod.rs +++ b/raiden/src/rusoto/mod.rs @@ -140,11 +140,11 @@ impl IntoAttribute for Option { impl FromAttribute for Option { fn from_attr(value: Option) -> Result { - Ok(if let Some(v) = value { - Some(FromAttribute::from_attr(Some(v))?) - } else { - None - }) + match value { + None => Ok(None), + Some(v) if Some(true) == v.null => Ok(None), + _ => Ok(Some(FromAttribute::from_attr(value)?)), + } } } From cc580cbd7bbff48b6860c5a96993dd4848e2846a Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Sat, 1 Jun 2024 00:21:46 +0900 Subject: [PATCH 13/22] fix: spelling mistakes --- .gitignore | 3 +- raiden-derive/src/aws_sdk/ops/batch_delete.rs | 2 +- raiden-derive/src/rusoto/ops/batch_delete.rs | 2 +- raiden/src/aws_sdk/errors.rs | 142 +++++++++--------- raiden/src/errors/transaction.rs | 4 +- 5 files changed, 78 insertions(+), 75 deletions(-) diff --git a/.gitignore b/.gitignore index 5feb9078..c31107e1 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,3 @@ +.vscode +node_modules target -node_modules \ No newline at end of file diff --git a/raiden-derive/src/aws_sdk/ops/batch_delete.rs b/raiden-derive/src/aws_sdk/ops/batch_delete.rs index acb82d10..abb3d04f 100644 --- a/raiden-derive/src/aws_sdk/ops/batch_delete.rs +++ b/raiden-derive/src/aws_sdk/ops/batch_delete.rs @@ -164,7 +164,7 @@ pub(crate) fn expand_batch_delete( let unprocessed_requests = unprocessed_items .remove(&self.table_name) - .expect("reqeust_items hashmap must have a value for the table name"); + .expect("request_items hashmap must have a value for the table name"); // push unprocessed requests back to the request buffer self.write_requests.extend(unprocessed_requests); } diff --git a/raiden-derive/src/rusoto/ops/batch_delete.rs b/raiden-derive/src/rusoto/ops/batch_delete.rs index f1b0fb48..6f8d49d5 100644 --- a/raiden-derive/src/rusoto/ops/batch_delete.rs +++ b/raiden-derive/src/rusoto/ops/batch_delete.rs @@ -162,7 +162,7 @@ pub(crate) fn expand_batch_delete( let unprocessed_requests = unprocessed_items .remove(&self.table_name) - .expect("reqeust_items hashmap must have a value for the table name"); + .expect("request_items hashmap must have a value for the table name"); // push unprocessed requests back to the request buffer self.write_requests.extend(unprocessed_requests); } diff --git a/raiden/src/aws_sdk/errors.rs b/raiden/src/aws_sdk/errors.rs index b7082802..de22654a 100644 --- a/raiden/src/aws_sdk/errors.rs +++ b/raiden/src/aws_sdk/errors.rs @@ -82,51 +82,34 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: SdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { SdkError::ServiceError(err) => match err.err() { - GetItemError::InternalServerError(err) => { - RaidenError::InternalServerError(err.to_string()) + DeleteItemError::ConditionalCheckFailedException(err) => { + RaidenError::ConditionalCheckFailed(err.to_string()) } - GetItemError::InvalidEndpointException(err) => { + DeleteItemError::InternalServerError(err) => { RaidenError::InternalServerError(err.to_string()) } - GetItemError::ProvisionedThroughputExceededException(err) => { - RaidenError::ProvisionedThroughputExceeded(err.to_string()) - } - GetItemError::RequestLimitExceeded(err) => { - RaidenError::RequestLimitExceeded(err.to_string()) - } - GetItemError::ResourceNotFoundException(err) => { - RaidenError::ResourceNotFound(err.to_string()) - } - _ => into_raiden_error(error), - }, - _ => into_raiden_error(error), - } - } -} - -impl From> for RaidenError { - fn from(error: SdkError) -> Self { - match &error { - SdkError::ServiceError(err) => match err.err() { - QueryError::InternalServerError(err) => { + DeleteItemError::InvalidEndpointException(err) => { RaidenError::InternalServerError(err.to_string()) } - QueryError::InvalidEndpointException(err) => { - RaidenError::InternalServerError(err.to_string()) + DeleteItemError::ItemCollectionSizeLimitExceededException(err) => { + RaidenError::ItemCollectionSizeLimitExceeded(err.to_string()) } - QueryError::ProvisionedThroughputExceededException(err) => { + DeleteItemError::ProvisionedThroughputExceededException(err) => { RaidenError::ProvisionedThroughputExceeded(err.to_string()) } - QueryError::RequestLimitExceeded(err) => { + DeleteItemError::RequestLimitExceeded(err) => { RaidenError::RequestLimitExceeded(err.to_string()) } - QueryError::ResourceNotFoundException(err) => { + DeleteItemError::ResourceNotFoundException(err) => { RaidenError::ResourceNotFound(err.to_string()) } + DeleteItemError::TransactionConflictException(err) => { + RaidenError::TransactionConflict(err.to_string()) + } _ => into_raiden_error(error), }, _ => into_raiden_error(error), @@ -134,23 +117,23 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: SdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { SdkError::ServiceError(err) => match err.err() { - ScanError::InternalServerError(err) => { + GetItemError::InternalServerError(err) => { RaidenError::InternalServerError(err.to_string()) } - ScanError::InvalidEndpointException(err) => { + GetItemError::InvalidEndpointException(err) => { RaidenError::InternalServerError(err.to_string()) } - ScanError::ProvisionedThroughputExceededException(err) => { + GetItemError::ProvisionedThroughputExceededException(err) => { RaidenError::ProvisionedThroughputExceeded(err.to_string()) } - ScanError::RequestLimitExceeded(err) => { + GetItemError::RequestLimitExceeded(err) => { RaidenError::RequestLimitExceeded(err.to_string()) } - ScanError::ResourceNotFoundException(err) => { + GetItemError::ResourceNotFoundException(err) => { RaidenError::ResourceNotFound(err.to_string()) } _ => into_raiden_error(error), @@ -195,34 +178,27 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: SdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { + dbg!(&error); + match &error { SdkError::ServiceError(err) => match err.err() { - UpdateItemError::ConditionalCheckFailedException(err) => { - RaidenError::ConditionalCheckFailed(err.to_string()) - } - UpdateItemError::InternalServerError(err) => { + QueryError::InternalServerError(err) => { RaidenError::InternalServerError(err.to_string()) } - UpdateItemError::InvalidEndpointException(err) => { + QueryError::InvalidEndpointException(err) => { RaidenError::InternalServerError(err.to_string()) } - UpdateItemError::ItemCollectionSizeLimitExceededException(err) => { - RaidenError::ItemCollectionSizeLimitExceeded(err.to_string()) - } - UpdateItemError::ProvisionedThroughputExceededException(err) => { + QueryError::ProvisionedThroughputExceededException(err) => { RaidenError::ProvisionedThroughputExceeded(err.to_string()) } - UpdateItemError::RequestLimitExceeded(err) => { + QueryError::RequestLimitExceeded(err) => { RaidenError::RequestLimitExceeded(err.to_string()) } - UpdateItemError::ResourceNotFoundException(err) => { + QueryError::ResourceNotFoundException(err) => { RaidenError::ResourceNotFound(err.to_string()) } - UpdateItemError::TransactionConflictException(err) => { - RaidenError::TransactionConflict(err.to_string()) - } _ => into_raiden_error(error), }, _ => into_raiden_error(error), @@ -230,34 +206,25 @@ impl From> for RaidenError { } } -impl From> for RaidenError { - fn from(error: SdkError) -> Self { +impl From> for RaidenError { + fn from(error: SdkError) -> Self { match &error { SdkError::ServiceError(err) => match err.err() { - DeleteItemError::ConditionalCheckFailedException(err) => { - RaidenError::ConditionalCheckFailed(err.to_string()) - } - DeleteItemError::InternalServerError(err) => { + ScanError::InternalServerError(err) => { RaidenError::InternalServerError(err.to_string()) } - DeleteItemError::InvalidEndpointException(err) => { + ScanError::InvalidEndpointException(err) => { RaidenError::InternalServerError(err.to_string()) } - DeleteItemError::ItemCollectionSizeLimitExceededException(err) => { - RaidenError::ItemCollectionSizeLimitExceeded(err.to_string()) - } - DeleteItemError::ProvisionedThroughputExceededException(err) => { + ScanError::ProvisionedThroughputExceededException(err) => { RaidenError::ProvisionedThroughputExceeded(err.to_string()) } - DeleteItemError::RequestLimitExceeded(err) => { + ScanError::RequestLimitExceeded(err) => { RaidenError::RequestLimitExceeded(err.to_string()) } - DeleteItemError::ResourceNotFoundException(err) => { + ScanError::ResourceNotFoundException(err) => { RaidenError::ResourceNotFound(err.to_string()) } - DeleteItemError::TransactionConflictException(err) => { - RaidenError::TransactionConflict(err.to_string()) - } _ => into_raiden_error(error), }, _ => into_raiden_error(error), @@ -310,3 +277,38 @@ impl From> for RaidenError { } } } + +impl From> for RaidenError { + fn from(error: SdkError) -> Self { + match &error { + SdkError::ServiceError(err) => match err.err() { + UpdateItemError::ConditionalCheckFailedException(err) => { + RaidenError::ConditionalCheckFailed(err.to_string()) + } + UpdateItemError::InternalServerError(err) => { + RaidenError::InternalServerError(err.to_string()) + } + UpdateItemError::InvalidEndpointException(err) => { + RaidenError::InternalServerError(err.to_string()) + } + UpdateItemError::ItemCollectionSizeLimitExceededException(err) => { + RaidenError::ItemCollectionSizeLimitExceeded(err.to_string()) + } + UpdateItemError::ProvisionedThroughputExceededException(err) => { + RaidenError::ProvisionedThroughputExceeded(err.to_string()) + } + UpdateItemError::RequestLimitExceeded(err) => { + RaidenError::RequestLimitExceeded(err.to_string()) + } + UpdateItemError::ResourceNotFoundException(err) => { + RaidenError::ResourceNotFound(err.to_string()) + } + UpdateItemError::TransactionConflictException(err) => { + RaidenError::TransactionConflict(err.to_string()) + } + _ => into_raiden_error(error), + }, + _ => into_raiden_error(error), + } + } +} diff --git a/raiden/src/errors/transaction.rs b/raiden/src/errors/transaction.rs index 35c2226b..37491b31 100644 --- a/raiden/src/errors/transaction.rs +++ b/raiden/src/errors/transaction.rs @@ -9,7 +9,7 @@ pub struct RaidenTransactionCancellationReasons( ); impl RaidenTransactionCancellationReasons { - // If `message` is unexcepted format, [RaidenTransactionCancellationReason::Unknown] is returned instead of Err(_) + // If `message` is unexpected format, [RaidenTransactionCancellationReason::Unknown] is returned instead of Err(_) // TODO: Fix it later. #[allow(clippy::should_implement_trait)] pub fn from_str(message: &str) -> Self { @@ -107,7 +107,7 @@ impl RaidenTransactionCancellationReason { "ProvisionedThroughputExceeded" => Self::ProvisionedThroughputExceeded, "ThrottlingError" => Self::ThrottlingError, "ValidationError" => Self::ValidationError, - // If `reason` is unexcepted, Self::Unknown is returned instead of Err(_) + // If `reason` is unexpected, Self::Unknown is returned instead of Err(_) _ => Self::Unknown, } } From 1374e99c461e4c5e350fb48d2b2febc9cff9fa23 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Sat, 1 Jun 2024 03:00:12 +0900 Subject: [PATCH 14/22] chore: add handling ValidationException. --- raiden/src/aws_sdk/errors.rs | 39 ++++++++++++++++++++++++++++++------ raiden/src/errors/mod.rs | 11 +++++----- 2 files changed, 38 insertions(+), 12 deletions(-) diff --git a/raiden/src/aws_sdk/errors.rs b/raiden/src/aws_sdk/errors.rs index de22654a..6cf483a9 100644 --- a/raiden/src/aws_sdk/errors.rs +++ b/raiden/src/aws_sdk/errors.rs @@ -1,6 +1,6 @@ use crate::{ aws_sdk::{ - error::SdkError, + error::{ProvideErrorMetadata, SdkError}, operation::{ batch_get_item::BatchGetItemError, batch_write_item::BatchWriteItemError, delete_item::DeleteItemError, get_item::GetItemError, put_item::PutItemError, @@ -11,15 +11,44 @@ use crate::{ RaidenError, RaidenTransactionCancellationReasons, }; -fn into_raiden_error(error: SdkError) -> RaidenError { +fn into_raiden_error(error: SdkError) -> RaidenError +where + E: std::fmt::Debug + ProvideErrorMetadata, +{ + let (code, message) = ( + error.meta().code().map(|v| v.to_owned()), + error.meta().message().map(|v| v.to_owned()), + ); + match error { SdkError::ConstructionFailure(err) => RaidenError::Construction(err), SdkError::TimeoutError(err) => RaidenError::Timeout(err), SdkError::DispatchFailure(err) => RaidenError::HttpDispatch(err), SdkError::ResponseError(err) => RaidenError::Unknown(err.into_raw()), + // This pattern is only for handling ServiceError::Unhandled. + // Other patterns should be handled in each ServiceError. SdkError::ServiceError(err) => { - // SdkError::ServiceError should be handled ( except for E::Unhandled(_)). - RaidenError::Unknown(err.into_raw()) + let Some(code) = code else { + return RaidenError::Unknown(err.into_raw()); + }; + + // https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Programming.Errors.html + match code.as_str() { + "ValidationException" => RaidenError::Validation(if let Some(message) = message { + message + } else { + format!("{err:?}") + }), + "AccessDeniedException" + | "IncompleteSignatureException" + | "LimitExceededException" + | "MissingAuthenticationTokenException" + | "ResourceInUseException" + | "ThrottlingException" + | "UnrecognizedClientException" + | "ServiceUnavailable" + | _ => RaidenError::Unknown(err.into_raw()), + } } _ => unreachable!( "Unexpected variant of SdkError detected. Raiden must be handle this variant." @@ -180,8 +209,6 @@ impl From> for RaidenError { impl From> for RaidenError { fn from(error: SdkError) -> Self { - dbg!(&error); - match &error { SdkError::ServiceError(err) => match err.err() { QueryError::InternalServerError(err) => { diff --git a/raiden/src/errors/mod.rs b/raiden/src/errors/mod.rs index 819287cf..cebb0e02 100644 --- a/raiden/src/errors/mod.rs +++ b/raiden/src/errors/mod.rs @@ -28,8 +28,10 @@ pub enum RaidenError { TransactionConflict(String), #[error("`{0}`")] TransactionInProgress(String), + #[error("`{0}`")] + Validation(String), // - // Next errors returns only using rusoto. + // Following errors are returned only using rusoto. // #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] #[error("blocking error")] @@ -51,11 +53,8 @@ pub enum RaidenError { #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] #[error("unknown error")] Unknown(crate::request::BufferedHttpResponse), - #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] - #[error("`{0}`")] - Validation(String), // - // Next errors returns only using aws-sdk. + // Following errors are returned only using aws-sdk. // #[cfg(feature = "aws-sdk")] #[error("`{0:?}`")] @@ -76,7 +75,7 @@ pub enum RaidenError { #[error("unknown error")] Unknown(aws_smithy_runtime_api::client::orchestrator::HttpResponse), // - // Next errors are not used. + // Following errors are never returned. // #[deprecated = "unused. this variant never returns."] #[error("attribute {attr_name:?} value not found")] From 45f1d3a4b1ae05b3b88358077289af6c896c4781 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Fri, 7 Jun 2024 13:50:43 +0900 Subject: [PATCH 15/22] chore: update dependencies and README --- README.md | 172 +++++++++++++++++++++++++++++++----- raiden/Cargo.toml | 2 +- raiden/examples/last_key.rs | 46 +++++++++- rust-toolchain | 2 +- 4 files changed, 198 insertions(+), 24 deletions(-) diff --git a/README.md b/README.md index 55b60f95..7e492382 100644 --- a/README.md +++ b/README.md @@ -10,12 +10,53 @@ ## Examples -### get_item example +You can see more examples [here](https://github.com/raiden-rs/raiden-dynamo/tree/master/raiden/examples) + +### Generating client + +`raiden` uses `aws-sdk-dynamodb` or `rusoto_dynamodb` as internal client. + +#### With aws-sdk-dynamodb + +```rust +use raiden::*; -``` rust #[derive(Raiden)] #[raiden(table_name = "user")] -pub struct User { +struct User { + #[raiden(partition_key)] + id: String, + name: String, +} + +#[tokio::main] +async fn main() { + // Simply, specify the region. + let client = User::client(config::Region::from_static("us-east-1")); + + // You can also specify aws-sdk-dynamodb client. + let client = { + let sdk_config = aws_config::defaults(aws_config::BehaviorVersion::latest()) + .region(raiden::config::Region::from_static("us-east-1")) + .load() + .await; + let sdk_client = raiden::Client::new(&sdk_config); + + User::client_with(sdk_client) + }; + + // Run operations... +} +``` + +#### With rusoto_dynamodb + +```rust +use raiden::*; + +#[derive(Raiden)] +#[raiden(table_name = "user")] +struct User { #[raiden(partition_key)] id: String, name: String, @@ -23,14 +64,107 @@ pub struct User { #[tokio::main] async fn main() { + // Simply, specify the region. let client = User::client(Region::UsEast1); + + // You can also specify rusoto_core client. + let client = User::client_with(Client::shared(), Region::UsEast1); + + // Run operations... +} +``` + +#### Set prefix/suffix to the table name + +```rust +use raiden::*; + +#[derive(Raiden)] +#[raiden(table_name = "user")] +struct User { + #[raiden(partition_key)] + id: String, + name: String, +} + +#[tokio::main] +async fn main() { + let client = User::client(config::Region::from_static("us-east-1")) + .table_prefix("prefix") + .table_suffix("suffix"); + + // Print `prefix-user-suffix` + println!("{}", client.table_name()); +} +``` + +#### Configure retry strategy + +NOTE: Default retry strategy differs between aws-sdk and rusoto( or rusoto_rustls) + +- `aws-sdk` ... Not retry in raiden by default. Because you can configure retry strategy using `aws_config`. Or you can configure your own strategy like next example. +- `rusoto` or `rusoto_rustls` ... Enabled retrying in raiden by default. See detail [here](https://github.com/mythrnr/raiden-dynamo/blob/master/raiden/src/retry/mod.rs). + +```rust +use raiden::*; + +#[derive(Raiden)] +#[raiden(table_name = "user")] +struct User { + #[raiden(partition_key)] + id: String, + name: String, +} + +// Force retry 3 times. +struct MyRetryStrategy; + +impl RetryStrategy for MyRetryStrategy { + fn should_retry(&self, _error: &RaidenError) -> bool { + true + } + + fn policy(&self) -> Policy { + Policy::Limit(3) + } +} + +#[tokio::main] +async fn main() { + let client = User::client(config::Region::from_static("us-east-1")) + .with_retries(Box::new(MyRetryStrategy)); + + // Run operations... +} +``` + +### Running operations + +#### get_item + +```rust +use raiden::*; + +#[derive(Raiden)] +#[raiden(table_name = "user")] +struct User { + #[raiden(partition_key)] + id: String, + name: String, +} + +#[tokio::main] +async fn main() { + let client = /* generate client */; let _res = client.get("user_primary_key").run().await; } ``` -### put_item example +#### put_item + +```rust +use raiden::*; -``` rust #[derive(Raiden)] #[raiden(table_name = "user")] pub struct User { @@ -41,18 +175,20 @@ pub struct User { #[tokio::main] async fn main() { - let client = User::client(Region::UsEast1); + let client = /* generate client */; let input = User::put_item_builder() .id("foo".to_owned()) .name("bokuweb".to_owned()) .build(); - let res = client.put(&input).run().await; + let _res = client.put(&input).run().await; } ``` -### batch_get_item example +#### batch_get_item + +```rust +use raiden::*; -``` rust #[derive(Raiden, Debug, PartialEq)] pub struct User { #[raiden(partition_key)] @@ -63,7 +199,7 @@ pub struct User { #[tokio::main] async fn main() { - let client = User::client(Region::UsEast1); + let client = /* generate client */; let keys: Vec<(&str, usize)> = vec![("Alice", 1992), ("Bob", 1976), ("Charlie", 2002)]; let res = client.batch_get(keys).run().await; } @@ -89,20 +225,12 @@ tracing = "0.1" ### Requirements -- Rust +- Rust (1.76.0+) - Deno (1.13.2+) - GNU Make - Docker Engine -### Setup - -``` -make dynamo -``` - -This starts up DynamoDB on Docker container, and then arranges test fixtures. - -### Test +### Run tests ``` make test @@ -110,9 +238,11 @@ make test NOTE: Don't recommend to use `cargo test` because our test suite doesn't support running tests in parallel. Use `cargo test -- --test-threads=1` instead of it. -### Example +### Run examples ``` +make dynamo + AWS_ACCESS_KEY_ID=dummy AWS_SECRET_ACCESS_KEY=dummy cargo run --example EXAMPLE_NAME ``` diff --git a/raiden/Cargo.toml b/raiden/Cargo.toml index 7335808d..723f9c9b 100644 --- a/raiden/Cargo.toml +++ b/raiden/Cargo.toml @@ -32,7 +32,7 @@ uuid = { version = "^1.8", features = ["v4"] } [dev-dependencies] aws-credential-types = { version = "^1" } aws-smithy-runtime = { version = "^1" } -hyper-rustls = { version = "0.25", features = ["http2"] } +hyper-rustls = { version = "=0.25.0", features = ["http2"] } pretty_assertions = "1.4.0" raiden = { path = "./", features = ["tracing"], default_features = false } time = "0.3.36" diff --git a/raiden/examples/last_key.rs b/raiden/examples/last_key.rs index ed58a986..0d340d28 100644 --- a/raiden/examples/last_key.rs +++ b/raiden/examples/last_key.rs @@ -10,7 +10,51 @@ pub struct Test { #[raiden(partition_key)] pub id: String, pub ref_id: String, - pub long_text: String, + pub long_text: LongText, +} + +#[derive(Clone, PartialEq)] +pub struct LongText(String); + +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +impl IntoAttribute for LongText { + fn into_attr(self) -> AttributeValue { + AttributeValue { + s: Some(self.0), + ..AttributeValue::default() + } + } +} + +#[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] +impl FromAttribute for LongText { + fn from_attr(value: Option) -> Result { + Ok(Self(value.unwrap().s.unwrap())) + } +} + +#[cfg(feature = "aws-sdk")] +impl raiden::IntoAttribute for LongText { + fn into_attr(self) -> raiden::AttributeValue { + raiden::AttributeValue::S(self.0) + } +} + +#[cfg(feature = "aws-sdk")] +impl raiden::FromAttribute for LongText { + fn from_attr(value: Option) -> Result { + if let Some(raiden::AttributeValue::S(v)) = value { + Ok(Self(v)) + } else { + unimplemented!(); + } + } +} + +impl std::fmt::Debug for LongText { + fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + write!(f, "Long long text") + } } #[cfg(any(feature = "rusoto", feature = "rusoto_rustls"))] diff --git a/rust-toolchain b/rust-toolchain index 7c7053aa..32a6ce3c 100644 --- a/rust-toolchain +++ b/rust-toolchain @@ -1 +1 @@ -1.75.0 +1.76.0 From 22ae7b7579892d3120abd9917354548f407ad750 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Fri, 7 Jun 2024 14:00:48 +0900 Subject: [PATCH 16/22] chore: raiden needs at least Rust 1.76.0 --- .github/workflows/ci.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 4164cac8..99da9981 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -16,7 +16,7 @@ jobs: - uses: actions-rs/toolchain@v1 with: profile: minimal - toolchain: 1.68.0 + toolchain: 1.76.0 override: true - name: Install deps run: sudo apt-get install libssl-dev From c9d32ca1e4a6b9c71a40fbe636940f0cb83e5aca Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Fri, 7 Jun 2024 17:43:24 +0900 Subject: [PATCH 17/22] fix: README --- README.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index 7e492382..040b8585 100644 --- a/README.md +++ b/README.md @@ -16,7 +16,7 @@ You can see more examples [here](https://github.com/raiden-rs/raiden-dynamo/tree `raiden` uses `aws-sdk-dynamodb` or `rusoto_dynamodb` as internal client. -#### With aws-sdk-dynamodb +#### With aws-sdk-dynamodb (`aws-sdk` is enabled) ```rust use raiden::*; @@ -49,7 +49,7 @@ async fn main() { } ``` -#### With rusoto_dynamodb +#### With rusoto_dynamodb ( `rusoto` or `rusoto_rustls` or `rustls` is enabled) ```rust use raiden::*; @@ -90,8 +90,8 @@ struct User { #[tokio::main] async fn main() { let client = User::client(config::Region::from_static("us-east-1")) - .table_prefix("prefix") - .table_suffix("suffix"); + .table_prefix("prefix-") + .table_suffix("-suffix"); // Print `prefix-user-suffix` println!("{}", client.table_name()); @@ -100,7 +100,7 @@ async fn main() { #### Configure retry strategy -NOTE: Default retry strategy differs between aws-sdk and rusoto( or rusoto_rustls) +NOTE: Default retry strategy differs between `aws-sdk` and `rusoto` ( or `rusoto_rustls` ) - `aws-sdk` ... Not retry in raiden by default. Because you can configure retry strategy using `aws_config`. Or you can configure your own strategy like next example. - `rusoto` or `rusoto_rustls` ... Enabled retrying in raiden by default. See detail [here](https://github.com/mythrnr/raiden-dynamo/blob/master/raiden/src/retry/mod.rs). From 33ad8d5d75d99ab2a7e9a4e85ab52ee3ed788fe5 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Thu, 13 Jun 2024 11:48:01 +0900 Subject: [PATCH 18/22] chore: add logging for debugging. --- setup/dynamo_util.ts | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/setup/dynamo_util.ts b/setup/dynamo_util.ts index 6141c754..c7d4070b 100644 --- a/setup/dynamo_util.ts +++ b/setup/dynamo_util.ts @@ -18,7 +18,10 @@ export async function createTableAndPutItems( client: DynamoDBClient, { table, items }: CreateAndPut, ) { + console.group() + await createTable(client, table); + console.log("table created"); // NOTE: Running `put` operations concurrently with `Promise.all` would lead to running out of write buffer. for (const item of items) { @@ -27,6 +30,9 @@ export async function createTableAndPutItems( Item: item, }); } + + console.log("items are put"); + console.groupEnd(); } export function getCredFromEnv(): { From ef05e44f6dcc01223760692e44f0ad60976816ce Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Thu, 13 Jun 2024 11:49:07 +0900 Subject: [PATCH 19/22] fix: code style. --- setup/dynamo_util.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/setup/dynamo_util.ts b/setup/dynamo_util.ts index c7d4070b..49ce3d36 100644 --- a/setup/dynamo_util.ts +++ b/setup/dynamo_util.ts @@ -18,7 +18,7 @@ export async function createTableAndPutItems( client: DynamoDBClient, { table, items }: CreateAndPut, ) { - console.group() + console.group(); await createTable(client, table); console.log("table created"); From e15e895ff6e843135710ccc216dffaa037b5ac2c Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Thu, 13 Jun 2024 11:54:42 +0900 Subject: [PATCH 20/22] fix: remove image on down. --- makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/makefile b/makefile index 388a4fb4..56e0b6f9 100644 --- a/makefile +++ b/makefile @@ -3,7 +3,7 @@ export AWS_SECRET_ACCESS_KEY := dummy .PHONY: dynamo dynamo: - docker compose down --volumes + docker compose down --rmi all --volumes docker compose up -d --wait dynamodb docker compose up aws-cli deno run --allow-net=localhost:8000 --allow-env --no-check ./setup/setup.ts From 5fdd697c6ca1bd4015526ba1de5ad27c84a6a1c6 Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Thu, 13 Jun 2024 11:59:07 +0900 Subject: [PATCH 21/22] fix: remove needless setup dynamodb action. --- .github/workflows/ci.yml | 5 ----- makefile | 2 +- 2 files changed, 1 insertion(+), 6 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 99da9981..1ea3b08a 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -47,10 +47,5 @@ jobs: with: path: target key: ${{ runner.os }}-cargo-build-target-${{ hashFiles('**/Cargo.lock') }} - - name: Setup DynamoDB Local - uses: rrainn/dynamodb-action@v2.0.0 - with: - port: 8000 - cors: "*" - name: test run: make test diff --git a/makefile b/makefile index 56e0b6f9..388a4fb4 100644 --- a/makefile +++ b/makefile @@ -3,7 +3,7 @@ export AWS_SECRET_ACCESS_KEY := dummy .PHONY: dynamo dynamo: - docker compose down --rmi all --volumes + docker compose down --volumes docker compose up -d --wait dynamodb docker compose up aws-cli deno run --allow-net=localhost:8000 --allow-env --no-check ./setup/setup.ts From 96ab27befac235f59ff2b88f2e544ab6652dd60f Mon Sep 17 00:00:00 2001 From: mythrnr <32730704+mythrnr@users.noreply.github.com> Date: Fri, 21 Jun 2024 19:25:45 +0900 Subject: [PATCH 22/22] fix: enable to use attribute use_default for generic type. --- raiden-derive/src/aws_sdk/ops/shared.rs | 4 ++-- raiden-derive/src/rusoto/ops/shared.rs | 4 ++-- raiden/tests/all/get.rs | 3 +++ 3 files changed, 7 insertions(+), 4 deletions(-) diff --git a/raiden-derive/src/aws_sdk/ops/shared.rs b/raiden-derive/src/aws_sdk/ops/shared.rs index 4a7cb380..cd7f0459 100644 --- a/raiden-derive/src/aws_sdk/ops/shared.rs +++ b/raiden-derive/src/aws_sdk/ops/shared.rs @@ -41,12 +41,12 @@ pub(crate) fn expand_attr_to_item( #ident: { #item if item.is_none() { - #ty::default() + Default::default() } else { let item = item.unwrap(); // If null is true, use default value. if item.is_null() { - #ty::default() + Default::default() } else { let converted = ::raiden::FromAttribute::from_attr(Some(item)); if converted.is_err() { diff --git a/raiden-derive/src/rusoto/ops/shared.rs b/raiden-derive/src/rusoto/ops/shared.rs index c355ad65..48038689 100644 --- a/raiden-derive/src/rusoto/ops/shared.rs +++ b/raiden-derive/src/rusoto/ops/shared.rs @@ -42,12 +42,12 @@ pub(crate) fn expand_attr_to_item( #ident: { #item if item.is_none() { - #ty::default() + Default::default() } else { let item = item.unwrap(); // If null is true, use default value. if let Some(true) = item.null { - #ty::default() + Default::default() } else { let converted = ::raiden::FromAttribute::from_attr(Some(item)); if converted.is_err() { diff --git a/raiden/tests/all/get.rs b/raiden/tests/all/get.rs index db664eea..54b2210c 100644 --- a/raiden/tests/all/get.rs +++ b/raiden/tests/all/get.rs @@ -324,6 +324,8 @@ mod tests { id: String, #[raiden(use_default)] flag: bool, + #[raiden(use_default)] + type_param: std::collections::BTreeSet, } #[tokio::test] @@ -337,6 +339,7 @@ mod tests { item: UseDefaultForNull { id: "id0".to_owned(), flag: false, + type_param: Default::default(), }, consumed_capacity: None, }