gpt4 book ai didi

javascript - 使用 Karma : "module is not defined" 进行 Angular Testing

转载 作者:IT老高 更新时间:2023-10-28 22:04:20 25 4
gpt4 key购买 nike

我知道这个问题已经被问过很多次了,而且我知道在大多数情况下人们都缺少 angular-mocks.js 文件。

我遇到了同样的问题,试图在一个模块上测试一个工厂。不幸的是,我一直遇到测试问题(为什么,Angular,哦,为什么你必须假设一个 windowdocument 对象?),这表明该模块未定义。我不知所措。我也尝试过使用 angular.mocks.module,但随后我收到一条消息说 Angular 未定义。我做错了什么?

值得注意的是,我使用 gulp 作为任务运行器。我的 gulpfile(还不完善,任务没有关联):

var gulp = require('gulp'),

uglify = require('gulp-uglify'),
jshint = require('gulp-jshint'),
jasmine = require('gulp-jasmine'),
karma = require('gulp-karma'),

paths = {
scripts: "scripts/*.js",
spec: "spec/*.js",
dist: "dist"
};

gulp.task('prepare', function () {
return gulp.src(paths.scripts)
.pipe(jshint())
.pipe(jshint.reporter('default'))
.pipe(uglify())
.pipe(gulp.dest(paths.dist))
});

gulp.task('test', function () {
gulp.src([paths.scripts, paths.spec])
.pipe(karma({
configFile: 'karma.conf.js',
action: 'run'
}));
});

gulp.task('default', ['prepare', 'test']);

我的 karma.conf.js,由 karma init 生成:

// Karma configuration
// Generated on Fri Mar 14 2014 14:24:30 GMT-0400 (EDT)

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: [
'./lib/angular/angular.min.js',
'./lib/angular-mocks/angular-mocks.js',
'./src/*.js',
'./spec/*.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: false,


// 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
});
};

最后,我的测试套件(还没有设置,如果我能通过这个障碍,我们会很好):

/* Tests for memento.js. */

describe('memento core test suite', function () {
var memento;

beforeEach(module('Memento'));

beforeEach(function() {
inject(function(_memento_) {
memento = _memento_;
});
});

// Check functions.
// check to see if it has the expected function
it('should match expected interface', function () {
expect(angular.isFunction(memento.canUndo)).toBe(true);
expect(angular.isFunction(memento.canRedo)).toBe(true);
expect(angular.isFunction(memento.undo)).toBe(true);
expect(angular.isFunction(memento.redo)).toBe(true);
expect(angular.isFunction(memento.push)).toBe(true);
});

it('should initialize', function () {
this.fail(Error('Test not implemented'));
});

it('should push() a changed object', function () {
this.fail(Error('Test not implemented'));
});

it('should not push() an unchanged object', function () {
this.fail(Error('Test not implemented'));
});

it('should return original object on undo()', function () {
this.fail(Error('Test not implemented'));
});

it('should return modified object on redo()', function () {
this.fail(Error('Test not implemented'));
});

it('should not undo() if at beginning of stack', function () {
this.fail(Error('Test not implemented'));
});

it('should not redo() if at end of stack', function () {
this.fail(Error('Test not implemented'));
});

// TODO: Implement revert to original, clearing history.
//
// it('should return seed object on revert()', function () {
// this.fail(Error('Test not implemented'));
// });

// it('should clear the stack on clear()', function () {
// this.fail(Error('Test not implemented'));
// });
});

有没有人发现有什么不对劲的地方?我不确定我是否遗漏了一些非常明显的东西——我可以多用一双眼睛,或者很多。我最初认为我可以在没有 Karma 的情况下将它作为一个简单的 Jasmine 测试套件运行,但由于 Angular,这有问题。如果我不能让它工作,我可能只是使用 npm 的 Angular 包并更改我的 Angular 模块,以便它支持 CommonJS...

谢谢大家!希望我没有疯。

编辑:我已经包含了我的开发依赖项。

  "devDependencies": {
"gulp": "~3.5.6",
"gulp-uglify": "~0.2.1",
"gulp-jshint": "~1.5.0",
"gulp-jasmine": "~0.2.0",
"angular": "~1.2.10",
"karma": "~0.12.0",
"gulp-karma": "0.0.4",
"karma-jasmine": "~0.2.2",
"karma-chrome-launcher": "~0.1.2"
}

最佳答案

声明模块/Angular 未定义的消息意味着您的 angular-mocks.js 文件未加载,尽管事实上您已将其列在 karma.conf.js 文件中。

您遇到的问题是 gulp-karma 忽略了您的 karma.conf.js 文件数组。当您将字符串或 glob 传递到 gulpfile 中的 gulp.src 时,就会发生这种情况。

要解决这个问题,请为 gulp.src 传递一个虚假文件的字符串,例如“./foobar”,这将导致使用 karma.conf.js 文件中的 files 数组。

gulp.task('test', function () {
gulp.src('./foobar')
.pipe(karma({
configFile: 'karma.conf.js',
action: 'run'
}));
});

希望这会有所帮助!

引用: https://github.com/lazd/gulp-karma/issues/9

关于javascript - 使用 Karma : "module is not defined" 进行 Angular Testing ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22413767/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com