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

Add side effect callbacks during retry #106

Merged
merged 8 commits into from
Mar 25, 2024
Merged

Add side effect callbacks during retry #106

merged 8 commits into from
Mar 25, 2024

Conversation

DybekK
Copy link
Contributor

@DybekK DybekK commented Mar 19, 2024

This PR addresses the proposed functionality in #56 and introduces enhancements to the retry mechanism by adding a onRetry function callback to the RetryPolicy class.

onRetry callback is executed after each retry attempt. It accepts two parameters: the attempt number and the result of the attempt. The result is represented as an Either type, where Left indicates an error and Right indicates a successful result. By default, this is an empty function.

@DybekK DybekK marked this pull request as ready for review March 19, 2024 15:03
@DybekK DybekK requested review from adamw, rucek and kciesielski March 19, 2024 15:03
Copy link
Member

@kciesielski kciesielski left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think we need the beforeEachAttempt part, can't see any good use case for it. Users can simply enrich their retried effect with effectBefore >> myEffect and retry such composite effect. Adding this to the retry API could the flow a bit confusing. The cats-retry library offers a onError: (E, RetryDetails) => M[Unit] callback, and I think we should be fine with a similar thing. Wdyt @rucek @DybekK?

Copy link
Contributor

@rucek rucek left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some minor coments, but overall LGTM.

Comment on lines 49 to 51
afterEachAttemptInvoked shouldBe true
afterEachAttemptInvocationCount shouldBe 1
returnedResult shouldBe Right(successfulResult)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Aren't those assertions redundant? If you verify that the callback was invoked once, I guess one of them would be sufficient. Same for the "before" callback.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • onRetryInvoked shouldBe true can be removed, since checking the invocation count would be sufficient enough.
  • returnedResult shouldBe Right(successfulResult) should not be removed. It checks whether the second parameter of the onRetry function has been given the correct result, in this case, Right(successfulResult). If this assertion fails, it indicates that the onRetry function wasn't given the correct result, and this oversight could potentially allow bugs to go unnoticed.

core/src/test/scala/ox/retry/RetryLifecycleTest.scala Outdated Show resolved Hide resolved
@tailrec
def loop(attempt: Int, remainingAttempts: Option[Int], lastDelay: Option[FiniteDuration]): F[T] =
def sleepIfNeeded =
val delay = policy.schedule.nextDelay(attempt + 1, lastDelay).toMillis
if (delay > 0) Thread.sleep(delay)
delay

lifecycle.beforeEachAttempt(attempt + 1)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm wondering if we could just number the attempts starting from 1 instead of 0 - WDYT?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree. In my opinion, it is more intuitive to read the code if we get rid of attempt + 1 in some places.

@rucek
Copy link
Contributor

rucek commented Mar 20, 2024

Users can simply enrich their retried effect with effectBefore >> myEffect and retry such composite effect

@kciesielski the difference would be that effectBefore won't be aware of the attempt number, but beforeEachAttempt will. Not sure about an actual use case for that though.

@kciesielski
Copy link
Member

Yes, I'm aware of that difference, but I can't see the usefulness of this attempt number in such a case. I think we should choose a simpler API and sacrifice it.

@DybekK
Copy link
Contributor Author

DybekK commented Mar 20, 2024

I don't think we need the beforeEachAttempt part, can't see any good use case for it. Users can simply enrich their retried effect with effectBefore >> myEffect and retry such composite effect. Adding this to the retry API could the flow a bit confusing. The cats-retry library offers a onError: (E, RetryDetails) => M[Unit] callback, and I think we should be fine with a similar thing. Wdyt @rucek @DybekK?

I completely removed RetryLifecycle class and replaced it with just onRetry function callback.

@DybekK DybekK requested review from rucek and kciesielski March 20, 2024 11:21
@adamw adamw merged commit 072f61c into master Mar 25, 2024
5 checks passed
@adamw adamw deleted the retry-side-effects branch March 25, 2024 10:11
@adamw
Copy link
Member

adamw commented Mar 25, 2024

Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants