首页 > 解决方案 > ..._1.default 在使用 Mocha 测试 TypeScript 时不是构造函数

问题描述

我正在尝试使用 mocha 进行单元测试。我正在使用打字稿,它被编译成带有 tsc 的纯 javascript。我总是收到错误:

    src\index.ts:22
        [new FrontendEndpoint(), ...],
         ^
    TypeError: v1_1.default is not a constructor

我采用了两种方法(两次遇到同样的问题):

首先,我创建了一个虚拟测试test.test.ts,导入我的一些模块用于测试目的:


    import { APIServer } from './../api/index';
    import { describe } from 'mocha';
    import FrontendEndpoint from '../api/endpoints/frontend/v1';
    import { SocketConnector } from '../api/sockets/socketio';

    describe('TestTest', () => {
        it('should run', (done) => {
            const server = new APIServer(4000, [new FrontendEndpoint()], new SocketConnector([]));
            done();
        });
    });

  1. 使用 ts-mocha

    • 安装了 ts-mocha、mocha、@types/mocha
    • ts-mocha src/test/test.test.ts
  2. 使用 mocha 和编译的 ts 文件

    • 已安装 mocha,@types/mocha
    • mocha build/test/test.test.js

两种方式都会产生上述错误。

index.ts看起来像这样:


    import FrontendEndpoint from './api/endpoints/frontend/v1';
    [...]
    new FrontendEndpoint()

编译(index.js):


    [...]
    const v1_1 = require("./api/endpoints/frontend/v1");
    [...]
    new v1_1.default()

并且frontend/v1.ts


    export default class FrontendEndpoint {
        [...]
    }

编译(v1.js):


    class FrontendEndpoint {
        [...]
    }
    exports.default = FrontendEndpoint;

我的 tsconfig 看起来像这样:

{
    "compilerOptions": {
        "target": "es2015",
        "module": "commonjs",
        "moduleResolution": "node",
        "sourceMap": true,
        "noImplicitReturns": true,
        "noImplicitAny": true,
        "preserveConstEnums": true,
        "strictPropertyInitialization": false,
        "experimentalDecorators": true,
        "typeRoots": [
            "src/types"
        ],
        "emitDecoratorMetadata": true,
        "sourceRoot": "src",
        "outDir": "build"
    },
    "compileOnSave": true,
    "exclude": [
        "node_modules",
        "coverage",
        "build",
        "logs"
    ],
}

似乎只有默认导出存在问题。为什么它们不能按预期工作?当使用node build/index.js一切正常运行应用程序时,默认导出/导入按预期工作。

尝试使用 Webpack、Mocha 和 Jest 将单元测试添加到我的前端 React 应用程序时,我遇到了同样的问题。我完全错过了什么吗?

标签: javascripttypescripttestingmocha.js

解决方案


我自己找到了解决方案。

在调试我的测试时,我发现一些导出没有被调用。这是由于文件的循环依赖性导致它们无法正确导出。

在使用https://github.com/pahen/madge找到这些循环并解决它们之后,运行测试就可以正常工作了。


推荐阅读