Jest не может импортировать модули TS / TSX

Когда я пытаюсь импортировать модули машинописи в мои модульные тесты, я получаю сообщение об ошибке Unable to resolve path to module 'src/js/TestNum', У него нет той же проблемы, выполняющей одинаковый импорт из файлов js / jsx.

В прошлом, когда у меня были проблемы с импортом модулей машинописи, он жаловался на неожиданную синтаксическую ошибку токена.

TestNum.ts

export const TestNum1 = 5;
export const TestNum2 = 10;

TestStr.js

export const TestStr1 = '5';
export const TestStr2 = '10';

test.js

/* global describe test */
import expect from 'expect';
import { TestNum1 } from 'src/js/TestNum';
import { TestStr1 } from 'src/js/TestStr';

describe('example', () => {
  test('if constant is 5', () => {
    expect(TestNum1).toEqual(5);
  });
  test('if constant is "5"', () => {
    expect(TestStr1).toEqual(5);
  });
});

В vscode, если я нажму на неудачный импорт и нажму F2, он перейдет к определению импорта.

package.json

{
  "devDependencies": {
    "@types/react": "^16.8.18",
    "@types/react-dom": "^16.8.4",
    "babel-jest": "^24.8.0",
    "babel-plugin-graphql-tag": "1.6.0",
    "child_process": "^1.0.2",
    "enzyme": "^3.9.0",
    "enzyme-adapter-react-16": "^1.13.1",
    "expect": "^24.8.0",
    "grunt": "0.4.5",
    "grunt-exec": "^3.0.0",
    "jest": "^23.4.1",
    "jest-config": "^24.8.0",
    "jest-html-reporter": "^2.5.0",
    "load-grunt-config": "^1.0.2",
    "react-test-renderer": "^16.8.6",
    "sinon": "^7.3.2",
    "ts-jest": "23.10.5",
    "typescript": "^3.4.5"
  },
  "scripts": {
    "start": "start-dev-shell",
    "stop": "stop-dev-shell",
    "restart": "restart-dev-shell"
  },
  "dependencies": {
    "react": "^16.8.6",
    "react-dom": "^16.8.6"
  }
}

jest.config.js

const { defaults } = require('jest-config');

module.exports = {
  coverageDirectory: 'build/test-results/code-coverage-reports',
  moduleFileExtensions: [...defaults.moduleFileExtensions, 'ts', 'tsx', 'js', 'jsx'],
  moduleNameMapper: {
    '\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$': '<rootDir>/__mocks__/fileMock.js',
    '\\.(css|less|scss)$': '<rootDir>/__mocks__/styleMock.js'
  },
  'reporters': ['default', ['./node_modules/jest-html-reporter', { 'pageTitle': 'Test Report' }]],
  setupFiles: ['<rootDir>/jest.setup.js'],
  testPathIgnorePatterns: [
    '<rootDir>/node_modules/',
    '<rootDir>/build-utils/',
    '<rootDir>/dist/',
    '<rootDir>/build/',
    '<rootDir>/__mocks__/'
  ],
  testRegex: 'test/unit/.+Tests?\\.(js|ts|jsx|tsx)?', //updated to grab ts/tsx tests
  transform: {
    '^.+\\.jsx?$': 'babel-jest',
    '^.+\\.tsx?$': 'ts-jest'
  },
  modulePaths: ['<rootDir>']
};

редактировать

Одна новая вещь, которую я обнаружил после игры на основе комментариев, заключалась в том, что если я переключу свой тест на тест с набором текста, то он не сможет найти мой модуль, если на него ссылаются из src вместо относительного пути ../../src, Это также предотвратит переход среды IDE к определению.

0 ответов

Другие вопросы по тегам