/** * {{LICENSE_HEADER}} * {{LICENSE_HEADER}} **/ /** * This node module acts as a mock for requirejs and allows you to * define your own dependencies in your tests. It also removes the * asynchronous character of dependency loading, so you don't need * to handle everthing in the callbacks. * * Per default it resolves the 'logging' dependency by routing it * to console. * **/ var path = require('path'); var registeredDependencies = {}; /** * Mock for the requirejs(dependencyList, callback) function, loads * all dependencies that have been registered under the given names * in dependencies and calls fn with them as the parameter * **/ var debug = false; var requireJsMock = function(dependencies, fn) { var fnArgs = []; for (var i=0;iobject map of dependencies * for lookup with requirejs()/define() **/ function registerDependencies(obj) { for(var name in obj) { registeredDependencies[name] = obj[name]; } } var base = path.normalize(__dirname+"../../../../public/js"); GLOBAL.requireNew = function(key) { key = path.normalize(base+"/"+key); delete require.cache[key]; return require(key); }; /** * The API for this module **/ module.exports = { purgeDependencies: purgeDependencies, registerDependencies: registerDependencies, getDefine: function(name) { if (typeof name === "undefined") { return registeredDependencies.__define__; } else { return registeredDependencies[name]; } } };