use*_*075 5 node.js typescript karma-runner webpack
我正在尝试将其rewire与Karma(Webpack + Typescript)单元测试一起使用。我的单元测试是用Typescript编写的,与Webpack捆绑在一起,然后与Karma一起运行。我不断收到错误:
PhantomJS 2.1.1 (Windows 7 0.0.0) ERROR
Error: Cannot find module "module"
at src/myTest.spec.ts:187
Run Code Online (Sandbox Code Playgroud)
我查看了Rewire的代码,问题出在线路上
var Module = require("module"),
Run Code Online (Sandbox Code Playgroud)
我知道有一个Webpack Rewire插件,但是当我使用它时,我遇到的问题与Issue中已经报告的问题相同。
我所有不使用的测试都可以rewire正常工作。
这是我的测试文件:
import rewire = require("rewire");
const decorators = rewire("./decorators");
describe('something', () => {
it('should do something', () => {
decorators.__set__('Test', () => 'hello');
// In know this is pointless, but it's just to make sure that rewire works.
expect(decorators.Test).toBe('hello');
});
});
Run Code Online (Sandbox Code Playgroud)
这是我的webpack配置:
var webpack = require('webpack');
var path = require('path');
var fs = require('fs');
var nodeModules = {};
fs.readdirSync('node_modules')
.filter(function (x) {
return ['.bin'].indexOf(x) === -1;
})
.forEach(function (mod) {
nodeModules[mod] = 'commonjs ' + mod;
});
// Our Webpack Defaults
var webpackConfig = {
entry: './src/index.ts',
target: 'node',
module: {
loaders: [
{test: /\.ts$/, loaders: ['ts-loader'], exclude: /node_modules/}
]
},
plugins: [
new webpack.BannerPlugin({banner: 'require("source-map-support").install();', raw: true, entryOnly: false}),
new webpack.optimize.UglifyJsPlugin({sourceMap: true}),
new webpack.optimize.AggressiveMergingPlugin(),
],
output: {
path: path.resolve(__dirname, './dist'),
filename: 'index.js',
sourceMapFilename: 'index.map'
},
externals: nodeModules,
devtool: 'source-map',
resolve: {
extensions: ['.ts', '.js']
}
};
module.exports = webpackConfig;
Run Code Online (Sandbox Code Playgroud)
这是我(相关的)部分karma.conf.js:
frameworks: ['jasmine'],
files: [
'src/**/*.spec.ts',
'test/**/*.ts'
],
exclude: [],
webpack: {
devtool: webpackConfig.devtool,
module: webpackConfig.module,
resolve: webpackConfig.resolve,
},
webpackMiddleware: {
quiet: true,
stats: {
colors: true
}
},
preprocessors: {
'src/**/*.spec.ts': ['webpack', 'sourcemap'],
'test/**/*.ts': ['webpack', 'sourcemap']
},
Run Code Online (Sandbox Code Playgroud)
我认为你写了这个错误 import rewire = require("rewire");
它应该是
import rewire from 'rewire'
Run Code Online (Sandbox Code Playgroud)
对于 ES6 或
const rewire = require('rewire')
Run Code Online (Sandbox Code Playgroud)
对于 ES5
| 归档时间: |
|
| 查看次数: |
1162 次 |
| 最近记录: |