-
Notifications
You must be signed in to change notification settings - Fork 156
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
Add overridden duration timeout to StreamTestKit #1468
base: main
Are you sure you want to change the base?
Conversation
@@ -35,12 +35,30 @@ object StreamTestKit { | |||
* This assertion is useful to check that all of the stages have | |||
* terminated successfully. | |||
*/ | |||
def assertAllStagesStopped[T](block: => T, overrideTimeout: FiniteDuration)(implicit materializer: Materializer): T = | |||
materializer match { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is code duplication here, I can clean it up if the premise of this PR is acceptable.
29df1ad
to
14b7ce3
Compare
stream-testkit/src/test/scala/org/apache/pekko/stream/testkit/StreamSpec.scala
Outdated
Show resolved
Hide resolved
afc1774
to
dd9fefe
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This might look a bit un-orthodox by Pekko standards, but it is the idiomatic way to override a configuration when in ScalaTest (which is what StreamSpec
extends).
The defaault behaviour is still the same (i.e. getting the value from pekko.stream.testkit.all-stages-stopped-timeout
) but if you decide to override it then you can do it the ScalaTest specific way.
dd9fefe
to
0624688
Compare
0624688
to
4763be2
Compare
including in 1.1.2 milestone - if 1.1.1-RC1 vote fails, we can consider adding this to a 1.1.1-RC2 |
import java.util.concurrent.TimeUnit | ||
|
||
trait StreamConfiguration extends TestKitBase { | ||
case class StreamConfig(allStagesStoppedTimeout: Span = Span({ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The premise here is that by default we get the timeout value from Pekko typesafe config (as is expected when using Pekko) however if a user wants to override this then its done the ScalaTest idiomatic way (which is overriding a def
in a trait, similar to how PatienceConfig
works).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It is possible to omit units and support more flexibility, but the code is slightly complex and for reference only.
import scala.jdk.DurationConverters._
import org.scalatest.time.Span._
system.settings.config.getDuration("pekko.stream.testkit.all-stages-stopped-timeout").toScala.convertDurationToSpan
I just saw this {}
and wanted to make some changes. I looked at the Span code and found that it has convertDurationoSpan. You can do whatever you want.
@@ -53,10 +71,15 @@ object StreamTestKit { | |||
} | |||
|
|||
/** INTERNAL API */ | |||
@InternalApi private[testkit] def assertNoChildren(sys: ActorSystem, supervisor: ActorRef): Unit = { | |||
@InternalApi private[testkit] def assertNoChildren(sys: ActorSystem, supervisor: ActorRef, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
add an overloaded method here to avoid the mima issue?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This approach seems reasonable to me!
@@ -0,0 +1 @@ | |||
ProblemFilters.exclude[DirectMissingMethodProblem]("org.apache.pekko.stream.testkit.scaladsl.StreamTestKit.assertNoChildren") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When adding mima excludes, please add the reason why it is acceptable. In this case, the reason might be we don't promise binary compatiblity for -testkit artifacts (https://pekko.apache.org/docs/pekko/current/common/binary-compatibility-rules.html), and that this method is private[testkit]
The context of this change is apache/pekko-http#590 (review). It turns out its extremely cumbersome to manually override the duration so I am adding this public method
@raboof @jrudolph Let me know if this line of thinking is on the right lines.