From b232d844c52adfb9af2adbabe8283222286da685 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Piotr=20Sowi=C5=84ski?= Date: Wed, 24 Apr 2024 11:50:58 +0200 Subject: [PATCH] Second attempt to fix flaky test (#49) Not sure why these two specs fail, maybe because of the different execution context based on Pekko? --- core/src/main/protobuf_shared | 2 +- .../jelly/integration_tests/CrossStreamingSpec.scala | 8 +++++--- .../jelly/integration_tests/io/IoSerDesSpec.scala | 6 ++++-- 3 files changed, 10 insertions(+), 6 deletions(-) diff --git a/core/src/main/protobuf_shared b/core/src/main/protobuf_shared index b702f006..fa815843 160000 --- a/core/src/main/protobuf_shared +++ b/core/src/main/protobuf_shared @@ -1 +1 @@ -Subproject commit b702f0061f5236395abefcb1c0e7dc28ff52e23d +Subproject commit fa815843efb4822898f56713e202d2ae06554f1c diff --git a/integration-tests/src/test/scala/eu/ostrzyciel/jelly/integration_tests/CrossStreamingSpec.scala b/integration-tests/src/test/scala/eu/ostrzyciel/jelly/integration_tests/CrossStreamingSpec.scala index cdfdee20..eb9cf817 100644 --- a/integration-tests/src/test/scala/eu/ostrzyciel/jelly/integration_tests/CrossStreamingSpec.scala +++ b/integration-tests/src/test/scala/eu/ostrzyciel/jelly/integration_tests/CrossStreamingSpec.scala @@ -10,6 +10,7 @@ import org.apache.jena.sparql.util.IsoMatcher import org.apache.jena.sys.JenaSystem import org.apache.pekko.actor.ActorSystem import org.apache.pekko.stream.scaladsl.* +import org.scalatest.BeforeAndAfterAll import org.scalatest.concurrent.ScalaFutures import org.scalatest.matchers.should.Matchers import org.scalatest.wordspec.AnyWordSpec @@ -20,12 +21,13 @@ import scala.concurrent.ExecutionContext import scala.concurrent.duration.* import scala.jdk.CollectionConverters.* -class CrossStreamingSpec extends AnyWordSpec, Matchers, ScalaFutures: +class CrossStreamingSpec extends AnyWordSpec, Matchers, ScalaFutures, BeforeAndAfterAll: implicit val actorSystem: ActorSystem = ActorSystem() implicit val ec: ExecutionContext = actorSystem.getDispatcher implicit val defaultPatience: PatienceConfig = PatienceConfig(timeout = 5.seconds, interval = 50.millis) - - JenaSystem.init() + + override def beforeAll(): Unit = + JenaSystem.init() private val implementations: Seq[(String, TestStream)] = Seq( ("Jena", JenaTestStream), diff --git a/integration-tests/src/test/scala/eu/ostrzyciel/jelly/integration_tests/io/IoSerDesSpec.scala b/integration-tests/src/test/scala/eu/ostrzyciel/jelly/integration_tests/io/IoSerDesSpec.scala index d5154627..4c529c69 100644 --- a/integration-tests/src/test/scala/eu/ostrzyciel/jelly/integration_tests/io/IoSerDesSpec.scala +++ b/integration-tests/src/test/scala/eu/ostrzyciel/jelly/integration_tests/io/IoSerDesSpec.scala @@ -4,6 +4,7 @@ import eu.ostrzyciel.jelly.core.JellyOptions import eu.ostrzyciel.jelly.core.proto.v1.RdfStreamOptions import org.apache.jena.sys.JenaSystem import org.apache.pekko.actor.ActorSystem +import org.scalatest.BeforeAndAfterAll import org.scalatest.concurrent.ScalaFutures import org.scalatest.matchers.should.Matchers import org.scalatest.wordspec.AnyWordSpec @@ -13,10 +14,11 @@ import java.io.{ByteArrayInputStream, ByteArrayOutputStream, File, FileInputStre /** * Tests for IO ser/des (Jena RIOT, RDF4J Rio, and semi-reactive IO over Pekko Streams). */ -class IoSerDesSpec extends AnyWordSpec, Matchers, ScalaFutures: +class IoSerDesSpec extends AnyWordSpec, Matchers, ScalaFutures, BeforeAndAfterAll: implicit val as: ActorSystem = ActorSystem("test") - JenaSystem.init() + override def beforeAll(): Unit = + JenaSystem.init() val casesTriples: Seq[(String, File)] = Seq[String]( "weather.nt", "p2_ontology.nt", "nt-syntax-subm-01.nt", "rdf-star.nt", "rdf-star-blanks.nt"