Mat*_*ble 2 jestjs react-native
setupJest.js在运行 React Native 测试之前,我使用了以下文件。
// Required to correctly polyfill React-Native
import { configure } from 'enzyme';
import Adapter from 'enzyme-adapter-react-16';
configure({ adapter: new Adapter() });
global.XMLHttpRequest = jest.fn();
global.fetch = jest.fn();
if (typeof window !== 'object') {
global.window = global;
global.window.navigator = {};
}
const EventEmitter = require('EventEmitter');
const RCTDeviceEventEmitter = require('RCTDeviceEventEmitter');
class NativeEventEmitter extends EventEmitter {
constructor() {
super(RCTDeviceEventEmitter.sharedSubscriber);
}
}
Run Code Online (Sandbox Code Playgroud)
这是一个示例测试:
/**
* @format
*/
import 'react-native';
import React from 'react';
import App from '../App';
// Note: test renderer must be required after react-native.
import renderer from 'react-test-renderer';
jest.mock('NativeEventEmitter');
it('renders correctly', () => {
renderer.create(<App />);
});
Run Code Online (Sandbox Code Playgroud)
这适用于 React Native 0.60.x。但是,使用 React Native 0.61.0,我收到以下错误:
Cannot find module 'EventEmitter' from 'setupJest.js'
Run Code Online (Sandbox Code Playgroud)
如果我更改我的导入以匹配文件所在的位置node_modules,我不会得到更多。
const EventEmitter = require('react-native/Libraries/vendor/emitter/EventEmitter');
const RCTDeviceEventEmitter = require('react-native/Libraries/EventEmitter/RCTDeviceEventEmitter');
Run Code Online (Sandbox Code Playgroud)
知道如何更新我的代码以使其适用于 React Native 0.61.0 吗?
Cannot find module 'NativeEventEmitter' from 'App-test.js'
10 | import renderer from 'react-test-renderer';
11 |
> 12 | jest.mock('NativeEventEmitter');
| ^
13 |
14 | it('renders correctly', () => {
15 | renderer.create(<App />);
at Resolver.resolveModule (node_modules/jest-resolve/build/index.js:259:17)
at Object.<anonymous> (tests/App-test.js:12:1)
Run Code Online (Sandbox Code Playgroud)
您可以通过克隆以下 repo 并运行其测试来重现此问题:
git clone -b react-native-61 https://github.com/mraible/samples-js-react-native.git
cd samples-js-react-native/browser-sign-in
npm i
npm test
Run Code Online (Sandbox Code Playgroud)
小智 8
RN 库具有NativeEventEmitter该类的模拟实现。只需从 setupJest.js 中删除以下代码:
const EventEmitter = require('EventEmitter');
const RCTDeviceEventEmitter = require('RCTDeviceEventEmitter');
class NativeEventEmitter extends EventEmitter {
constructor() {
super(RCTDeviceEventEmitter.sharedSubscriber);
}
}
Run Code Online (Sandbox Code Playgroud)
并在您的测试文件中设置模拟:
jest.mock(
'../node_modules/react-native/Libraries/EventEmitter/NativeEventEmitter',
);
Run Code Online (Sandbox Code Playgroud)
不要忘记删除:
jest.mock('NativeEventEmitter');
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1782 次 |
| 最近记录: |