我正在尝试对使用requirejs的文件运行茉莉花测试。我有一个require.config.js文件,其中提供了requirejs的所有配置,我正在传递给此命令以运行茉莉花测试。
茉莉花节点--runWithRequireJs --captureExceptions --requireJsSetup spec / require.config.js spec / modules / test.spec.js
我的require.config.js看起来像这样-
var require = {
baseUrl: "../app",
urlArgs: 'cb=' + Math.random(),
paths: {
jquery: '../assets/js/libs/jquery-1.8.2',
underscore: '../assets/js/libs/underscore-min',
backbone: '../assets/js/libs/backbone-min',
jasmine: '../spec/lib/jasmine',
jasminehtml: '../spec/lib/jasmine-html',
boot: '../spec/lib/boot',
spec: '../spec/',
handlebars : '../assets/js/libs/handlebars-1.0.0.beta.6',
// plugins
jqueryui : '../assets/js/plugins/jquery-ui',
jqgrid : '../assets/js/plugins/jqGrid',
jqgridlocale : '../assets/js/plugins/i18n/grid.locale-en',
jqform : '../assets/js/plugins/jquery.form',
jqfiledownload : '../assets/js/plugins/jquery.fileDownload',
migrate: '../assets/js/plugins/jquery-migrate',
text : '../assets/js/plugins/text'
},
shim: {
'underscore': {
exports: "_"
},
'backbone': {
deps: ['underscore', 'jquery'],
exports: 'Backbone'
},
'jasmine': {
exports: 'jasmine'
},
'jasminehtml': {
deps: ['jasmine'],
exports: 'jasmine'
},
'boot': {
deps: ['jasmine', 'jasminehtml'],
exports: 'window.jasmineRequire'
},
'handlebars' : {
exports : 'Handlebars'
},
'text' : {
exports : 'text'
},
'jqueryui' : [ 'jquery' ],
'jqgrid' : [ 'jquery' ],
'jqgridlocale' : [ 'jquery' ],
'jqform':['jquery'],
'jqfiledownload':['jquery'],
'migrate':['jquery']
}};
我的test.spec.js文件如下所示-
define(['modules/models/RouteModel','modules/models/RestWebService'], function(RouteModel,RestWebService){
describe("RouteModel :", function(){
it("should create an test instance", function(){
expect(RouteModel).not.toBe(null);
});
});
运行命令后,我进入控制台
ReferenceError: define is not defined at C:\Users\TestProject\spec\modules\test.spec.js:1:1
在这种情况下可能是什么问题?这是路径配置问题吗?
P.S。 -我想要茉莉花的完整控制台输出,而不是茉莉花的浏览器输出。
答案 0 :(得分:0)
错误非常直接,您需要在调用函数之前加载requirejs。您可以从以下链接中找到更清晰的主意: https://stackoverflow.com/a/29317859/1607130