From 89600f3a3a93d6d357c2f8018eb6abe427911718 Mon Sep 17 00:00:00 2001 From: James Ward Date: Thu, 25 Jul 2024 21:53:28 -0600 Subject: [PATCH] cleanup scenario for hedging #bill #james #time 30m --- Chapters/09_Resilience.md | 77 ++++++++++----------------------------- examples | 2 +- 2 files changed, 21 insertions(+), 58 deletions(-) diff --git a/Chapters/09_Resilience.md b/Chapters/09_Resilience.md index ffb6967a..b7bec015 100644 --- a/Chapters/09_Resilience.md +++ b/Chapters/09_Resilience.md @@ -657,85 +657,51 @@ import zio.* import zio.direct.* import zio.Console.* -object Scenario: - def apply( - z: ZIO[Any, String, Unit] - ): ZLayer[Any, Nothing, Unit] = - Runtime.setConfigProvider: - StaticConfigProvider(z) - -// This configuration is used by Effects to get the scenario that -// may have been passed in via `bootstrap` -// The configuration is optional and the default of `Config.fail` -// sets the Option to None. -val scenarioConfig: Config[ - Option[ZIO[Any, String, Unit]] -] = - Config.Optional[ZIO[Any, String, Unit]]: - Config.fail("no default scenario") - -class StaticConfigProvider( - z: ZIO[Any, String, Unit] -) extends ConfigProvider: - override def load[A](config: Config[A])( - implicit trace: Trace - ): IO[Config.Error, A] = - ZIO.succeed: - Some(z).asInstanceOf[A] - val sometimesSlowRequest = defer: if Random.nextIntBounded(1_000).run == 0 then ZIO.sleep(3.second).run -// based on our config from bootstrap, make the request with the additional logic -val makeRequest = - defer: - ZIO.config(scenarioConfig).run match - case Some(z: ZIO[Any, String, Unit]) => - z.run - case _ => - ZIO.fail("No scenario") +case class Scenario( + effect: ZIO[Any, Nothing, Unit] +) ``` ```scala 3 mdoc:silent -// TODO not sure yet how I feel about this -// It should be a def that takes a ZIO, but we are avoiding that -val makeLotsOfRequests = +import zio.* +import zio.direct.* + +def makeLotsOfRequests(scenario: Scenario) = defer: val totalRequests = 50_000 + val failOnBreach = + scenario + .effect + .timeoutFail("took too long"): + 1.second + val successes = ZIO .collectAllSuccessesPar: - List - .fill(totalRequests)(makeRequest) + List.fill(totalRequests): + failOnBreach .run val contractBreaches = totalRequests - successes.length - "Contract Breaches: " + contractBreaches -``` - -```scala 3 mdoc:silent -val requestWithTimeout = - sometimesSlowRequest - .timeoutFail("took too long"): - 1.second + "Contract Breaches: $contractBreaches" ``` ```scala 3 mdoc:runzio:liveclock import zio.* import zio.direct.* -override val bootstrap = - Scenario: - requestWithTimeout - def run = - makeLotsOfRequests + makeLotsOfRequests: + Scenario(sometimesSlowRequest) ``` Sadly, we have breached our contract many times in this scenario. @@ -752,12 +718,9 @@ val hedged = import zio.* import zio.direct.* -override val bootstrap = - Scenario: - hedged - def run = - makeLotsOfRequests + makeLotsOfRequests: + Scenario(hedged) ``` ## Test Resilience diff --git a/examples b/examples index 7a923e5f..223a7cc7 160000 --- a/examples +++ b/examples @@ -1 +1 @@ -Subproject commit 7a923e5fb1cc9ae6492e6504f46fcbc5a1aa6658 +Subproject commit 223a7cc722d5d3756953c36a90e9f7d2461a0a9f