我在service class
中用es6
写了一个角度应用程序。它正在使用api
请求http
数据。现在我想通过mocha and chai
测试服务。这是服务的样子:
"use strict";
const HTTP = new WeakMap();
class EventService{
constructor($http, moment){
HTTP.set(this, $http);
this.$http = $http;
this.url = 'http://test/api/events?';
this.apiKey = '1234asd';
}
getEvents(){
return this.$http({
url: this.url + 'from=' + this.from + '&to=' + this.to + '&apiKey=' + this.apiKey,
method: "GET",
crossDomain: true,
headers: {
'Content-Type': 'application/json; charset=utf-8'
}
});
}
}
EventService.$inject = ['$http', 'moment'];
export default EventService;
Karma.conf.js:
module.exports = function(config) {
config.set({
// base path that will be used to resolve all patterns (eg. files, exclude)
basePath: '',
// frameworks to use
// available frameworks: https://npmjs.org/browse/keyword/karma-adapter
frameworks: ['mocha', 'chai'],
// list of files / patterns to load in the browser
files: [
'node_modules/angular/angular.js',
'node_modules/angular-mocks/angular-mocks.js',
'node_modules/moment/moment.js',
'node_modules/angular-moment/angular-moment.js',
'lib/shared/services/events-service.js',
'tests/*.js'
],
// list of files to exclude
exclude: [
],
// preprocess matching files before serving them to the browser
// available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
preprocessors: {
},
// test results reporter to use
// possible values: 'dots', 'progress'
// available reporters: https://npmjs.org/browse/keyword/karma-reporter
reporters: ['progress'],
// web server port
port: 9876,
// enable / disable colors in the output (reporters and logs)
colors: true,
// level of logging
// possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
logLevel: config.LOG_INFO,
// enable / disable watching file and executing tests whenever any file changes
autoWatch: true,
// start these browsers
// available browser launchers: https://npmjs.org/browse/keyword/karma-launcher
browsers: ['Chrome'],
// Continuous Integration mode
// if true, Karma captures browsers, runs the tests and exits
singleRun: false,
// Concurrency level
// how many browser should be started simultaneous
concurrency: Infinity
})
}
现在我只是想让测试套件启动并运行,但是,当我运行karma start
时出现以下错误:
Uncaught SyntaxError: Unexpected token export
at lib/shared/services/events-service.js
这是服务的导出命令。我是否需要进行一些配置更改才能使其正常工作?
答案 0 :(得分:0)
我认为您需要将文件预处理为浏览器可读格式。例如,可以使用karma-rollup-preprocessor,rollup-plugin-babel和es2015-rollup babel预设来完成此操作。因此,您的Karma.conf.js
文件将如下所示:
var babel = require('rollup-plugin-babel');
module.exports = function(config) {
config.set({
basePath: '',
frameworks: ['mocha', 'chai'],
files: [
'node_modules/angular/angular.js',
'node_modules/angular-mocks/angular-mocks.js',
'node_modules/moment/moment.js',
'node_modules/angular-moment/angular-moment.js',
'lib/shared/services/events-service.js',
'tests/*.js'
],
preprocessors: {
'lib/shared/services/events-service.js': ['rollup'],
'tests/*.js': ['rollup']
},
rollupPreprocessor: {
plugins: [
babel({
'babelrc': false,
'presets': ['es2015-rollup']
})
],
format: 'iife',
moduleName: '<your_project>',
sourceMap: 'inline'
},
/* other config options */
});
};
这只是一种方法,但在es5
运行之前,您的文件将被捆绑并预处理为适合浏览器的iife
Karma
。这应该消除你得到的Uncaught SyntaxError
。希望这会有所帮助。