Skip to content

Commit

Permalink
Adapted snapshotTest for reuse
Browse files Browse the repository at this point in the history
  • Loading branch information
develeon committed Sep 14, 2024
1 parent f2130cb commit c8bac23
Show file tree
Hide file tree
Showing 5 changed files with 91 additions and 58 deletions.
28 changes: 18 additions & 10 deletions build.sbt
Original file line number Diff line number Diff line change
Expand Up @@ -216,7 +216,8 @@ lazy val tools = project
"dev.zio" %% "zio-test" % zioVersion % Test,
"dev.zio" %% "zio-test-sbt" % zioVersion % Test,
"dev.zio" %% "zio-json" % zioJsonVersion % Test
)
),
Test / publishArtifact := true
)
.dependsOn(core, clientJVM, quickAdapter % Test)

Expand Down Expand Up @@ -267,18 +268,25 @@ lazy val codegenSbt = project
.settings(
scriptedLaunchOpts := {
scriptedLaunchOpts.value ++
Seq("-Xmx1024M", "-Xss4M", "-Dplugin.version=" + version.value)
Seq(
"-Xmx1024M",
"-Xss4M",
"-Dplugin.version=" + version.value,
s"-Dproject.dir=${baseDirectory.value.getAbsolutePath}"
)
},
scriptedBufferLog := false,
scriptedDependencies := {
(macros / publishLocal).value
(core / publishLocal).value
(clientJVM / publishLocal).value
(tools / publishLocal).value
publishLocal.value
}
scriptedDependencies := scriptedDependencies
.dependsOn(
macros / publishLocal,
core / publishLocal,
clientJVM / publishLocal,
tools / publishLocal,
publishLocal
)
.value
)
.dependsOn(tools)
.dependsOn(tools % "compile->compile;test->test")

lazy val catsInterop = project
.in(file("interop/cats"))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,19 +26,20 @@ ThisBuild / crossScalaVersions := allScala

// ### Dependencies ###

lazy val calibanLib: Seq[ModuleID] =
sys.props.get("plugin.version") match {
case Some(x) => Seq("com.github.ghostdogpr" %% "caliban" % x)
case _ => sys.error("""|The system property 'plugin.version' is not defined.
|Specify this property using the scriptedLaunchOpts -D.""".stripMargin)
}
lazy val calibanLib = Seq(
"com.github.ghostdogpr" %% "caliban" % Version.pluginVersion,
"com.github.ghostdogpr" %% "caliban-tools" % Version.pluginVersion % "compile->compile;test->test"
)

lazy val sttp = Seq(
"com.softwaremill.sttp.client3" %% "core" % "3.9.8",
"com.softwaremill.sttp.client3" %% "zio" % "3.9.8"
)

lazy val zioTest = Seq("dev.zio" %% "zio-test" % "2.1.9" % Test)
lazy val zioTest = Seq(
"dev.zio" %% "zio-test" % "2.1.9" % Test,
"dev.zio" %% "zio-test-sbt" % "2.1.9" % Test
)
// ### App Modules ###

/**
Expand Down Expand Up @@ -106,6 +107,7 @@ lazy val posts =
)
.settings(libraryDependencies ++= calibanLib ++ zioTest)


lazy val potatoes =
project
.in(file("modules/potatoes"))
Expand Down
Original file line number Diff line number Diff line change
@@ -1,24 +1,24 @@
import poc.caliban.posts.GraphQLApi

import scala.io.Source
import java.io.File
import java.nio.file.{Files, Paths}
import zio.test.Assertion._
import zio.test._
import caliban.tools._
import java.nio.file.Path

class ValidateGraphQlSpec extends ZIOSpecDefault {
object ValidateGraphQlSpec extends SnapshotTest {
override val testName: String = "ValidateGraphQlSpec"

val graphqlFile= "src/sbt-test/compiletime-codegen/test-compile/modules/posts/src/test/resources/postservice.graphql"
val projectDir = sys.props.get("project.dir").getOrElse("")

override def spec =
suite("Validate Postservice")(
test("Render postservice as earlier") {
val filename = "postservice.graphql"
val expectedGraphQL: String = Source.fromResource(filename).getLines().mkString("\n")
val gqlApi = GraphQLApi.api
val renderContent: String = s"${gqlApi.render}"

//Files.writeString(Paths.get(File(s"/tmp/$filename").toURI), renderContent)

assertTrue(expectedGraphQL == renderContent)
writeAndCompare(Path.of(projectDir).resolve(graphqlFile), renderContent, "Render postservice")
}
)
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
object Version {
def pluginVersion: String =
sys.props.get("plugin.version") match {
case Some(x) => x
case _ => sys.error("""|The system property 'plugin.version' is not defined.
|Specify this property using the scriptedLaunchOpts -D.""".stripMargin)
}
}
81 changes: 48 additions & 33 deletions tools/src/test/scala/caliban/tools/SnapshotTest.scala
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@ package caliban.tools

import caliban.tools.SnapshotTest.GitLock
import zio.internal.stacktracer.SourceLocation
import zio.test.{ assert, assertTrue, Assertion, Spec, TestResult, ZIOSpecDefault }
import zio.prelude._
import zio.test.Assertion.equalTo
import zio.test.{ assert, assertNever, assertTrue, Assertion, Spec, TestResult, ZIOSpecDefault }
import zio.{ Task, Trace }

import java.nio.file.{ Files, Path }
Expand All @@ -16,51 +18,64 @@ trait SnapshotTest extends ZIOSpecDefault {
)(str: Task[String])(implicit sourceLocation: SourceLocation, trace: Trace): Spec[Any, Throwable] = {
val label = label0.replace('/', '_').replace("'", "")
zio.test.test[Task[TestResult]](label) {
str.map { str =>
val isCi = SnapshotTest.isCi
str.map { content =>
val path = SnapshotTest.projectRoot.resolve(s"tools/src/test/resources/snapshots/$testName/${label + ".scala"}")
writeAndCompare(path, content, label)
}
}
}

def write(): TestResult = {
Files.createDirectories(path.getParent)
Files.writeString(path, str)
import scala.sys.process._
// at least don't take the git lock multiple times from same process. this can still fail if concurrent processes try to take it.
GitLock.synchronized {
// allow failing external command, but complain to stderr
try s"git add '$path'".!
catch {
case th: Throwable =>
System.err.println(s"Could not add snapshot file '$path' to git: ${th.getMessage}")
}
}
assert(())(Assertion.anything)
}
private def write(path: Path, str: String): TestResult = {
Files.createDirectories(path.getParent)
Files.writeString(path, str)
import scala.sys.process._

Try(Files.readString(path)) match {
case Success(existing) if isCi =>
assertTrue(str == existing).label(
s"generated result for test '$label' did not match snapshot contents in file '$path. Rerun with environment `CI` not set to 'true' to update and then check in the file"
)
case Success(_) =>
write()
case Failure(_) if isCi =>
assertTrue(false).label(
s"Could not read snapshot file '$path'. Rerun with environment `CI` not set to 'true' to create and then check in the file"
)
case Failure(_) =>
write()
var exitCode = 0
// at least don't take the git lock multiple times from same process. this can still fail if concurrent processes try to take it.
GitLock.synchronized {
// allow failing external command, but complain to stderr
exitCode =
try
s"git add '$path'".!
catch {
case th: Throwable =>
System.err.println(s"Could not add snapshot file '$path' to git: ${th.getMessage}")
-1
}
}
}

if (exitCode == 0) {
assert(())(Assertion.anything)
} else {
assertNever(s"Failed to add file '$path' to git. Exit code: $exitCode")
}
}

def writeAndCompare(path: Path, content: String, label: String): TestResult =
Try(Files.readString(path)) match {
case Success(existing) if SnapshotTest.isCi =>
assertTrue(content == existing).label(
s"generated result for test '$label' did not match snapshot contents in file '$path. Rerun with environment `CI` not set to 'true' to update and then check in the file"
)
case Success(existing) if existing.equals(content) =>
assert(())(Assertion.anything)
case Success(_) =>
write(path, content)
case Failure(_) if SnapshotTest.isCi =>
assertTrue(false).label(
s"Could not read snapshot file '$path'. Rerun with environment `CI` not set to 'true' to create and then check in the file"
)
case Failure(_) =>
write(path, content)
}

}

object SnapshotTest {
val `.git`: Path = Path.of(".git")
val cwd: Path = Path.of(sys.props("user.dir"))

val projectRoot: Path = {
lazy val projectRoot: Path = {
def lookUpwards(p: Path): Option[Path] =
if (Files.list(p).anyMatch(p => p.getFileName == `.git`)) Some(p)
else Option(p.getParent).flatMap(lookUpwards)
Expand Down

0 comments on commit c8bac23

Please sign in to comment.