首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Vue单元测试错误: vuex需要此浏览器中的Promise polyfill

Vue单元测试错误: vuex需要此浏览器中的Promise polyfill
EN

Stack Overflow用户
提问于 2016-11-24 18:43:00
回答 3查看 7.7K关注 0票数 17

我使用vue-cli创建了一个项目,并在其中添加了vuexvue-router。我正在尝试为它设置一个单元测试,但是我得到了下面的错误。没有Vuex,它过去是可以工作的。

PhantomJS 2.1.1 (Mac 0.0.0)错误

错误: vuex vuex需要此浏览器中的Promise polyfill。

在webpack:/~/vuex/dist/vuex.js:145:0 <- index.js:9871

以下是相关的包版本:

代码语言:javascript
复制
"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:

代码语言:javascript
复制
// 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' }
      ]
    }
  })
}
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2016-11-24 18:57:47

使用巴别塔填充解决了这个问题。下面是我所做的步骤:

安装Babel Polyfill

代码语言:javascript
复制
npm install --save-dev babel-polyfill

然后,在karma.conf.jsfiles部分中,在源文件和测试文件之前包含polyfill文件

代码语言:javascript
复制
files: [
  '../node_modules/babel-polyfill/dist/polyfill.js',
  'index.js'
],
票数 26
EN

Stack Overflow用户

发布于 2017-01-10 13:40:12

如果您认为babel-polyfill太大,可以只包含es6-promise polyfill:

代码语言:javascript
复制
files: [
  '../node_modules/es6-promise/dist/es6-promise.auto.js',
  'index.js'
],

另一方面,如果您不确定站点访问者的浏览器是否具有内置的Promise支持,则可以在条目填充main.js中包含polyfill

代码语言:javascript
复制
import 'es6-promise/auto'

编辑:

好消息!Chrome can run in mode since version 59。所以你现在可以在无头的Chrome中运行你的单元测试,而不是PhantomJS。

对于vue-cli/webpack生成的项目,您可以执行以下步骤:

通过npm或

  • 安装karma-phantomjs-launcherkarma-phantomjs-shimphantomjs-prebuilt
  • 你也可以从你的项目中删除yarn。它们用于将browsers字段更改为['ChromeHeadless'],并从frameworks字段中删除'phantomjs-shim'

这是我的karma.conf.js,,不再填充polyfill:

代码语言:javascript
复制
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. Chrome59是最新的稳定版本,它支持大多数ES6功能,甚至一些来自ES7/8的功能,没有polyfill.
  2. PhantomJS自18个月前以来就没有更新过。由于ES规范变化如此之快,它不支持太多新功能。PhantomJS的作者
  3. 向discontinue.

宣布

票数 22
EN

Stack Overflow用户

发布于 2020-09-15 23:41:21

我的应用程序是用webpack创建的,我发现在internet explorer中加载我的应用程序并阻止这个错误的唯一方法是把这个脚本放在我的index.html的头部

代码语言:javascript
复制
    <!-- Script for polyfilling Promises on IE9 and 10 -->
    <script src='https://cdn.polyfill.io/v2/polyfill.min.js'></script>

我希望能帮上忙。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40784305

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档