在对一个有一定规模的react前端项目执行jest单元测试时,遇到了如下问题:
node scripts/test.js –env=jsdom
错误信息
2020-02-04 11:05 node9117 FSEventStreamStart: register_with_server: ERROR: f2d_register_rpc() => (null) (-22)
2020-02-04 11:05 node9117 FSEventStreamStart: register_with_server: ERROR: f2d_register_rpc() => (null) (-22)
2020-02-04 11:05 node9117 FSEventStreamStart: register_with_server: ERROR: f2d_register_rpc() => (null) (-22)
events.js:174
throw er; // Unhandled ‘error’ event
^
Error: EMFILE: too many open files, watch
at FSEvent.FSWatcher._handle.onchange (internal/fs/watchers.js:123:28)
Emitted ‘error’ event at:
at FSEvent.FSWatcher._handle.onchange (internal/fs/watchers.js:129:12)
npm ERR! Test failed. See above for more details.
这个问题是由于Mac OSX对于打开文件数的限制所导致的,虽然可以直接sudo扩大这个打开文件数限制,但毕竟不是个很干净的解决方案,这里参考:https://github.com/facebook/create-react-app/issues/4540 所给出的建议,在命令行中通过brew安装一个叫watchman的东西,即可解决问题:
$ brew update
$ brew install watchman
没有brew的话也可以这样安装:
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
安装好后再次执行npm test就可以正常跑起单元测试了。
博主友情提示:
如您在评论中需要提及如QQ号、电子邮件地址或其他隐私敏感信息,欢迎使用>>博主专用加密工具v3<<处理后发布,原文只有博主可以看到。