简体   繁体   English

配置 Jest 以支持 Typescript (NodeJs)

[英]configure Jest to support Typescript (NodeJs)

I would like to write tests for my Node/Express/Typescript application.我想为我的 Node/Express/Typescript 应用程序编写测试。 Next to my src directory I added a tests directory with a app.spec.ts file with this demo content在我的src目录旁边,我添加了一个带有app.spec.ts文件的测试目录,其中包含此演示内容

import { App } from '../src/app';

describe('App', () => {
    let instance: App;

    beforeEach(() => {
        instance = new App();
    });

    it('creates an instance of App', async () => {
        expect(instance).toBeInstanceOf(App);
    });
});

Unfortunately Jest is not able to handle Typescript.不幸的是,Jest 无法处理 Typescript。

Details:细节:

C:...\\tests\\app.spec.ts:1 ({"Object. ":function(module,exports,require,__dirname,__filename,global,jest){import { App } from '../src/app'; C:...\\tests\\app.spec.ts:1 ({"Object.":function(module,exports,require,__dirname,__filename,global,jest){import { App } from '../src/应用程序';

SyntaxError: Unexpected token { at ScriptTransformer._transformAndBuildScript (node_modules/@jest/transform/build/ScriptTransformer.js:471:17) at ScriptTransformer.transform (node_modules/@jest/transform/build/ScriptTransformer.js:513:25) SyntaxError: Unexpected token { at ScriptTransformer._transformAndBuildScript (node_modules/@jest/transform/build/ScriptTransformer.js:471:17) at ScriptTransformer.transform (node_modules/@jest/transform/build/ScriptTransformer.js:513:25)

This is my package.json (relavant fields)这是我的 package.json(相关字段)

{
  "scripts": {
    "start": "node dist/app.js",
    "dev": "nodemon src/app.ts",
    "build": "tsc -p .",
    "test": "jest",
    "testWithCoverage": "jest --coverage"
  },
  "devDependencies": {
    "@types/express": "^4.17.0",
    "@types/jest": "^24.0.17",
    "@types/node": "^12.6.9",
    "@typescript-eslint/eslint-plugin": "^1.13.0",
    "@typescript-eslint/parser": "^1.13.0",
    "eslint": "^5.16.0",
    "eslint-config-airbnb-base": "^13.2.0",
    "eslint-plugin-import": "^2.18.2",
    "jest": "^24.8.0",
    "nodemon": "^1.19.1",
    "ts-jest": "^24.0.2",
    "ts-node": "^8.3.0",
    "typescript": "^3.5.3"
  }
}

Further I created a jest.config.js file with that content此外,我创建了一个带有该内容的jest.config.js文件

module.exports = {
    roots: [
        './tests',
    ],
    moduleFileExtensions: [
        'ts',
        'tsx',
        'js',
        'jsx',
    ],
};

Does someone know what's missing here?有人知道这里缺少什么吗?

Change your jest.config.js file to:jest.config.js文件更改为:

module.exports = {
  "roots": [
    "<rootDir>/src",
    "<rootDir>/tests"
  ],
  "transform": {
    "^.+\\.tsx?$": "ts-jest"
  },
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM