Jest Test Babel Error: файлы Plugin/Preset не разрешены для экспорта объектов

Я использую очень актуальный (декабрь 2017 года) стек зависимостей. Когда я испытываю тесты изоморфного реагирования с помощью Jest, тестовый набор продолжает терпеть неудачу со следующей ошибкой:

* Test suite failed to run
[BABEL] /__tests__/router.test.js: Plugin/Preset files are not allowed to
export objects, only functions.

Вот мои зависимости:

"dependencies": {
    "axios": "^0.17.1",
    "babel-polyfill": "^6.26.0",
    "cors": "^2.8.4",
    "express": "^4.16.2",
    "react": "^16.1.1",
    "react-dom": "^16.1.1",
    "react-router-dom": "^4.2.2"
  },
  "devDependencies": {
    "@babel/core": "^7.0.0-beta.35",
    "babel-cli": "^6.26.0",
    "babel-core": "^7.0.0-bridge.0",
    "babel-eslint": "^8.0.2",
    "babel-jest": "^22.0.1",
    "babel-loader": "^7.1.2",
    "babel-preset-env": "^1.6.1",
    "babel-preset-react": "^6.24.1",
    "enzyme": "^3.2.0",
    "enzyme-adapter-react-16": "^1.1.0",
    "enzyme-to-json": "^3.2.2",
    "eslint": "^4.11.0",
    "eslint-plugin-react": "^7.5.1",
    "html-webpack-plugin": "^2.30.1",
    "jest": "^21.2.1",
    "nodemon": "^1.11.0",
    "parallelshell": "^3.0.2",
    "react-test-renderer": "^16.2.0",
    "regenerator-runtime": "^0.11.1",
    "supertest": "^3.0.0",
    "webpack": "^3.8.1",
    "webpack-dev-server": "^2.9.4"
  },
  "peerDependencies": {
    "babel-core": "^7.0.0-0"
  }

.babelrc:

{
  "presets": [
    "env",
    "react",
  ]
}

Кто-нибудь знает, почему Джест не сбежит?

Ответы

Ответ 1

  Babel Bridge предназначен для решения любых вопросов между 6 и 7

Это на 100% не то, что делает пакет bridge. Все, что он делает - позволяет инструментам, использующим babel-core, проходить к @babel/core. Весь пакет представляет собой эту строку кода.

Если вы используете @babel/core, вам нужно использовать плагины, которые работают на Babel 7. Это означает, что babel-preset-react следует изменить на @babel/preset-react и то же самое для @babel/preset-env, а ваш .babelrc должен быть:

{
  "presets": [
    "@babel/env",
    "@babel/react",
  ]
}

Аналогично, babel-polyfill должен быть @babel/polyfill.

Ничто из этого еще не задокументировано, потому что Babel 7 все еще является нестабильной бета-версией.

Ответ 2

{
    "presets": [
        "env",
        "react"
    ],
    "test": [
        "jest"
    ]
}

Добавьте последний блок кода для "теста" вам babel.rc Вот мой код .babelrc для справки

   {
    "presets": [
        "env",
        "react"
    ],
    "plugins": [
        "transform-class-properties",
        "transform-object-rest-spread"
    ],
    "test": [
        "jest"
    ]
}

Вот мой вывод из командной строки

Test Suites: 1 passed, 1 total
Tests:       1 passed, 1 total
Snapshots:   0 total
Time:        9.264s
Ran all test suites.
Done in 12.99s.

Ответ 3

  Я столкнулся с той же проблемой при настройке jest для работы с babel-6.

Смотрите полное объяснение здесь

Но в итоге, эта комбинация --devDependencies сработала для меня, и я настроил babel-jest для преобразования моих файлов **.js:

// package.json

  "devDependencies": {
    "babel-core": "6.26.0",
    "babel-jest": "21.2.0",
    "babel-loader": "7.1.2",
    "babel-preset-env": "1.6.0",
    "babel-preset-react": "6.24.1",
    "babel-preset-stage-0": "6.24.1",
    "jest": "21.2.1",
    "webpack": "3.6.0"
  },
  "jest": {
    "transform": {
      "^.+\\.jsx?$": "babel-jest"
    }
  }

// .babelrc

{
  "presets": [
    "env",
    "stage-0",
    "react"
  ]
}