我正在为我的 Angularjs 应用编写 Jasmine 测试。 我使用 karma init 生成了 karma.conf.js,但是当我运行 karma start 时,我收到这样的警告:
WARN [web-server]: 404: /bower_components/angular/angular.js
WARN [web-server]: 404: /js/app.js
karma.conf.js 在我的应用程序文件夹中,这也是 bower_components 文件夹的位置。
我想这可能是因为我使用这种方法的本地测试服务器:https://github.com/mhevery/angular-node-socketio
(我已经能够在没有测试服务器的情况下在其他项目中设置这样的测试)
谁能给我指出正确的方向吗?
更新:
我的 karma.conf.js 看起来像这样:
module.exports = function(config) {
config.set({
basePath: '.',
frameworks: ['jasmine', 'requirejs'],
files: [
'tests/*.js',
'js/*.js',
'bower_components/angular/angular.js',
'bower_components/angular-mocks/angular-mocks.js',
'bower_components/angular-resource/angular-resource.js',
'bower_components/d3/d3.js'
],
exclude: [],
reporters: ['progress'],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
captureTimeout: 60000,
singleRun: false
});
};
这是我的目录结构:
最佳答案
现在您已经修复了基本路径(从“.”到“”,请参阅上面的问题评论),您应该更改 karma.conf.js 中文件加载的顺序:
module.exports = function(config) {
config.set({
basePath: '.',
frameworks: ['jasmine', 'requirejs'],
files: [
//load angular.js first
//(unless if you use jQuery which must be first if I remember well)
'bower_components/angular/angular.js',
//Then angular-modules
'bower_components/angular-resource/angular-resource.js',
'bower_components/angular-mocks/angular-mocks.js',
//Other libs
'bower_components/d3/d3.js',
//Your app scripts
'js/*.js',
//And your specs
'tests/*.js'
],
exclude: [],
reporters: ['progress'],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
captureTimeout: 60000,
singleRun: false
});
};
您可以在此处找到更多信息:http://karma-runner.github.io/0.10/config/files.html
Ordering
- The order of patterns determines the order of files in which they are included in the browser.
- Multiple files matching a single pattern are sorted alphabetically.
- Each file is included exactly once. If multiple patterns match the same file, it's included as if it only matched the first pattern.
关于javascript - Karma 找不到配置文件中指定的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21581700/