Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[WIP] Fix flaky tests #3827

Draft
wants to merge 85 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
85 commits
Select commit Hold shift + click to select a range
0a9e3ad
Add tracing for tests
kciesielski Jun 6, 2024
f97d3e7
Don't for in tests for NettySync
kciesielski Jun 7, 2024
4c37ef6
Run tests on JVM21
kciesielski Jun 7, 2024
53ce6d1
Disable vert.x tests for maxContentLength
kciesielski Jun 7, 2024
4cbe640
Merge branch 'master' into fix-hanging-tests
kciesielski Jun 14, 2024
c72ea72
Disable client tests
kciesielski Jun 14, 2024
830be26
Return a more standard message
kciesielski Jun 14, 2024
235ced3
Don't check Close frame when it can fail (vertx)
kciesielski Jun 14, 2024
682b158
Restore after merge
kciesielski Jun 14, 2024
055c5e0
Merge branch 'master' into fix-hanging-tests
kciesielski Jun 14, 2024
0d1cb9b
Restore Java 11 builds
kciesielski Jun 14, 2024
96efdc8
Restore fork needed for running perf test server
kciesielski Jun 14, 2024
5359d41
Disable graceful shutdown tests
kciesielski Jun 14, 2024
6440174
Disable tests for zio-based backends
kciesielski Jun 14, 2024
c4e2904
Bring back testServer and two zio backends
kciesielski Jun 17, 2024
44f12f2
Fix build
kciesielski Jun 17, 2024
6f5daf2
Hide http4s-zio to check if armeria-zio fails
kciesielski Jun 17, 2024
e036510
Restore http4sZio
kciesielski Jun 18, 2024
61daec2
Disable WebSocket tests for http4s-zio
kciesielski Jun 18, 2024
ff4b9ae
Restore zhtt4p4s WS tests, disable vertx-cats
kciesielski Jun 20, 2024
0fb69ae
Keep only vertx-cats disabled
kciesielski Jun 24, 2024
35b9d8d
Merge branch 'master' into fix-hanging-tests
kciesielski Jun 24, 2024
66d0799
Disable tests for vertx-zio
kciesielski Jun 24, 2024
e7dd9ab
Experiment: publish compiled code as an image
kciesielski Jul 8, 2024
952f37b
Fix references
kciesielski Jul 8, 2024
0cf5edb
Add a dockerfile
kciesielski Jul 8, 2024
7dfdac7
Install additional tools on the test image
kciesielski Jul 8, 2024
1fa2f61
Fix dockerfile
kciesielski Jul 8, 2024
ab5025e
Limit matrices for faster experimenting
kciesielski Jul 8, 2024
5be2f45
Remove workdir
kciesielski Jul 8, 2024
75df48c
Fix the matrix
kciesielski Jul 8, 2024
5aff159
Fix compileScoped command
kciesielski Jul 8, 2024
abd0ab7
Mount workdir
kciesielski Jul 8, 2024
b72fce4
Disable build cache from GH Action
kciesielski Jul 8, 2024
eee3fdd
Try different base image for tests
kciesielski Jul 8, 2024
a352599
Try the gh actions runner base image
kciesielski Jul 8, 2024
d1f32ba
Remove run npm step
kciesielski Jul 8, 2024
beac067
Manually set up sbt
kciesielski Jul 9, 2024
fbcae65
Run installdependencies.sh
kciesielski Jul 9, 2024
5c95e1e
Install deps as root
kciesielski Jul 9, 2024
dae3523
Install curl manually
kciesielski Jul 9, 2024
7f7d820
Fix apt calls
kciesielski Jul 9, 2024
e692177
Fix apt upgrade
kciesielski Jul 9, 2024
485c0aa
Install unzip
kciesielski Jul 9, 2024
99b3318
Disable retry
kciesielski Jul 9, 2024
5b44599
Set all workspace files as owned by runner
kciesielski Jul 9, 2024
32ba788
Add some checks
kciesielski Jul 9, 2024
63e0c46
Remove some stuff from Dockerfile
kciesielski Jul 9, 2024
8f6f709
Debug workdir
kciesielski Jul 9, 2024
efa067f
Try a different workdir
kciesielski Jul 9, 2024
2e1e73c
Move sources to workdir
kciesielski Jul 9, 2024
2eb77aa
Try a different way of moving
kciesielski Jul 9, 2024
5ed1af1
Switch default shell to bash
kciesielski Jul 9, 2024
4c8000a
Copy build results
kciesielski Jul 9, 2024
5cf767e
Use context to make changes visible
kciesielski Jul 9, 2024
99578bb
Drop dockerization, use build-group axis
kciesielski Jul 9, 2024
9277b03
Force zio only for experimentation, disable netty-zio
kciesielski Jul 9, 2024
b1d6868
Disable zio-http
kciesielski Jul 9, 2024
0480fa7
Reduce retries for faster feedback
kciesielski Jul 9, 2024
9e7ac71
Remove the JS platform temporarily
kciesielski Jul 9, 2024
fe6c8be
Restore jdk 11 for Mima
kciesielski Jul 9, 2024
6998880
Don't expect close response for zhttp4s ws tests (flaky)
kciesielski Jul 9, 2024
a1f27d7
Attempt a thread dump on retry
kciesielski Jul 9, 2024
e8d23ff
Leave disabled tests only for netty-zio
kciesielski Jul 9, 2024
2604d67
Tune attempts/retries for better feedback
kciesielski Jul 9, 2024
40a9d3f
Include missing matrix combinations
kciesielski Jul 9, 2024
bf45f53
Fix saving pid
kciesielski Jul 9, 2024
b59591a
use pkill instead of pidfile
kciesielski Jul 9, 2024
63d3b4d
Try a different hack to pkill java
kciesielski Jul 9, 2024
894e6ee
Fork tests for netty-zio and zio-http
kciesielski Jul 10, 2024
35d261b
Remove test forks
kciesielski Jul 10, 2024
5de2a9b
Run kill switch when closing server
kciesielski Jul 10, 2024
e7bb1a2
Remove the pkill hack
kciesielski Jul 10, 2024
b97599e
Fork tests for zio-http
kciesielski Jul 10, 2024
ff8d3b1
Restore longer timeout
kciesielski Jul 10, 2024
4312db0
Restore short timeout
kciesielski Jul 10, 2024
9898c8f
Revert test fork
kciesielski Jul 10, 2024
e403e94
Restore pkill to get thread dumps
kciesielski Jul 10, 2024
0041cab
Run on bash, try different dump technique
kciesielski Jul 10, 2024
a001a0c
Add pkill to on_retry_command as well
kciesielski Jul 10, 2024
9e23e3d
Disable graceful shutdown
kciesielski Jul 10, 2024
69212ad
Restore graceful shutdown
kciesielski Jul 10, 2024
bb1d898
Add pkill to 2.12
kciesielski Jul 10, 2024
3fdf9f9
Disable additionalTests
kciesielski Jul 10, 2024
636655d
Remove pkill
kciesielski Jul 11, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 22 additions & 6 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,9 @@ jobs:
fail-fast: false
matrix:
scala-version: [ "2.12", "2.13", "3" ]
target-platform: [ "JVM", "JS", "Native" ]
target-platform: [ "JVM", "Native" ]
java: [ "11", "21" ]
build-group: [ "main", "zio" ]
exclude:
- java: "21"
- scala-version: "2.12"
Expand All @@ -32,9 +33,22 @@ jobs:
- scala-version: "2.13"
target-platform: "JVM"
java: "21"
build-group: "main"
- scala-version: "2.13"
target-platform: "JVM"
java: "21"
build-group: "zio"
- scala-version: "3"
target-platform: "JVM"
java: "21"
build-group: "main"
- scala-version: "3"
target-platform: "JVM"
java: "21"
build-group: "zio"
defaults:
run:
shell: bash -eo pipefail {0}
steps:
- name: Checkout
uses: actions/checkout@v4
Expand Down Expand Up @@ -71,24 +85,26 @@ jobs:
- name: Enable Loom-specific modules
if: matrix.java == '21'
run: echo "ONLY_LOOM=1" >> $GITHUB_ENV
- name: Set build group
run: echo "BUILD_GROUP=${{ matrix.build-group }}" >> $GITHUB_ENV
- name: Compile
run: sbt $SBT_JAVA_OPTS -v "compileScoped ${{ matrix.scala-version }} ${{ matrix.target-platform }}"
- name: Compile documentation
if: matrix.target-platform == 'JVM' && matrix.java == '11'
if: matrix.target-platform == 'JVM' && matrix.java == '21'
run: sbt $SBT_JAVA_OPTS -v compileDocumentation
- name: Test
if: matrix.target-platform == 'JVM' && matrix.scala-version == '2.12'
uses: nick-fields/retry@v2
with:
timeout_minutes: 15
max_attempts: 4
timeout_minutes: 10
max_attempts: 2
command: sbt $SBT_JAVA_OPTS -v "testScoped ${{ matrix.scala-version }} ${{ matrix.target-platform }}; openapiCodegenSbt2_12/scripted"
- name: Test
if: matrix.target-platform != 'JS' && !(matrix.target-platform == 'JVM' && matrix.scala-version == '2.12')
uses: nick-fields/retry@v2
with:
timeout_minutes: 15
max_attempts: 4
timeout_minutes: 10
max_attempts: 2
command: sbt $SBT_JAVA_OPTS -v "testScoped ${{ matrix.scala-version }} ${{ matrix.target-platform }}"
# The finatra tests take a really long time (1/3 of the build duration); hence, they are disabled and need to be run separately
#- name: Test finatra
Expand Down
23 changes: 23 additions & 0 deletions build.sbt
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,7 @@ val commonJvmSettings: Seq[Def.Setting[_]] = commonSettings ++ Seq(
Compile / unmanagedSourceDirectories ++= versionedScalaJvmSourceDirectories((Compile / sourceDirectory).value, scalaVersion.value),
Test / unmanagedSourceDirectories ++= versionedScalaJvmSourceDirectories((Test / sourceDirectory).value, scalaVersion.value),
Test / testOptions += Tests.Argument("-oD"), // js has other options which conflict with timings
testListeners += TimingTestListener,
scalacOptions ++= {
CrossVersion.partialVersion(scalaVersion.value) match {
case Some((2, _)) => Seq("-target:jvm-1.8") // some users are on java 8
Expand Down Expand Up @@ -252,6 +253,9 @@ lazy val rawAllAggregates = core.projectRefs ++

lazy val loomProjects: Seq[String] = Seq(nettyServerSync, nimaServer, examples).flatMap(_.projectRefs).flatMap(projectId)

// Separated zio-related projects, to run their build/tests as a parallel "axis" to save resources
lazy val zioProjects: Seq[String] = Seq(zio, armeriaServerZio, http4sServerZio, nettyServerZio, vertxServerZio, zioHttpServer).flatMap(_.projectRefs).flatMap(projectId)

def projectId(projectRef: ProjectReference): Option[String] =
projectRef match {
case ProjectRef(_, id) => Some(id)
Expand All @@ -260,6 +264,7 @@ def projectId(projectRef: ProjectReference): Option[String] =
}

lazy val allAggregates: Seq[ProjectReference] = {
val filteredByTargetAndPlatform = {
val filteredByNative = if (sys.env.isDefinedAt("STTP_NATIVE")) {
println("[info] STTP_NATIVE defined, including native in the aggregate projects")
rawAllAggregates
Expand All @@ -277,6 +282,24 @@ lazy val allAggregates: Seq[ProjectReference] = {
println("[info] ONLY_LOOM *not* defined, *not* including loom-based-projects")
filteredByNative.filterNot(p => projectId(p).forall(loomProjects.contains))
}
}
val filteredByBuildGroup = {
val buildGroup = sys.env.getOrElse("BUILD_GROUP", "none")
if (buildGroup != "none") {
println(s"[info] Running build only for projects in group: $buildGroup")
}
buildGroup match {
case "zio" =>
filteredByTargetAndPlatform.filter(p => projectId(p).forall(zioProjects.contains))
case "main" =>
// TODO should be 'filterNot', but leaving filter to experiment with zio-related builds
filteredByTargetAndPlatform.filter(p => projectId(p).forall(zioProjects.contains))
case other =>
println("[info] Build group not specified, it won't be used for filtering.")
filteredByTargetAndPlatform
}
}
filteredByBuildGroup
}

// separating testing into different Scala versions so that it's not all done at once, as it causes memory problems on CI
Expand Down
36 changes: 36 additions & 0 deletions project/TimingTestListener.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
import sbt._
import sbt.Keys._
import sbt.testing.{Status, Event, EventHandler, Logger => TLogger}

object TimingTestListener extends TestsListener {
def now(): Long = System.nanoTime() / 1000000

override def startGroup(name: String): Unit = {
println(s"[TESTINFO] Starting test group: $name,${now()}")
}

override def testEvent(event: TestEvent): Unit = {
if (event.detail.isEmpty)
println(s"[TESTINFO] Test event: ${event},${now()}")
else
event.detail.foreach { e =>
val status = if (e.status() == Status.Success) "PASSED" else "FAILED"
println(s"[TESTINFO] Test ${e.fullyQualifiedName()} $status in ${e.duration()} ms,${now()}")
}
}

override def endGroup(name: String, t: Throwable): Unit = {
println(s"[TESTINFO] Test group $name failed with ${t.getMessage},${now()}")
}

override def endGroup(name: String, result: TestResult): Unit = {
println(s"[TESTINFO] Finished test group: $name result: $result,${now()}")
}

override def doInit(): Unit = {
}

override def doComplete(finalResult: TestResult): Unit = {
()
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,8 @@ class ZHttp4sServerTest extends TestSuite with OptionValues {
ZioStreams,
autoPing = true,
failingPipe = false,
handlePong = false
handlePong = false,
expectCloseResponse = false
) {
override def functionToPipe[A, B](f: A => B): streams.Pipe[A, B] = in => in.map(f)
override def emptyPipe[A, B]: streams.Pipe[A, B] = _ => ZStream.empty
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,5 +21,5 @@ trait TestServerInterpreter[F[_], +R, OPTIONS, ROUTE] {
def serverWithStop(routes: NonEmptyList[ROUTE], gracefulShutdownTimeout: Option[FiniteDuration] = None): Resource[IO, (Port, KillSwitch)]

def server(routes: NonEmptyList[ROUTE]): Resource[IO, Port] =
serverWithStop(routes, gracefulShutdownTimeout = None).map(_._1)
serverWithStop(routes, gracefulShutdownTimeout = None).flatMap { case (port, killSwitch) => Resource.pure(port).onFinalize(killSwitch) }
}
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,8 @@ class CatsVertxServerTest extends TestSuite {
new ServerMultipartTests(
createServerTest,
partContentTypeHeaderSupport = false, // README: doesn't seem supported but I may be wrong
partOtherHeaderSupport = false
partOtherHeaderSupport = false,
maxContentLengthSupport = false
).tests() ++
new ServerStreamingTests(createServerTest).tests(Fs2Streams.apply[IO])(drainFs2) ++
new ServerWebSocketTests(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,8 @@ class VertxBlockingServerTest extends TestSuite {
new ServerMultipartTests(
createServerTest,
partContentTypeHeaderSupport = false, // README: doesn't seem supported but I may be wrong
partOtherHeaderSupport = false
partOtherHeaderSupport = false,
maxContentLengthSupport = false
).tests()
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,8 @@ class VertxServerTest extends TestSuite {
new ServerMultipartTests(
createServerTest,
partContentTypeHeaderSupport = true,
partOtherHeaderSupport = false
partOtherHeaderSupport = false,
maxContentLengthSupport = false
).tests() ++ new ServerStreamingTests(createServerTest).tests(VertxStreams)(drainVertx[Buffer]) ++
(new ServerWebSocketTests(
createServerTest,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,8 @@ class ZioVertxServerTest extends TestSuite with OptionValues {
new ServerMultipartTests(
createServerTest,
partContentTypeHeaderSupport = false, // README: doesn't seem supported but I may be wrong
partOtherHeaderSupport = false
partOtherHeaderSupport = false,
maxContentLengthSupport = false
).tests() ++ additionalTests() ++
new ServerStreamingTests(createServerTest).tests(ZioStreams)(drainZStream) ++
new ServerWebSocketTests(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -276,8 +276,8 @@ class ZioHttpServerTest extends TestSuite {
) {
override def functionToPipe[A, B](f: A => B): ZioStreams.Pipe[A, B] = in => in.map(f)
override def emptyPipe[A, B]: ZioStreams.Pipe[A, B] = _ => ZStream.empty
}.tests() ++
additionalTests()
}.tests() //++
// additionalTests()
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ class ZioHttpTestServerInterpreter(
Server.Config.default
.port(0)
.enableRequestStreaming
.gracefulShutdownTimeout(gracefulShutdownTimeout.map(Duration.fromScala).getOrElse(50.millis))
.gracefulShutdownTimeout(gracefulShutdownTimeout.map(Duration.fromScala).getOrElse(50.millis))
)
)

Expand Down
2 changes: 1 addition & 1 deletion tests/src/main/resources/logback.xml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
</encoder>
</appender>

<root level="INFO">
<root level="WARN">
<appender-ref ref="STDOUT"/>
</root>
</configuration>
Loading