Ошибка тестового модуля Vue: vuex требует полифилла Promise в этом браузере

Я создал проект, используя vue-cli и добавил vuex а также vue-router в этом. Я пытаюсь настроить юнит-тест для него, но я получаю следующую ошибку. Без Vuex раньше работало.

PhantomJS 2.1.1 (Mac OS X 0.0.0) ОШИБКА

Ошибка: [vuex] vuex требует многозаполнения Promise в этом браузере.

в веб-пакете:///~/vuex/dist/vuex.js:145:0 <- index.js: 9871

Ниже приведены соответствующие версии пакета:

"babel-core": "^6.0.0",
"babel-eslint": "^7.0.0",
"babel-loader": "^6.0.0",
"vue": "^2.1.0",
"vue-router": "^2.0.3",
"vuex": "^2.0.0",
"vuex-router-sync": "^3.0.0"
"karma": "^1.3.0",
"karma-coverage": "^1.1.1",
"karma-mocha": "^1.2.0",
"karma-phantomjs-launcher": "^1.0.0",
"karma-sinon-chai": "^1.2.0",
"karma-sourcemap-loader": "^0.3.7",
"karma-spec-reporter": "0.0.26",
"karma-webpack": "^1.7.0",
"webpack": "^1.13.2",
"webpack-dev-middleware": "^1.8.3",
"webpack-hot-middleware": "^2.12.2",
"webpack-merge": "^0.14.1"

Ниже приводится karma.conf.js:

// This is a karma config file. For more details see
//   http://karma-runner.github.io/0.13/config/configuration-file.html
// we are also using it with karma-webpack
//   https://github.com/webpack/karma-webpack

var path = require('path')
var merge = require('webpack-merge')
var baseConfig = require('../../build/webpack.base.conf')
var utils = require('../../build/utils')
var webpack = require('webpack')
var projectRoot = path.resolve(__dirname, '../../')

var webpackConfig = merge(baseConfig, {
  // use inline sourcemap for karma-sourcemap-loader
  module: {
    loaders: utils.styleLoaders()
  },
  devtool: '#inline-source-map',
  vue: {
    loaders: {
      js: 'isparta'
    }
  },
  plugins: [
    new webpack.DefinePlugin({
      'process.env': require('../../config/test.env')
    })
  ]
})

// no need for app entry during tests
delete webpackConfig.entry

// make sure isparta loader is applied before eslint
webpackConfig.module.preLoaders = webpackConfig.module.preLoaders || []
webpackConfig.module.preLoaders.unshift({
  test: /\.js$/,
  loader: 'isparta',
  include: path.resolve(projectRoot, 'src'),
  exclude: /test\/unit|node_modules/
})

// only apply babel for test files when using isparta
webpackConfig.module.loaders.some(function (loader, i) {
  if (loader.loader === 'babel') {
    loader.include = path.resolve(projectRoot, 'test/unit')
    return true
  }
})

module.exports = function (config) {
  config.set({
    // to run in additional browsers:
    // 1. install corresponding karma launcher
    //    http://karma-runner.github.io/0.13/config/browsers.html
    // 2. add it to the `browsers` array below.
    browsers: ['Chrome'],
    frameworks: ['mocha', 'sinon-chai'],
    reporters: ['spec', 'coverage'],
    files: ['./index.js'],
    preprocessors: {
      './index.js': ['webpack', 'sourcemap']
    },
    webpack: webpackConfig,
    webpackMiddleware: {
      noInfo: true
    },
    coverageReporter: {
      dir: './coverage',
      reporters: [
        { type: 'lcov', subdir: '.' },
        { type: 'text-summary' }
      ]
    }
  })
}

2 ответа

Решение

Использование вавилонского полифилла решило проблему. Вот шаги, которые я сделал:

Установка Babel Polyfill:

npm install --save-dev babel-polyfill

затем включите файл polyfill перед вашими исходными и тестовыми файлами в files раздел вашего karma.conf.js:

files: [
  '../node_modules/babel-polyfill/dist/polyfill.js',
  'index.js'
],

Если вы думаете, что babel-polyfill слишком велик, вы можете просто включить esf-обещание polyfill:

files: [
  '../node_modules/es6-promise/dist/es6-promise.auto.js',
  'index.js'
],

С другой стороны, если вы не уверены, есть ли встроенные в браузеры посетителей вашего сайта Promise поддержка, вы можете включить polyfill в вашу запись, main.js:

import 'es6-promise/auto'

РЕДАКТИРОВАТЬ:

Хорошие новости! Chrome может работать в автономном режиме начиная с версии 59. Так что теперь вы можете запускать свои юнит-тесты в Chrome без PhantomJS.

Для проектов, сгенерированных vue-cli/webpack, вы можете выполнить следующие шаги:

  • Установите karma-chrome-launcher через npm или пряжу.
  • Вы также можете удалить karma-phantomjs-launcher, karma-phantomjs- shim, phantomjs-prebuilt из вашего проекта. Они для PhantomJS.
  • В test/unit/karma.conf.js измените browsers поле для ['ChromeHeadless'] и удалить 'phantomjs-shim' от frameworks поле.

Вот мой karma.conf.js, больше не заполнение:

var webpackConfig = require('../../build/webpack.test.conf')

module.exports = function(config) {
  config.set({
    // to run in additional browsers:
    // 1. install corresponding karma launcher
    //    http://karma-runner.github.io/0.13/config/browsers.html
    // 2. add it to the `browsers` array below.
    browsers: ['ChromeHeadless'],
    frameworks: ['mocha', 'sinon-chai'],
    reporters: ['spec', 'coverage'],
    files: ['./index.js'],
    preprocessors: {
      './index.js': ['webpack', 'sourcemap']
    },
    webpack: webpackConfig,
    webpackMiddleware: {
      noInfo: true
    },
    coverageReporter: {
      dir: './coverage',
      reporters: [
        { type: 'lcov', subdir: '.' },
        { type: 'text-summary' }
      ]
    }
  })
}

Причина для этого:

  1. Chrome 59 является последней стабильной версией, он поддерживает большинство функций ES6, даже некоторые из ES7/8, без polyfill.
  2. PhantomJS не обновлялся около 18 месяцев назад. Он не поддерживает много новых функций, так как спецификации ES движутся так быстро.
  3. Автор PhantomJS объявил о прекращении.

Мое приложение было создано с помощью webpack, и единственный способ, который я нашел, загрузить свое приложение в Internet Explorer и остановить эту ошибку, заключался в том, чтобы поместить этот скрипт в заголовок моего index.html


    <!-- Script for polyfilling Promises on IE9 and 10 -->
    <script src='https://cdn.polyfill.io/v2/polyfill.min.js'></script>

Надеюсь помочь.

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