From 1e9cd5f28af889eaafb13020eef3a7cc6ef78e5a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Olivier=20M=C3=A9lois?= Date: Tue, 21 May 2024 10:47:18 +0200 Subject: [PATCH 1/4] Avoid hardcoding the appending of `smithy4s` in SBT Also align on what ScalaPB does and avoid the `/scala` segment in the generated folders. --- .../sbt-test/codegen-plugin/aws-newtype-flatten/test | 4 ++-- .../src/sbt-test/codegen-plugin/aws-specs/test | 2 +- .../src/sbt-test/codegen-plugin/custom-settings/test | 10 +++++----- .../src/sbt-test/codegen-plugin/defaults/test | 4 ++-- .../src/sbt-test/codegen-plugin/dependencies-only/test | 2 +- .../src/sbt-test/codegen-plugin/extra-configs/test | 4 ++-- .../src/sbt-test/codegen-plugin/multimodule-aws/test | 4 ++-- .../sbt-test/codegen-plugin/multimodule-staged/test | 4 ++-- .../src/sbt-test/codegen-plugin/multimodule/test | 10 +++++----- .../src/sbt-test/codegen-plugin/scala3/test | 8 ++++---- .../src/sbt-test/codegen-plugin/smithy-build/test | 2 +- .../src/sbt-test/codegen-plugin/smithy-rules/test | 2 +- .../src/smithy4s/codegen/Smithy4sCodegenPlugin.scala | 4 ++-- 13 files changed, 30 insertions(+), 30 deletions(-) diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/aws-newtype-flatten/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/aws-newtype-flatten/test index c813c07d5..d853c9a95 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/aws-newtype-flatten/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/aws-newtype-flatten/test @@ -2,7 +2,7 @@ > run # This new type was not flattened because it has range constraints -$ exists smithy_output/smithy4s/com/amazonaws/dynamodb/ListTablesInputLimit.scala +$ exists smithy_output/com/amazonaws/dynamodb/ListTablesInputLimit.scala # Flattened and removed by the projection transformer --$ exists smithy_output/smithy4s/com/amazonaws/dynamodb/Long.scala +-$ exists smithy_output/com/amazonaws/dynamodb/Long.scala diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/aws-specs/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/aws-specs/test index e58e612c4..9c4c518d2 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/aws-specs/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/aws-specs/test @@ -1,3 +1,3 @@ # check if smithy4sCodegen works > smithy4sCodegen -$ exists target/scala-2.13/src_managed/main/scala/smithy4s/com/amazonaws/dynamodb/AttributeValue.scala +$ exists target/scala-2.13/src_managed/main/smithy4s/com/amazonaws/dynamodb/AttributeValue.scala diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/custom-settings/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/custom-settings/test index 0e740f87c..4372b5970 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/custom-settings/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/custom-settings/test @@ -1,10 +1,10 @@ # check if smithy4sCodegen works > show p1/smithy4sAllExternalDependencies > p1/compile -$ exists p1/smithy_output/smithy4s/aws/iam/ActionPermissionDescription.scala -$ exists p1/smithy_output/smithy4s/smithy4s/example/ObjectService.scala +$ exists p1/smithy_output/aws/iam/ActionPermissionDescription.scala +$ exists p1/smithy_output/smithy4s/example/ObjectService.scala > p2/compile -$ exists p2/smithy_output/smithy4s/aws/iam/ActionPermissionDescription.scala -$ exists p2/smithy_output/smithy4s/smithy4s/example/ObjectService.scala --$ exists p2/smithy_output/smithy4s/smithy4s/toexclude/StructureToExclude.scala +$ exists p2/smithy_output/aws/iam/ActionPermissionDescription.scala +$ exists p2/smithy_output/smithy4s/example/ObjectService.scala +-$ exists p2/smithy_output/smithy4s/toexclude/StructureToExclude.scala diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/defaults/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/defaults/test index 03ff1b43e..a967ff4bc 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/defaults/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/defaults/test @@ -1,6 +1,6 @@ # check if smithy4sCodegen works > compile -$ exists target/scala-2.13/src_managed/main/scala/smithy4s/smithy4s/example/ObjectService.scala +$ exists target/scala-2.13/src_managed/main/smithy4s/smithy4s/example/ObjectService.scala $ exists target/scala-2.13/resource_managed/main/smithy4s.example.ObjectService.json # check if code can run, this can reveal runtime issues @@ -8,7 +8,7 @@ $ exists target/scala-2.13/resource_managed/main/smithy4s.example.ObjectService. > run $ copy-file example-added.smithy src/main/smithy/example-added.smithy > compile -$ exists target/scala-2.13/src_managed/main/scala/smithy4s/smithy4s/example/Added.scala +$ exists target/scala-2.13/src_managed/main/smithy4s/smithy4s/example/Added.scala # ensuring that removing existing files removes their outputs $ delete src/main/smithy/example.smithy diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/dependencies-only/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/dependencies-only/test index 1b03c2fca..7e6822104 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/dependencies-only/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/dependencies-only/test @@ -1,3 +1,3 @@ # check if smithy4sCodegen works > p1/compile -$ exists p1/smithy_output/smithy4s/aws/iam/ActionPermissionDescription.scala +$ exists p1/smithy_output/aws/iam/ActionPermissionDescription.scala diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/extra-configs/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/extra-configs/test index 4815ec114..535543089 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/extra-configs/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/extra-configs/test @@ -1,7 +1,7 @@ # check if main sources are generated > compile -$ exists target/scala-2.13/src_managed/main/scala/smithy4s/example/ExampleStruct.scala +$ exists target/scala-2.13/src_managed/main/smithy4s/example/ExampleStruct.scala # check if test sources are generated > Test/compile -$ exists target/scala-2.13/src_managed/test/scala/smithy4s/testexample/TestStruct.scala +$ exists target/scala-2.13/src_managed/test/smithy4s/testexample/TestStruct.scala diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule-aws/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule-aws/test index 883b4d0ac..9638cef6d 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule-aws/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule-aws/test @@ -1,5 +1,5 @@ # check if smithy4sCodegen works with libraries that were built with Smithy4s > show bar/smithy4sAllExternalDependencies > compile -$ exists foo/target/scala-2.13/src_managed/main/scala/smithy4s/foo/Lambda.scala -$ absent bar/target/scala-2.13/src_managed/main/scala/smithy4s/foo/Lambda.scala +$ exists foo/target/scala-2.13/src_managed/main/smithy4s/foo/Lambda.scala +$ absent bar/target/scala-2.13/src_managed/main/smithy4s/foo/Lambda.scala diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule-staged/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule-staged/test index 183e549f6..436ce1e19 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule-staged/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule-staged/test @@ -2,8 +2,8 @@ > foo/publishLocal > upstream/publishLocal > bar/compile -$ exists bar/target/scala-2.13/src_managed/main/scala/smithy4s/bar/Bar.scala -$ absent bar/target/scala-2.13/src_managed/main/scala/smithy4s/foo/Foo.scala +$ exists bar/target/scala-2.13/src_managed/main/smithy4s/bar/Bar.scala +$ absent bar/target/scala-2.13/src_managed/main/smithy4s/foo/Foo.scala # check if code can run, this can reveal runtime issues# such as initialization errors > bar/run diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule/test index e48a23e0e..f0f8da933 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/multimodule/test @@ -1,10 +1,10 @@ # check if smithy4sCodegen works in multimodule contexts > compile -$ exists bar/target/scala-2.13/src_managed/main/scala/smithy4s/bar/Bar.scala -$ absent bar/target/scala-2.13/src_managed/main/scala/smithy4s/foo/Foo.scala -$ absent bar/target/scala-2.13/src_managed/main/scala/smithy4s/foodir/FooDir.scala -$ exists foo/target/scala-2.13/src_managed/main/scala/smithy4s/foo/Foo.scala -$ exists foo/target/scala-2.13/src_managed/main/scala/smithy4s/foodir/FooDir.scala +$ exists bar/target/scala-2.13/src_managed/main/smithy4s/bar/Bar.scala +$ absent bar/target/scala-2.13/src_managed/main/smithy4s/foo/Foo.scala +$ absent bar/target/scala-2.13/src_managed/main/smithy4s/foodir/FooDir.scala +$ exists foo/target/scala-2.13/src_managed/main/smithy4s/foo/Foo.scala +$ exists foo/target/scala-2.13/src_managed/main/smithy4s/foodir/FooDir.scala # check if code can run, this can reveal runtime issues# such as initialization errors > bar/run diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/scala3/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/scala3/test index c6fef7253..7754244ad 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/scala3/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/scala3/test @@ -1,10 +1,10 @@ # check if smithy4sCodegen works > compile -$ exists target/scala-3.3.0/src_managed/main/scala/smithy4s/smithy4s/errors/BadRequest.scala -$ exists target/scala-3.3.0/src_managed/main/scala/smithy4s/smithy4s/errors/InternalServerError.scala -$ exists target/scala-3.3.0/src_managed/main/scala/smithy4s/smithy4s/errors/ErrorService.scala -$ exists target/scala-3.3.0/src_managed/main/scala/smithy4s/smithy4s/errors/package.scala +$ exists target/scala-3.3.0/src_managed/main/smithy4s/smithy4s/errors/BadRequest.scala +$ exists target/scala-3.3.0/src_managed/main/smithy4s/smithy4s/errors/InternalServerError.scala +$ exists target/scala-3.3.0/src_managed/main/smithy4s/smithy4s/errors/ErrorService.scala +$ exists target/scala-3.3.0/src_managed/main/smithy4s/smithy4s/errors/package.scala # check if code can run > run diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/smithy-build/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/smithy-build/test index 442fb337b..291aa5750 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/smithy-build/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/smithy-build/test @@ -1,5 +1,5 @@ # check if smithy4sCodegen works > compile -$ exists target/scala-2.13/src_managed/main/scala/smithy4s/smithy4s/example/ObjectService.scala +$ exists target/scala-2.13/src_managed/main/smithy4s/smithy4s/example/ObjectService.scala $ exists target/scala-2.13/resource_managed/main/smithy4s.example.ObjectService.json > checkOpenApi diff --git a/modules/codegen-plugin/src/sbt-test/codegen-plugin/smithy-rules/test b/modules/codegen-plugin/src/sbt-test/codegen-plugin/smithy-rules/test index b2a89b735..cdec95a97 100644 --- a/modules/codegen-plugin/src/sbt-test/codegen-plugin/smithy-rules/test +++ b/modules/codegen-plugin/src/sbt-test/codegen-plugin/smithy-rules/test @@ -1,3 +1,3 @@ # check if smithy4sCodegen works > compile -$ exists target/scala-2.13/src_managed/main/scala/smithy4s/smithy/rules +$ exists target/scala-2.13/src_managed/main/smithy4s/smithy/rules diff --git a/modules/codegen-plugin/src/smithy4s/codegen/Smithy4sCodegenPlugin.scala b/modules/codegen-plugin/src/smithy4s/codegen/Smithy4sCodegenPlugin.scala index 623fc3e9b..f6010e11c 100644 --- a/modules/codegen-plugin/src/smithy4s/codegen/Smithy4sCodegenPlugin.scala +++ b/modules/codegen-plugin/src/smithy4s/codegen/Smithy4sCodegenPlugin.scala @@ -188,7 +188,7 @@ object Smithy4sCodegenPlugin extends AutoPlugin { (config / sourceManaged).value / "smithy" ), config / unmanagedSourceDirectories ++= (config / smithy4sInputDirs).value, - config / smithy4sOutputDir := (config / sourceManaged).value / "scala", + config / smithy4sOutputDir := (config / sourceManaged).value / "smithy4s", config / smithy4sResourceDir := (config / resourceManaged).value, config / smithy4sCodegen := cachedSmithyCodegen(config).value, config / smithy4sSmithyLibrary := true, @@ -408,7 +408,7 @@ object Smithy4sCodegenPlugin extends AutoPlugin { (inputDirs ++ generatedFiles) .filter(_.exists()) .toList - val outputPath = (conf / smithy4sOutputDir).value / "smithy4s" + val outputPath = (conf / smithy4sOutputDir).value val resourceOutputPath = (conf / smithy4sResourceDir).value val allowedNamespaces = (conf / smithy4sAllowedNamespaces).?.value.map(_.toSet) From e710edb3045393e3167a8a7662905def8b86faa9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Olivier=20M=C3=A9lois?= Date: Tue, 21 May 2024 10:51:16 +0200 Subject: [PATCH 2/4] Bump versions --- project/Dependencies.scala | 2 +- project/Smithy4sBuildPlugin.scala | 2 +- project/plugins.sbt | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/project/Dependencies.scala b/project/Dependencies.scala index 9833ee1ea..27ed6341f 100644 --- a/project/Dependencies.scala +++ b/project/Dependencies.scala @@ -80,7 +80,7 @@ object Dependencies { object Fs2Data { val xml: Def.Initialize[ModuleID] = - Def.setting("org.gnieh" %%% "fs2-data-xml" % "1.10.0") + Def.setting("org.gnieh" %%% "fs2-data-xml" % "1.11.0") } object Mill { diff --git a/project/Smithy4sBuildPlugin.scala b/project/Smithy4sBuildPlugin.scala index 10a6edab6..d499cc486 100644 --- a/project/Smithy4sBuildPlugin.scala +++ b/project/Smithy4sBuildPlugin.scala @@ -30,7 +30,7 @@ case class CatsEffectAxis(idSuffix: String, directorySuffix: String) object Smithy4sBuildPlugin extends AutoPlugin { val Scala212 = "2.12.19" - val Scala213 = "2.13.12" + val Scala213 = "2.13.13" val Scala3 = "3.3.3" object autoImport { diff --git a/project/plugins.sbt b/project/plugins.sbt index 993d65eaa..1982a6892 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -1,6 +1,6 @@ // format: off addSbtPlugin("ch.epfl.scala" % "sbt-scalafix" % "0.12.0") -addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.15.0") +addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.16.0") addSbtPlugin("com.github.sbt" % "sbt-pgp" % "2.2.1") addSbtPlugin("com.github.sbt" % "sbt-dynver" % "5.0.1") addSbtPlugin("org.xerial.sbt" % "sbt-sonatype" % "3.10.0") From 52556e236d549036d52067f8161d83f404a53e94 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Olivier=20M=C3=A9lois?= Date: Tue, 21 May 2024 11:18:33 +0200 Subject: [PATCH 3/4] Avoid deprecated calls to fs2-data-xml's render --- modules/xml/src/smithy4s/xml/Xml.scala | 2 +- .../smithy4s/xml/internals/XmlPayloadEncoderCompilerImpl.scala | 2 +- modules/xml/test/src/smithy4s/xml/XmlCodecSpec.scala | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/modules/xml/src/smithy4s/xml/Xml.scala b/modules/xml/src/smithy4s/xml/Xml.scala index 0793a84b7..1b287f34d 100644 --- a/modules/xml/src/smithy4s/xml/Xml.scala +++ b/modules/xml/src/smithy4s/xml/Xml.scala @@ -115,7 +115,7 @@ object Xml { XmlDocument.documentEventifier .eventify(xmlDocument) - .through(render(collapseEmpty = false)) + .through(render.raw(collapseEmpty = false)) } private def writeToBytes[A: Schema](a: A): Stream[fs2.Pure, Byte] = diff --git a/modules/xml/src/smithy4s/xml/internals/XmlPayloadEncoderCompilerImpl.scala b/modules/xml/src/smithy4s/xml/internals/XmlPayloadEncoderCompilerImpl.scala index c1385b3cc..30f82e2ca 100644 --- a/modules/xml/src/smithy4s/xml/internals/XmlPayloadEncoderCompilerImpl.scala +++ b/modules/xml/src/smithy4s/xml/internals/XmlPayloadEncoderCompilerImpl.scala @@ -33,7 +33,7 @@ private[xml] class XmlPayloadEncoderCompilerImpl(escapeAttributes: Boolean) Blob { eventifier .eventify(xmlDocumentEncoder.encode(a)) - .through(fs2.data.xml.render(collapseEmpty = false)) + .through(fs2.data.xml.render.raw(collapseEmpty = false)) .through(fs2.text.utf8.encode[fs2.Pure]) .compile .to(Collector.supportsArray(Array)) diff --git a/modules/xml/test/src/smithy4s/xml/XmlCodecSpec.scala b/modules/xml/test/src/smithy4s/xml/XmlCodecSpec.scala index b33409f56..7be02550b 100644 --- a/modules/xml/test/src/smithy4s/xml/XmlCodecSpec.scala +++ b/modules/xml/test/src/smithy4s/xml/XmlCodecSpec.scala @@ -585,7 +585,7 @@ object XmlCodecSpec extends SimpleIOSuite { def show(xmlDocument: XmlDocument): String = XmlDocument.documentEventifier .eventify(xmlDocument) - .through(render()) + .through(render.raw()) .compile .string } From 5e190735ef3d2223051e6f35bd4c0a695d235c7e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Olivier=20M=C3=A9lois?= Date: Tue, 21 May 2024 12:07:34 +0200 Subject: [PATCH 4/4] Make mdoc happy --- modules/docs/markdown/06-guides/endpoint-middleware.md | 1 - 1 file changed, 1 deletion(-) diff --git a/modules/docs/markdown/06-guides/endpoint-middleware.md b/modules/docs/markdown/06-guides/endpoint-middleware.md index 7a1d0386b..a8ab23fef 100644 --- a/modules/docs/markdown/06-guides/endpoint-middleware.md +++ b/modules/docs/markdown/06-guides/endpoint-middleware.md @@ -108,7 +108,6 @@ We will create a server-side middleware that implements the authentication as de import smithy4s.example.guides.auth._ import cats.effect._ import cats.implicits._ -import org.http4s.implicits._ import org.http4s._ import smithy4s.http4s.SimpleRestJsonBuilder import smithy4s._