Jest - SyntaxError: Неожиданный идентификатор - PullRequest
3 голосов
/ 11 марта 2019

Выполнение некоторого тестирования некоторых функций NodeJS с использованием Jest, но ему не нравятся операторы import, например. import DatabaseController from '../util/database-controller'.

Я немного читаю, и люди предложили установить babel-jest и обновить мой конфиг (ниже), но мне не повезло. Что мне не хватает? Из того, что я понимаю, он не понимает import утверждений, поскольку это es6 вещь ...

Шутливая часть моего package.json:

"jest": {
    "collectCoverageFrom": [
      "src/**/*.{js,jsx}"
    ],
    "resolver": "jest-pnp-resolver",
    "setupFiles": [
      "react-app-polyfill/jsdom"
    ],
    "testMatch": [
      "<rootDir>/**/__tests__/**/*.{js,jsx}",
      "<rootDir>/**/?(*.)(spec|test).{js,jsx}"
    ],
    "testEnvironment": "jsdom",
    "testURL": "http://localhost",
    "transform": {
      "^.+\\.jsx?$": "babel-jest",
      "^.+\\.css$": "<rootDir>/config/jest/cssTransform.js",
      "^(?!.*\\.(js|jsx|css|json)$)": "<rootDir>/config/jest/fileTransform.js"
    },
    "transformIgnorePatterns": [
      "[/\\\\]node_modules[/\\\\].+\\.(js|jsx)$",
      "^.+\\.module\\.(css|sass|scss)$"
    ],
    "moduleNameMapper": {
      "^react-native$": "react-native-web",
      "^.+\\.module\\.(css|sass|scss)$": "identity-obj-proxy"
    },
    "moduleFileExtensions": [
      "web.js",
      "js",
      "json",
      "web.jsx",
      "jsx",
      "node"
    ]
  },

1 Ответ

0 голосов
/ 28 апреля 2019

В последнее время я нахожу, что мне вообще не нужно babel-jest, и я могу обойтись просто с помощью @babel/preset-env и следующих .babelrc:

{
  "env": {
    "test": {
      "presets": [["@babel/preset-env"]]
    }
  }
}
...