如何解决如何使用 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
中的常量。有人可以帮我解决这个问题吗?
谢谢
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。