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

Odd behavior in watch mode between "Enter" and "save" with React #10091

Closed
kentcdodds opened this issue May 26, 2020 · 7 comments
Closed

Odd behavior in watch mode between "Enter" and "save" with React #10091

kentcdodds opened this issue May 26, 2020 · 7 comments

Comments

@kentcdodds
Copy link
Contributor

🐛 Bug Report

To Reproduce

Steps to reproduce the behavior:

git clone https://github.com/kentcdodds/jest-save-enter
cd jest-save-enter
npm install
npm run test

Then open the example.test.js and save it a few times until you notice the issue. The test passes, but every now and then, we'll get a console.error from React.

Here's the code in the example.test.js file:

const React = require('react')
const ReactDOM = require('react-dom')
const {act} = require('react-dom/test-utils')

function Comp() {
  const [state, setState] = React.useState()
  React.useEffect(() => {
    setTimeout(() => {
      console.log('updating state')
      setState('blah')
    })
  }, [state])
  return null
}

test('example', async () => {
  const container = document.createElement('div')

  // using `act` is required to get effect callbacks run when rendering components
  // (React Testing Library does this automatically)
  act(() => {
    ReactDOM.render(React.createElement(Comp), container)
  })

  // the `cleanup` function from React Testing Library (which also happens automatically)
  // flushes all the in-flight effects by waiting for the next tick of the event loop
  // this is basically a simplified version of: https://github.com/facebook/react/blob/master/packages/shared/enqueueTask.js
  await new Promise((resolve) => setImmediate(resolve))

  // this is the last thing that happens in cleanup (to avoid memory leaks)
  ReactDOM.unmountComponentAtNode(container)
}

And here's some output:

When it works

image

Without changing anything, sometimes this happens

image

Expected behavior

I expect the output to be consistent.

Link to repl or repo (highly encouraged)

https://github.com/kentcdodds/jest-save-enter

This issue is best explained in video form (5 minutes): https://youtu.be/hRxf6QUwkow

envinfo

  System:
    OS: macOS 10.15.4
    CPU: (16) x64 Intel(R) Core(TM) i9-9980HK CPU @ 2.40GHz
  Binaries:
    Node: 12.13.1 - ~/n/bin/node
    Yarn: 1.21.1 - ~/.yarn/bin/yarn
    npm: 6.14.5 - /usr/local/bin/npm
  npmPackages:
    jest: ^26.0.1 => 26.0.1 

I honestly have no idea what's going on here, but I definitely observe this happening sometimes in less contrived examples.

Related issues:

@avegancafe
Copy link

avegancafe commented May 27, 2020

Looks like it may have to do with the setTimeout, I was able to modify the test to make sure it's using fake timers when it's rendering to seemingly remove the randomness from it-- no idea if this is the best solution, but it's worked for me so far! haha kentcdodds/jest-save-enter#1

@kentcdodds
Copy link
Contributor Author

Thanks, but changing the test is irrelevant. The fact jest is inconsistent with this is the bug in jest.

@github-actions
Copy link

This issue is stale because it has been open for 1 year 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 Feb 17, 2023
@eps1lon
Copy link
Contributor

eps1lon commented Feb 17, 2023

a

@github-actions github-actions bot removed the Stale label Feb 17, 2023
Copy link

This issue is stale because it has been open for 1 year 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 Feb 17, 2024
Copy link

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

@github-actions github-actions bot closed this as not planned Won't fix, can't repro, duplicate, stale Mar 18, 2024
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 Apr 18, 2024
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

4 participants