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

Fix runOnlyPendingTimers for setTimeout inside setImmediate #4608

Merged
merged 1 commit into from
Oct 5, 2017

Conversation

thymikee
Copy link
Collaborator

@thymikee thymikee commented Oct 5, 2017

Summary

Nested calls to timer mocks (setTimeout/setInterval) inside setImmediate were unreliable with jest.runOnlyPendingTimers.

To fix this, we need to store the timers object before executing immediates – simply clone timers (assigning will hold the reference) at the very beginning of jest.runOnlyPendingTimers so we're sure we're going to run only pending timers :D. Otherwise the timers object gets populated with timers that should not be there yet.

Fixes #3048

Test plan

Updated the existing test to support currently failing case

@github-actions
Copy link

This pull request 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 May 11, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

runOnlyPendingTimers running nested timer under setImmediate
3 participants