javascript - 如何在 React Native 中使用 jest for constant 开始单元测试
问题描述
我是单元测试的新手,目前正在使用 Jest 为我的 TypeScript 应用程序编写单元测试。我正在使用一个名为common-packages
我存储所有常量的自定义包,像这样简单
const CLIENT_ID = 1231123123;
const TEXT = {
Discover:"Discover",
loading: 'loading',
Type: "Testing",
}
const Constants = {
TEXT,
CLIENT_ID,
} as const;
export default Constants;
在我的包裹 index.tsx 上。我出口Constant
export { default as Constants } from "./constants";
我要测试的功能是这个
import {Constants} from 'common-packages';
export const lockNextCardIfUncompleted = (data: any[]) => {
if (data.length !== 0) {
const locked = data.filter((e: any) => e.Type === Constants.TEXT.Type );
if (locked.length === 0) return false;
return true;
}
return false;
};
我已经尝试像这样为 lodash 编写单元测试并且它正在工作
const lodash = require('lodash')
test("repeat", () => {
expect(lodash.repeat("A",3)).toBe("AAA");
})
但是对于具有 common-packages 的单元测试,它失败了
import {
lockNextCardIfUncompleted,
} from './fileName';
test('should return locked', () => {
expect(
lockNextCardIfUncompleted([
{
Type: 'A',
},
]),
).toBe(false);
expect(
lockNextCardIfUncompleted([
{
Type: 'Testing,
},
]),
).toBe(true);
});
它返回TypeError: Cannot read property 'TEXT' of undefined
。所以测试没有从common-package
. 有人可以帮我解决这个问题吗?谢谢你
解决方案
推荐阅读
- mysql - 计算两个文本列中匹配字符数的 SQL 查询
- python - django 属性错误 ------>AttributeError: module 'django.contrib.auth.views' has no attribute 'login', 'logout'
- powerapps - 如何在 PowerApps 中取消选择选定的库?
- r - 添加第二个轴以绘图而不同时添加跟踪
- javascript - 使用手机时 Socket.io 不显示连接
- php - 通过部分名称和变量混合调用函数
- intellij-idea - IntelliJ 2019.3 为什么我看不到“下一步”按钮?原因是什么?
- powershell - Powershell 中用户输入的通配符功能
- reactjs - 如何使用 auth0 正确验证来自 React SPA 的 API 调用?
- canvas - 从 canvas.toDataURL() 创建图像 bloburl