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

[Feature]: Add handler when tests are being retried #12600

Closed
ryana opened this issue Mar 24, 2022 · 7 comments
Closed

[Feature]: Add handler when tests are being retried #12600

ryana opened this issue Mar 24, 2022 · 7 comments

Comments

@ryana
Copy link

ryana commented Mar 24, 2022

🚀 Feature Proposal

I would like to know when tests are being retried. The retryTimes feature is great, but it can effectively hide the fact that a test is flakey. The ideal solution would allow for providing a handler that gets called whenever a test is retried, and would be passed the test name.

Note: I tried to use addEventHandler from state.js and watch for the test_retry event but I couldn't get it working after ~30 minutes of playing around.

Motivation

retryTimes is necessary when running E2E tests on larger apps, but it can hide flakey tests. On large teams running scores of builds in CI a day, being able to centralize recording those flakey tests can give valuable insight to help stabilize test suites.

Example

We could optionally augment retryTimes with a single handler:

jest.retryTimes(3, (testName) => console.log(`Retrying ${test name}`))

Or we could provide a list of handlers:

jest.retryTimes(3)
jest.addRetryHandler((testName) => console.log(`Retrying ${testName}`))
jest.addRetryHandler((testName) => metricsService.recordMetric(`test/retry/${testname}`, 1))

Pitch

Because I don't want to have to write my own runner to do this :) I want to keep using the default jest runner.

Also I don't know if this goes without saying, but I'm happy to do all the work here.

@github-actions
Copy link

This issue is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 30 days.

@github-actions github-actions bot added the Stale label Apr 23, 2022
@SimenB
Copy link
Member

SimenB commented Apr 24, 2022

We just landed #12201 yesterday, which adds optional logging, does that cover your use case? Note that this means you can use a custom reporter to do your recordMetric as the retry reasons are included in the test results.

That said, I think we now only pass the reasons if logging is enabled, that's probably the wrong way to do it... Might make more sense to always pass them, and just add some config to the reporter or something. Thoughts? (this is not shipped yet, but you can build the repo and play with it locally)

@github-actions github-actions bot removed the Stale label Apr 24, 2022
@mrazauskas
Copy link
Contributor

What if these retry errors would be logged as warnings by default? Also always passed to reporters. The option of jest.retryTimes() could disable the logging. All just the opposite to current implementation, which was authored as non-breaking. But isn't it that the opposite behaviour is more useful?

Still good time to do this. I can work, if the idea is acceptable.

@SimenB
Copy link
Member

SimenB commented Apr 24, 2022

I don't think we should log by default, but we should always pass the reasons in the test results. Not sure how to communicate logging being on or off, tho.

Separately, we should make sure test_retry event works

@github-actions
Copy link

This issue is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 30 days.

@github-actions github-actions bot added the Stale label May 24, 2022
@github-actions
Copy link

This issue was closed because it has been stalled for 7 days with no activity. Please open a new issue if the issue is still relevant, linking to this one.

@github-actions
Copy link

This issue has been automatically locked since there has not been any recent activity after it was closed. Please open a new issue for related bugs.
Please note this issue tracker is not a help forum. We recommend using StackOverflow or our discord channel for questions.

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Jul 24, 2022
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

3 participants