如何解决Webpack 2和Karma MemoryFileSystem错误?

时间:2017-03-29 01:52:20

标签: reactjs webpack karma-webpack

我试图在一个非常简单的反应应用程序中设置karma与webpack运行但是因为更新到webpack 2所以我得到的是运行我的测试时的错误。编译react应用程序完美地工作。我的webpack或karma配置中可能导致此问题的任何内容?

这是我的错误:

> NODE_ENV=test karma start


START:
(node:1370) DeprecationWarning: loaderUtils.parseQuery() received a non-string value which can be problematic, see https://github.com/webpack/loader-utils/issues/56
parseQuery() will be replaced with getOptions() in the next major version of loader-utils.
Error
    at MemoryFileSystem.mkdirpSync (/Users/rperez/devProjects/CamperLeaderBoard/node_modules/memory-fs/lib/MemoryFileSystem.js:144:10)
    at MemoryFileSystem.(anonymous function) [as mkdirp] (/Users/rperez/devProjects/CamperLeaderBoard/node_modules/memory-fs/lib/MemoryFileSystem.js:279:34)
    at Compiler.<anonymous> (/Users/rperez/devProjects/CamperLeaderBoard/node_modules/webpack/lib/Compiler.js:322:27)
    at /Users/rperez/devProjects/CamperLeaderBoard/node_modules/webpack/node_modules/async/dist/async.js:3022:16
    at eachOfArrayLike (/Users/rperez/devProjects/CamperLeaderBoard/node_modules/webpack/node_modules/async/dist/async.js:941:9)
    at eachOf (/Users/rperez/devProjects/CamperLeaderBoard/node_modules/webpack/node_modules/async/dist/async.js:991:5)
    at Object.eachLimit (/Users/rperez/devProjects/CamperLeaderBoard/node_modules/webpack/node_modules/async/dist/async.js:3086:3)
    at Compiler.emitFiles (/Users/rperez/devProjects/CamperLeaderBoard/node_modules/webpack/lib/Compiler.js:312:20)
    at Immediate.<anonymous> (/Users/rperez/devProjects/CamperLeaderBoard/node_modules/memory-fs/lib/MemoryFileSystem.js:288:4)
    at runCallback (timers.js:651:20)
    at tryOnImmediate (timers.js:624:5)
    at processImmediate [as _immediateCallback] (timers.js:596:5)

依赖关系:

"dependencies": {
    "axios": "^0.15.3",
    "express": "^4.15.2",
    "react": "^15.4.2",
    "react-dom": "^15.4.2",
    "react-router": "^3.0.2"
  },
  "devDependencies": {
    "babel-core": "^6.23.1",
    "babel-loader": "^6.4.0",
    "babel-preset-es2015": "^6.22.0",
    "babel-preset-react": "^6.23.0",
    "babel-preset-stage-0": "^6.22.0",
    "css-loader": "^0.26.2",
    "expect": "^1.20.2",
    "foundation-sites": "^6.3.1",
    "jquery": "^3.1.1",
    "karma": "^1.5.0",
    "karma-chrome-launcher": "^2.0.0",
    "karma-mocha": "^1.3.0",
    "karma-mocha-reporter": "^2.2.2",
    "karma-sourcemap-loader": "^0.3.7",
    "karma-webpack": "^2.0.2",
    "mocha": "^3.2.0",
    "node-sass": "^4.5.0",
    "react-addons-test-utils": "^15.4.2",
    "sass-loader": "^6.0.2",
    "script-loader": "^0.7.0",
    "style-loader": "^0.13.2",
    "webpack": "^2.2.1"
  }

webpack config:

    const webpack = require('webpack');
    const path = require('path');

    //will be set to 'production on heroku'
    //process.env.NODE_ENV = process.env.NODE_ENV || 'development';

    module.exports = {
      //where to start the app
      entry: {
        app: path.resolve(__dirname, 'app/app.jsx'),
      },
      output: {
        path: path.resolve(__dirname, './public'),
        filename: '[name].bundle.js'
      },
      //setting up the babel loader to handle jsx files(es2015)
      module: {
        rules: [
          {
            test: /\.jsx?$/,
            exclude: /(node_modules|bower_componets)/,
            use: [{
              loader: 'babel-loader',
              options: {presets:['react', 'es2015', 'stage-0']}
            }],
          },
        ],
      },//end of modules
      resolve: {
        //Tell webpack what directories should be searched when resolving modules.
        modules: [
          path.join(__dirname, 'app/components'),
          path.join(__dirname, 'app/api'),
          'node_modules',
        ],
        //Automatically resolve certain extensions.
        extensions: ['.js', '.jsx', '.json'],
      }, //end of resolve
      //This option controls if and how Source Maps are generated.
      devtool:'cheap-module-eval-source-map'
    };//end of module.exports

karma config:

var webpackConfig = require('./webpack.config.js');

module.exports = function (config) {
  config.set({
    browsers: ['Chrome'],
    singleRun: true,
    frameworks: ['mocha'],
    files: [
      './app/tests/**/*.test.jsx'
    ],
    preprocessors: {
      './app/tests/**/*.test.jsx': ['webpack', 'sourcemap']
    },
    reporters: ['mocha'],
    client: {
      mocha: {
        timeout: '5000'
      }
    },
    webpack: webpackConfig,
    webpackServer: {
      noInfo: true
    }
  })

1 个答案:

答案 0 :(得分:1)

我的问题是我需要从webpack.config中删除“entry”属性。我这样做是通过添加以下代码来实现的:

webpackConfig.entry = null;

感谢启蒙的这篇文章: Error: not a directory at MemoryFileSystem.mkdirpSync