我有一个React Native应用程序。我想用Jest添加单元测试。运行yarn test
时,出现以下错误:
FAIL ./App.test.tsx
● app › can render snapshot
ReferenceError: React is not defined
5 | describe("app", () => {
6 | it("can render snapshot", () => {
> 7 | const tree = renderer.create(<App />);
| ^
8 | expect(tree).toMatchSnapshot();
9 | });
10 | });
这是我的App.tsx
:
import React from "react";
import Amplify from "aws-amplify";
import awsmobile from "./src/aws-exports";
import AppContainer from "./src/navigation/index";
Amplify.configure(awsmobile);
const App = () => {
return (
<AppContainer />
);
};
这就是我的App.test.tsx
中的东西:
import "react-native";
import React from "react";
import renderer from "react-test-renderer";
import App from "./App";
describe("app", () => {
it("can render snapshot", () => {
const tree = renderer.create(<App />);
expect(tree).toMatchSnapshot();
});
});
还有,这是我的jest.config.js
:
// jest.config.js
const {defaults: tsjPreset} = require("ts-jest/presets");
module.exports = {
...tsjPreset,
preset: "react-native",
transform: {
...tsjPreset.transform,
"\\.js$": "<rootDir>/node_modules/react-native/jest/preprocessor.js",
},
globals: {
"ts-jest": {
babelConfig: true,
},
},
// This is the only part which you can keep
// from the above linked tutorial's config:
cacheDirectory: ".jest/cache",
moduleFileExtensions: [
"ios.js",
"native.js",
"js",
"json",
"jsx",
"node",
"ios.ts",
"native.ts",
"ts",
"tsx",
],
};
更新:
这是我的babel.config.js
:
module.exports = {
presets: ['module:metro-react-native-babel-preset'],
};
我遵循了here的说明。