【问题标题】:test service class using es6 in angular在 Angular 中使用 es6 测试服务类
【发布时间】:2016-08-05 18:13:44
【问题描述】:

我有一个用es6 编写的service class 用于角度应用程序。它使用http 请求api 获取数据。现在我想通过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

在服务的导出命令中。我是否必须进行一些配置更改才能完成这项工作?

【问题讨论】:

    标签: javascript angularjs testing ecmascript-6 karma-mocha


    【解决方案1】:

    我认为您需要将文件预处理为浏览器可读的格式。例如,这可以使用karma-rollup-preprocessorrollup-plugin-babeles2015-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 */
        });
    };
    

    这只是一种方法,但您的文件将被捆绑并预处理到浏览器友好的es5iifes 中,然后由Karma 运行。这应该消除您得到的Uncaught SyntaxError。希望这会有所帮助。

    【讨论】:

      猜你喜欢
      • 2016-12-21
      • 2014-02-09
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-08-23
      • 1970-01-01
      • 2023-01-30
      • 2013-11-08
      相关资源
      最近更新 更多