通过业力角度的茉莉花测试案例给出错误

时间:2015-03-26 09:29:17

标签: jasmine karma-runner

我正试图在业力中执行角度 - 茉莉花测试案例。我有requirejs也在我的程序中。我收到了一些错误。因为我是茉莉和业力的新手,我不知道如何为karma文件部分写文件。它是否应该包含我的代码中的所有文件(外部库,源文件和测试文件)?以下代码是我的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: ['jasmine'],


    // list of files / patterns to load in the browser
    files: [
        'https://code.jquery.com/jquery-1.11.2.min.js',
        'https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.min.js',
        'src/app/app.js',
        'src/app/spec/testSpec.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
  });
};

我收到了以下错误:

Uncaught Error: Mismatched anonymous define() module: function (angular, $) {

我的测试规格是:

describe('Testing routes', function() {

    beforeEach(module('myApp'));

    var location, route, rootScope;

    beforeEach(inject(
        function( _$location_, _$route_, _$rootScope_ ) {
            console.log("At inject method");
            location = _$location_;
            route = _$route_;
            rootScope = _$rootScope_;
    }));

     describe('home route', function() {


        it('should load the home page on successful load of /', function() {
            location.path('/');
            rootScope.$digest();
            expect(route.current.controller).toBe('homeController');
        });
    });
});

我的模块以require的定义开始,如:

define(['angular', 'jquery'], function(angular, $) {

    angular
        .module('myApp', [])
        .config(['$routeProvider', '$locationProvider', routeConfig])
        .config(['$httpProvider', errorHandler])
        .run(initHome);
});

1 个答案:

答案 0 :(得分:0)

在您的某个angularjs文件中,依赖注入参数不匹配。 如果您能够显示'src / app / app.js','src / app / spec / testSpec.js'文件的内容,我们将能够提供更多帮助。

我认为您需要在karma.conf.js文件中添加requirejs的支持。 编辑框架行并添加requirejs。

frameworks: [ 'jasmine', 'requirejs' ],//add requirejs support
 // list of files / patterns to load in the browser
files: [
    'https://code.jquery.com/jquery-1.11.2.min.js',
    'https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.min.js',
    'vendor/requirejs/require.js', //load requirejs file
    'src/app/app.js',
    'src/app/spec/testSpec.js'
],