Skip to content

Latest commit

 

History

History
65 lines (52 loc) · 1.57 KB

karma.md

File metadata and controls

65 lines (52 loc) · 1.57 KB

Using Enzyme with Karma

Karma is a popular test runner that can run tests in browser environments. Enzyme is compatible with Karma, but often requires a little bit of configuration.

This configuration largely depends on which plugins you are using to bundle your JavaScript code. In the case of Browserify or Webpack, see the below documentation in order to get these up and running.

Enzyme + Karma + Webpack

See the webpack guide.

/* karma.conf.js */

webpack: { //kind of a copy of your webpack config
  devtool: 'inline-source-map', //just do inline source maps instead of the default
  module: {
    loaders: [
      {
        test: /\.js$/,
        exclude: /\/node_modules\//,
        loader: 'babel',
        query: {
          presets: ['airbnb']
        }
      }
    ]
  },
  externals: {
    'cheerio': 'window',
    'react/addons': true,
    'react/lib/ExecutionEnvironment': true,
    'react/lib/ReactContext': true
  }
},

Enzyme + Karma + Browserify

See the browserify guide.

/* karma.conf.js */
browserify: {
  debug: true,
  transform: [
    ['babelify', { presets: ['airbnb'] }]
  ],
  configure: function(bundle) {
    bundle.on('prebundle', function() {
      bundle.external('react/addons');
      bundle.external('react/lib/ReactContext');
      bundle.external('react/lib/ExecutionEnvironment');
    });
  }
},

Example Projects