npm install grunt-template-jasmine-requirejs --save-dev
Type: String
Options: 2.0.0
to 2.1.5
Default: latest requirejs version included
The version of requirejs to use.
Type String
Path to a require config file. The configuration is extracted from the require.config({}) call in the file, and is passed into the require.config({}) call in the template.
Type: Object
This object is JSON.stringify()
-ed ( support serialize Function object ) into the template and passed into var require
variable
// Example configuration
grunt.initConfig({
connect: {
test : {
port : 8000
}
},
jasmine: {
taskName: {
src: 'src/**/*.js',
options: {
specs: 'spec/*Spec.js',
helpers: 'spec/*Helper.js',
host: 'http://127.0.0.1:8000/',
template: require('grunt-template-jasmine-requirejs'),
templateOptions: {
requireConfigFile: 'src/main.js',
requireConfig: {
baseUrl: 'src/',
paths: {
"jquery": "path/to/jquery"
}
shim: {
'foo': {
deps: ['bar'],
exports: 'Foo',
init: function (bar) {
return this.Foo.noConflict();
}
}
},
deps: ['jquery']
callback: function($) {
// do initialization stuff
/*
*/
}
}
}
}
}
}
});
Note the usage of the 'connect' task configuration. You will need to use a task like grunt-contrib-connect if you need to test your tasks on a running server.
If you end up using this template, it's worth looking at the
source in order to familiarize yourself with how it loads your files. The load process
consists of a series of nested require
blocks, incrementally loading your source and specs:
require([*YOUR SOURCE*], function() {
require([*YOUR SPECS*], function() {
require([*GRUNT-CONTRIB-JASMINE FILES*], function() {
// at this point your tests are already running.
}
}
}
If "callback" function is defined in requireConfig, above code will be injected to the end of body of "callback" definition
templateOptions: {
callback: function() {
// suppose we define a module here
define("config", {
"endpoint": "/path/to/endpoint"
})
}
}
Generated runner page with require configuration looks like:
var require = {
...
callback: function() {
// suppose we define a module here
define("config", {
"endpoint": "/path/to/endpoint"
})
require([*YOUR SOURCE*], function() {
require([*YOUR SPECS*], function() {
require([*GRUNT-CONTRIB-JASMINE FILES*], function() {
// at this point your tests are already running.
}
}
}
}
...
}
This automation can help to avoid unexpected dependency order issue
- Jarrod Overson (@jsoverson)
- Cloud Chen (@cloudchen)