From 7f4dad62a425e161de20d4391b69b3020629f35f Mon Sep 17 00:00:00 2001 From: David Oguns <38018552+DavidOgunsAWS@users.noreply.github.com> Date: Fri, 19 Aug 2022 13:29:05 -0700 Subject: [PATCH] Update Smithy to 1.23.1 to support IDL 2 (#1623) --- CHANGELOG.next.toml | 31 +++++++ .../ServerHttpSensitivityGenerator.kt | 13 ++- .../protocol/ServerProtocolTestGenerator.kt | 3 - .../ServerHttpSensitivityGeneratorTest.kt | 87 +++++-------------- .../smithy/protocols/EventStreamTestTools.kt | 2 +- codegen-test/model/rest-xml-extras.smithy | 16 ++-- .../smithy/protocols/InlineFunctionNamer.kt | 4 +- .../generators/StructureGeneratorTest.kt | 7 +- .../codegen/generators/UnionGeneratorTest.kt | 2 +- .../http/RequestBindingGeneratorTest.kt | 6 +- gradle.properties | 2 +- 11 files changed, 83 insertions(+), 90 deletions(-) diff --git a/CHANGELOG.next.toml b/CHANGELOG.next.toml index ac2bd6bacc..a6b2160e1e 100644 --- a/CHANGELOG.next.toml +++ b/CHANGELOG.next.toml @@ -1,4 +1,5 @@ # Example changelog entries +# # [[aws-sdk-rust]] # message = "Fix typos in module documentation for generated crates" # references = ["smithy-rs#920"] @@ -47,6 +48,36 @@ references = ["smithy-rs#1598"] meta = { "breaking" = true, "tada" = true, "bug" = false, "target" = "client" } author = "Velfi" +[[smithy-rs]] +message = "Update Smithy dependency to 1.23.1. Models using version 2.0 of the IDL are now supported." +references = ["smithy-rs#1623"] +meta = { "breaking" = false, "tada" = true, "bug" = false } +author = "ogudavid" + +[[smithy-rs]] +message = "Fix detecting sensitive members through their target shape having the @sensitive trait applied." +references = ["smithy-rs#1623"] +meta = { "breaking" = false, "tada" = false, "bug" = true } +author = "ogudavid" + +[[smithy-rs]] +message = "Remove @sensitive trait tests which applied trait to member. The ability to mark members with @sensitive was removed in Smithy 1.22." +references = ["smithy-rs#1623"] +meta = { "breaking" = true, "tada" = false, "bug" = false } +author = "ogudavid" + +[[smithy-rs]] +message = "Fix SetShape matching needing to occur before ListShape since it is now a subclass. Sets were deprecated in Smithy 1.22." +references = ["smithy-rs#1623"] +meta = { "breaking" = false, "tada" = false, "bug" = false } +author = "ogudavid" + +[[smithy-rs]] +message = "Fix Union shape test data having an invalid empty union. Break fixed from Smithy 1.21 to Smithy 1.22." +references = ["smithy-rs#1623"] +meta = { "breaking" = false, "tada" = false, "bug" = false } +author = "ogudavid" + [[smithy-rs]] message = "Add codegen version to generated package metadata" references = ["smithy-rs#1612"] diff --git a/codegen-server/src/main/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/ServerHttpSensitivityGenerator.kt b/codegen-server/src/main/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/ServerHttpSensitivityGenerator.kt index 3c3c743e74..b2e3eb0faf 100644 --- a/codegen-server/src/main/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/ServerHttpSensitivityGenerator.kt +++ b/codegen-server/src/main/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/ServerHttpSensitivityGenerator.kt @@ -132,7 +132,7 @@ class ServerHttpSensitivityGenerator( it.direction == RelationshipDirection.DIRECTED } .filter { - it.hasTrait() + isDirectedRelationshipSensitive(it) }.mapNotNull { it as? MemberShape } @@ -294,7 +294,7 @@ class ServerHttpSensitivityGenerator( it.direction == RelationshipDirection.DIRECTED && !it.shape.hasTrait() } .filter { - it.hasTrait() + isDirectedRelationshipSensitive(it) } .flatMap { Walker(model) @@ -303,13 +303,20 @@ class ServerHttpSensitivityGenerator( it.direction == RelationshipDirection.DIRECTED } .filter { - it.hasTrait() + isDirectedRelationshipSensitive(it) }.mapNotNull { it as? MemberShape } } } + internal inline fun isDirectedRelationshipSensitive(partnerShape: Shape): Boolean { + return partnerShape.hasTrait() || ( + partnerShape.asMemberShape().isPresent() && + model.expectShape(partnerShape.asMemberShape().get().getTarget()).hasTrait() + ) + } + // Find member shapes with trait `T` contained in a shape enjoying `SensitiveTrait`. // [trait|sensitive] ~> [trait|T] internal inline fun findSensitiveBound(rootShape: Shape): List { diff --git a/codegen-server/src/main/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/protocol/ServerProtocolTestGenerator.kt b/codegen-server/src/main/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/protocol/ServerProtocolTestGenerator.kt index dee9f50ada..fff4b8d364 100644 --- a/codegen-server/src/main/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/protocol/ServerProtocolTestGenerator.kt +++ b/codegen-server/src/main/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/protocol/ServerProtocolTestGenerator.kt @@ -658,7 +658,6 @@ class ServerProtocolTestGenerator( FailingTest(RestJson, "RestJsonHttpWithEmptyStructurePayload", TestType.Request), FailingTest(RestJson, "RestJsonHttpResponseCodeDefaultsToModeledCode", TestType.Response), - FailingTest(RestJson, "RestJsonWithPayloadExpectsImpliedAccept", TestType.MalformedRequest), FailingTest(RestJson, "RestJsonBodyMalformedBlobInvalidBase64_case1", TestType.MalformedRequest), FailingTest(RestJson, "RestJsonBodyMalformedBlobInvalidBase64_case2", TestType.MalformedRequest), FailingTest(RestJson, "RestJsonWithBodyExpectsApplicationJsonContentType", TestType.MalformedRequest), @@ -673,8 +672,6 @@ class ServerProtocolTestGenerator( FailingTest(RestJson, "RestJsonBodyTimestampDefaultRejectsMalformedEpochSeconds_case5", TestType.MalformedRequest), FailingTest(RestJson, "RestJsonBodyTimestampDefaultRejectsMalformedEpochSeconds_case7", TestType.MalformedRequest), FailingTest(RestJson, "RestJsonBodyTimestampDefaultRejectsMalformedEpochSeconds_case9", TestType.MalformedRequest), - FailingTest(RestJson, "RestJsonPathTimestampDefaultRejectsDifferent8601Formats_case13", TestType.MalformedRequest), - FailingTest(RestJson, "RestJsonQueryTimestampDefaultRejectsDifferent8601Formats_case13", TestType.MalformedRequest), FailingTest(RestJson, "RestJsonMalformedUnionNoFieldsSet", TestType.MalformedRequest), FailingTest(RestJson, "RestJsonMalformedSetDuplicateBlobs", TestType.MalformedRequest), diff --git a/codegen-server/src/test/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/ServerHttpSensitivityGeneratorTest.kt b/codegen-server/src/test/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/ServerHttpSensitivityGeneratorTest.kt index 80dd267b12..74072d3b22 100644 --- a/codegen-server/src/test/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/ServerHttpSensitivityGeneratorTest.kt +++ b/codegen-server/src/test/kotlin/software/amazon/smithy/rust/codegen/server/smithy/generators/ServerHttpSensitivityGeneratorTest.kt @@ -65,36 +65,6 @@ class ServerHttpSensitivityGeneratorTest { assertEquals(members, listOf("code")) } - @Test - fun `find inner sensitive`() { - val model = """ - namespace test - - operation Secret { - input: Input, - } - - structure Input { - @required - @sensitive - @httpHeader("header-a") - headerA: String, - - @required - @httpHeader("header-b") - headerB: String - } - """.asSmithyModel() - - val operation = model.operationShapes.toList()[0] - val generator = ServerHttpSensitivityGenerator(model, operation, TestRuntimeConfig) - - val inputShape = operation.inputShape(model) - val members: List = generator.findSensitiveBound(inputShape).map(MemberShape::getMemberName) - - assertEquals(members, listOf("headerA")) - } - @Test fun `find nested sensitive`() { val model = """ @@ -142,18 +112,9 @@ class ServerHttpSensitivityGeneratorTest { @httpQuery("query_a") queryA: String, - @sensitive - nestedA: NestedA, - nestedB: NestedB } - structure NestedA { - @required - @httpQuery("query_b") - queryB: String - } - @sensitive structure NestedB { @required @@ -167,7 +128,7 @@ class ServerHttpSensitivityGeneratorTest { val input = generator.input()!! val querySensitivity = generator.findQuerySensitivity(input) assertEquals(querySensitivity.allKeysSensitive, false) - assertEquals((querySensitivity as ServerHttpSensitivityGenerator.QuerySensitivity.NotSensitiveMapValue).queryKeys, listOf("query_c", "query_b")) + assertEquals((querySensitivity as ServerHttpSensitivityGenerator.QuerySensitivity.NotSensitiveMapValue).queryKeys, listOf("query_c")) val testProject = TestWorkspace.testProject(serverTestSymbolProvider(model)) testProject.lib { writer -> @@ -178,7 +139,6 @@ class ServerHttpSensitivityGeneratorTest { rustTemplate( """ assert_eq!(closure("query_a"), #{SmithyHttpServer}::logging::sensitivity::uri::QueryMarker { key: false, value: false }); - assert_eq!(closure("query_b"), #{SmithyHttpServer}::logging::sensitivity::uri::QueryMarker { key: false, value: true }); assert_eq!(closure("query_c"), #{SmithyHttpServer}::logging::sensitivity::uri::QueryMarker { key: false, value: true }); """, *codegenScope, @@ -250,9 +210,11 @@ class ServerHttpSensitivityGeneratorTest { queryMap: QueryMap, } + @sensitive + string SensitiveKey + map QueryMap { - @sensitive - key: String, + key: SensitiveKey, value: String } @@ -297,10 +259,12 @@ class ServerHttpSensitivityGeneratorTest { queryMap: QueryMap, } + @sensitive + string SensitiveValue + map QueryMap { key: String, - @sensitive - value: String + value: SensitiveValue } """.asSmithyModel() @@ -343,18 +307,9 @@ class ServerHttpSensitivityGeneratorTest { @httpHeader("header-a") headerA: String, - @sensitive - nestedA: NestedA, - nestedB: NestedB } - structure NestedA { - @required - @httpHeader("header-b") - headerB: String - } - @sensitive structure NestedB { @required @@ -367,7 +322,7 @@ class ServerHttpSensitivityGeneratorTest { val inputShape = operation.inputShape(model) val headerData = generator.findHeaderSensitivity(inputShape) - assertEquals(headerData.headerKeys, listOf("header-c", "header-b")) + assertEquals(headerData.headerKeys, listOf("header-c")) assertEquals((headerData as ServerHttpSensitivityGenerator.HeaderSensitivity.NotSensitiveMapValue).prefixHeader, null) val testProject = TestWorkspace.testProject(serverTestSymbolProvider(model)) @@ -380,8 +335,6 @@ class ServerHttpSensitivityGeneratorTest { """ let name = #{Http}::header::HeaderName::from_static("header-a"); assert_eq!(closure(&name), #{SmithyHttpServer}::logging::sensitivity::headers::HeaderMarker { value: false, key_suffix: None }); - let name = #{Http}::header::HeaderName::from_static("header-b"); - assert_eq!(closure(&name), #{SmithyHttpServer}::logging::sensitivity::headers::HeaderMarker { value: true, key_suffix: None }); let name = #{Http}::header::HeaderName::from_static("header-c"); assert_eq!(closure(&name), #{SmithyHttpServer}::logging::sensitivity::headers::HeaderMarker { value: true, key_suffix: None }); """, @@ -458,9 +411,10 @@ class ServerHttpSensitivityGeneratorTest { prefix_map: PrefixMap, } + @sensitive + string SensitiveKey map PrefixMap { - @sensitive - key: String, + key: SensitiveKey, value: String } @@ -511,10 +465,12 @@ class ServerHttpSensitivityGeneratorTest { prefix_map: PrefixMap, } + @sensitive + string SensitiveValue + map PrefixMap { key: String, - @sensitive - value: String + value: SensitiveValue } """.asSmithyModel() @@ -560,15 +516,16 @@ class ServerHttpSensitivityGeneratorTest { input: Input, } + @sensitive + string SensitiveString + structure Input { @required - @sensitive @httpLabel - labelA: String, + labelA: SensitiveString, @required @httpLabel - @sensitive - labelB: String, + labelB: SensitiveString, } """.asSmithyModel() val operation = model.operationShapes.toList()[0] diff --git a/codegen-server/src/test/kotlin/software/amazon/smithy/rust/codegen/server/smithy/protocols/EventStreamTestTools.kt b/codegen-server/src/test/kotlin/software/amazon/smithy/rust/codegen/server/smithy/protocols/EventStreamTestTools.kt index af85f63416..23f8a744ee 100644 --- a/codegen-server/src/test/kotlin/software/amazon/smithy/rust/codegen/server/smithy/protocols/EventStreamTestTools.kt +++ b/codegen-server/src/test/kotlin/software/amazon/smithy/rust/codegen/server/smithy/protocols/EventStreamTestTools.kt @@ -98,7 +98,7 @@ private fun fillInBaseModel( MessageWithNoHeaderPayloadTraits: MessageWithNoHeaderPayloadTraits, SomeError: SomeError, } - structure TestStreamInputOutput { @required value: TestStream } + structure TestStreamInputOutput { @httpPayload @required value: TestStream } operation TestStreamOp { input: TestStreamInputOutput, output: TestStreamInputOutput, diff --git a/codegen-test/model/rest-xml-extras.smithy b/codegen-test/model/rest-xml-extras.smithy index 372aab8fe7..9c520676ed 100644 --- a/codegen-test/model/rest-xml-extras.smithy +++ b/codegen-test/model/rest-xml-extras.smithy @@ -1,4 +1,4 @@ -$version: "1.0" +$version: "2.0" namespace aws.protocoltests.restxml use aws.protocols#restXml @@ -43,13 +43,12 @@ structure CreateFooInput {} method: "POST", body: """ - 0 """, bodyMediaType: "application/xml", - params: {} + params: { } }, { - id: "RestXmlSerPrimitiveIntSet", + id: "RestXmlSerPrimitiveIntSetToDefault", protocol: "aws.protocols#restXml", documentation: "Primitive ints should not be serialized when they are unset", uri: "/primitive-document", @@ -57,8 +56,7 @@ structure CreateFooInput {} body: """ 1 - 0 - + """, bodyMediaType: "application/xml", params: { value: 1 } @@ -70,9 +68,9 @@ operation PrimitiveIntOpXml { } structure PrimitiveIntDocument { - value: PrimitiveInt, - @required - requiredValue: PrimitiveInt + value: PrimitiveInt + @default(0) + defaultedValue: PrimitiveInt } @enum([{"value": "enumvalue", "name": "V"}]) diff --git a/codegen/src/main/kotlin/software/amazon/smithy/rust/codegen/smithy/protocols/InlineFunctionNamer.kt b/codegen/src/main/kotlin/software/amazon/smithy/rust/codegen/smithy/protocols/InlineFunctionNamer.kt index 794b208832..3c13a11eb6 100644 --- a/codegen/src/main/kotlin/software/amazon/smithy/rust/codegen/smithy/protocols/InlineFunctionNamer.kt +++ b/codegen/src/main/kotlin/software/amazon/smithy/rust/codegen/smithy/protocols/InlineFunctionNamer.kt @@ -60,11 +60,11 @@ fun ShapeId.toRustIdentifier(): String { private fun RustSymbolProvider.shapeFunctionName(prefix: String, shape: Shape): String { val symbolNameSnakeCase = toSymbol(shape).fullName.replace("::", "_").toSnakeCase() return prefix + "_" + when (shape) { - is ListShape -> "list_${shape.id.toRustIdentifier()}" is MapShape -> "map_${shape.id.toRustIdentifier()}" is MemberShape -> "member_${shape.container.toRustIdentifier()}_${shape.memberName.toSnakeCase()}" is OperationShape -> "operation_$symbolNameSnakeCase" - is SetShape -> "set_${shape.id.toRustIdentifier()}" + is SetShape -> "set_${shape.id.toRustIdentifier()}" // set shape check MUST come before list, it is a subclass + is ListShape -> "list_${shape.id.toRustIdentifier()}" is StructureShape -> "structure_$symbolNameSnakeCase" is UnionShape -> "union_$symbolNameSnakeCase" is DocumentShape -> "document" diff --git a/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/StructureGeneratorTest.kt b/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/StructureGeneratorTest.kt index 6ef3d91bcd..0f09322b44 100644 --- a/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/StructureGeneratorTest.kt +++ b/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/StructureGeneratorTest.kt @@ -58,12 +58,13 @@ class StructureGeneratorTest { @sensitive string SecretKey + @sensitive + string Password + structure Credentials { username: String, - @sensitive - password: String, + password: Password, - // test that sensitive can be applied directly to a member or to the shape secretKey: SecretKey } diff --git a/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/UnionGeneratorTest.kt b/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/UnionGeneratorTest.kt index ce3708a000..33a6fc52ee 100644 --- a/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/UnionGeneratorTest.kt +++ b/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/UnionGeneratorTest.kt @@ -110,7 +110,7 @@ class UnionGeneratorTest { } @deprecated - union Bar {} + union Bar { x: Integer } """.asSmithyModel() val provider: SymbolProvider = testSymbolProvider(model) val writer = RustWriter.root() diff --git a/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/http/RequestBindingGeneratorTest.kt b/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/http/RequestBindingGeneratorTest.kt index 59f9e45ba5..6f7c834f61 100644 --- a/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/http/RequestBindingGeneratorTest.kt +++ b/codegen/src/test/kotlin/software/amazon/smithy/rust/codegen/generators/http/RequestBindingGeneratorTest.kt @@ -101,10 +101,12 @@ class RequestBindingGeneratorTest { @httpPrefixHeaders("X-Prefix-") prefix: StringMap, - @sensitive @httpHeader("stringHeader") - stringHeader: String + stringHeader: SensitiveStringHeader } + + @sensitive + string SensitiveStringHeader """.asSmithyModel() private val model = OperationNormalizer.transform(baseModel) private val symbolProvider = testSymbolProvider(model) diff --git a/gradle.properties b/gradle.properties index 6f198d403e..d1883f1dbb 100644 --- a/gradle.properties +++ b/gradle.properties @@ -15,7 +15,7 @@ kotlin.code.style=official # codegen smithyGradlePluginVersion=0.6.0 -smithyVersion=1.21.0 +smithyVersion=1.23.1 # kotlin kotlinVersion=1.6.21