Использование Benchmarkjs с Webpack и Babel

Я пытаюсь заставить работать некоторые базовые тесты, и у меня возникают проблемы с определением правильной конфигурации. Я пытаюсь использовать Benchmarkjs с webpack и babel для переноса моего кода в es5. Я создал benchmarks.webpack.js в качестве точки входа, которая выглядит следующим образом:

var context = require.context('./src/js', true, /-benchmark\.js$/);
context.keys().forEach(context);
module.exports = context;

Затем у меня есть файл теста, который я хочу запустить (test-benchmark.js):

import benchmark from 'benchmark';
import benchmarks from 'beautify-benchmark';

let suite = new benchmark.Suite;

suite.add('RegExp#test', function() {
  /o/.test('Hello World!');
})
.add('String#indexOf', function() {
  'Hello World!'.indexOf('o') > -1;
})
.on('cycle', function(event) {
  benchmarks.add(event.target);
})
.on('complete', function() {
  benchmarks.log();
})
.run();

Я обновил свою сборку веб-пакета, чтобы попытаться выполнить тестирование:

_.assign(config, {
  devtool: 'eval-cheap-module-source-map',
  output: {
    path: path.join(__dirname, 'build/benchmark'),
    filename: 'benchmark.js',
    publicPath: '/'
  },
  entry: [
    './benchmarks.webpack.js'
  ],
  plugins: [

  ],
  module: {
    loaders: [
      {
        test: /\.js$/,
        loaders: ['babel?stage=0'],
        include: path.join(__dirname, 'src/js')
      },
    ]
  },
});

Наконец, я хочу иметь возможность запустить это из сценария npm:

  "scripts": {
    "bench": "webpack --config webpack.bench.config.js && node build/benchmark/benchmark.js"
  },

Тем не менее, я получаю предупреждения о том, что результатом зависимости производительности является выражение, и нет подходящих загрузчиков для файлов.json,.txt и т. Д. Я попытался взломать Benchmarkjs для правильного экспорта, но безуспешно.

WARNING in ./~/benchmark/benchmark.js
Critical dependencies:
1122:34-49 the request of a dependency is an expression
 @ ./~/benchmark/benchmark.js 1122:34-49

WARNING in ./~/benchmark/package.json
Module parse failed: /home/bill/dev/levelstory/react-client-redux/node_modules/benchmark/package.json Line 2: Unexpected token :
You may need an appropriate loader to handle this file type.
| {
|   "name": "benchmark",
|   "version": "1.0.0",
|   "description": "A benchmarking library that works on nearly all JavaScript platforms, supports high-resolution timers, and returns statistically significant results.",
 @ ./~/benchmark ^\.\/.*$

WARNING in ./~/benchmark/LICENSE.txt
Module parse failed: /home/bill/dev/levelstory/react-client-redux/node_modules/benchmark/LICENSE.txt Line 1: Unexpected number
You may need an appropriate loader to handle this file type.
| Copyright 2010-2012 Mathias Bynens <http://mathiasbynens.be/>
| Based on JSLitmus.js, copyright Robert Kieffer <http://broofa.com/>
| Modified by John-David Dalton <http://allyoucanleet.com/>
 @ ./~/benchmark ^\.\/.*$

1 ответ

Похоже, тест делает что-то особенное с require, Это портит это для Webpack. Он имеет следующие строки:

var freeRequire = typeof require == 'function' && require;

...

function req(id) {
    try {
        var result = freeExports && freeRequire(id);
    } catch(e) { }
    return result || null;
}

Если вы закомментируете содержимое функции, ошибка исчезнет. Учитывая, что это не идеальное решение, я бы посоветовал ребятам прямо сейчас. Возможно, что-то нам не хватает.

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