prepare 0.3.0, moved example to main package.json and move
options.error/debug to options.boot
This commit is contained in:
parent
a9798d05b6
commit
7b94313f90
32
README.md
32
README.md
|
@ -15,10 +15,13 @@ A javascript library providing server defined loading of assets for a single pag
|
||||||
* Assets hashing for fast syncing.
|
* Assets hashing for fast syncing.
|
||||||
* Assets types: js,css,dss
|
* Assets types: js,css,dss
|
||||||
* Caching backends: localStorage,webSqlDB,sqllite,none
|
* Caching backends: localStorage,webSqlDB,sqllite,none
|
||||||
* Server url question ui.
|
* Multi server/version support by url question ui.
|
||||||
|
* Progress indicator ui.
|
||||||
* Loader error ui.
|
* Loader error ui.
|
||||||
|
* No external dependencies.
|
||||||
|
* Technology agnostic booting.
|
||||||
* Build-in Cordova booting.
|
* Build-in Cordova booting.
|
||||||
* Build-in AngularJS booting.
|
* Build-in AngularJS-1 booting.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
|
@ -29,7 +32,7 @@ A javascript library providing server defined loading of assets for a single pag
|
||||||
|
|
||||||
### Usage Single Server
|
### Usage Single Server
|
||||||
|
|
||||||
FFSpaLoader.options.server.url = 'http://myserver';
|
FFSpaLoader.options.server.url = 'http://myserver'; // or window.location.href;
|
||||||
FFSpaLoader.options.server.assets = '/api/path/to/spa/client/resources';
|
FFSpaLoader.options.server.assets = '/api/path/to/spa/client/resources';
|
||||||
FFSpaLoader.start();
|
FFSpaLoader.start();
|
||||||
|
|
||||||
|
@ -39,7 +42,7 @@ A javascript library providing server defined loading of assets for a single pag
|
||||||
FFSpaLoader.options.boot.angular.modules.push('exampleUI');
|
FFSpaLoader.options.boot.angular.modules.push('exampleUI');
|
||||||
FFSpaLoader.options.server.url = 'http://myserver';
|
FFSpaLoader.options.server.url = 'http://myserver';
|
||||||
FFSpaLoader.options.server.assets = '/api/path/to/spa/client/resources';
|
FFSpaLoader.options.server.assets = '/api/path/to/spa/client/resources';
|
||||||
FFSpaLoader.start(function() {
|
FFSpaLoader.start(function(err) {
|
||||||
console.log('FFExample.boot done');
|
console.log('FFExample.boot done');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -73,11 +76,11 @@ A javascript library providing server defined loading of assets for a single pag
|
||||||
|
|
||||||
The available FFSpaLoader.options.* values;
|
The available FFSpaLoader.options.* values;
|
||||||
|
|
||||||
* debug.enable = Enable debug output. (default: false)
|
* boot.debug.enable = Enable debug output. (default: false)
|
||||||
* debug.handler = Prints/log debug message. (default: console.log)
|
* boot.debug.handler = Prints/log debug message. (default: console.log)
|
||||||
* debug.prefix = Debug message prefix. (default: 'FFSpaLoader.')
|
* boot.debug.prefix = Debug message prefix. (default: 'FFSpaLoader.')
|
||||||
* error.handler = The error handler. (default: internal error handler ui)
|
* boot.error.enable = Enables the ui error handler. (default: true)
|
||||||
* error.title = The error title. (default: 'Loader ');
|
* boot.error.title = The error title. (default: 'Loader ');
|
||||||
* boot.cordova.enable = Use deviceready event to boot when cordova is detected. (default: true)
|
* boot.cordova.enable = Use deviceready event to boot when cordova is detected. (default: true)
|
||||||
* boot.cordova.timeout = Boot after (if<0=no-)timeout when deviceready event is not received. (default: -1)
|
* boot.cordova.timeout = Boot after (if<0=no-)timeout when deviceready event is not received. (default: -1)
|
||||||
* boot.cordova.flag = The window flag which is set when cordova is booted. (default: 'FFCordovaDevice')
|
* boot.cordova.flag = The window flag which is set when cordova is booted. (default: 'FFCordovaDevice')
|
||||||
|
@ -118,8 +121,9 @@ A javascript library providing server defined loading of assets for a single pag
|
||||||
|
|
||||||
## Functions
|
## Functions
|
||||||
|
|
||||||
The functions iin FFSpaLoader.*;
|
The functions in FFSpaLoader.*;
|
||||||
|
|
||||||
|
* start(cb) = Starts loading your application, optional argument used for done or error callback.
|
||||||
* clearServerUrl(cb) = Clears the cached server url so after reload user get promted again.
|
* clearServerUrl(cb) = Clears the cached server url so after reload user get promted again.
|
||||||
* clearCache(cb) = Clears the cached values so after reload all assets get refetched.
|
* clearCache(cb) = Clears the cached values so after reload all assets get refetched.
|
||||||
|
|
||||||
|
@ -175,7 +179,6 @@ A javascript library providing server defined loading of assets for a single pag
|
||||||
|
|
||||||
* git clone https://bitbucket.org/im_ik/es5-ff-spa-loader.git
|
* git clone https://bitbucket.org/im_ik/es5-ff-spa-loader.git
|
||||||
* cd es5-ff-spa-loader
|
* cd es5-ff-spa-loader
|
||||||
* cd example
|
|
||||||
* npm install
|
* npm install
|
||||||
* npm start
|
* npm start
|
||||||
|
|
||||||
|
@ -219,7 +222,7 @@ Add unit tests for any new or changed functionality. Lint and test your code.
|
||||||
|
|
||||||
## Release History
|
## Release History
|
||||||
|
|
||||||
### 0.2.2
|
### 0.3.0
|
||||||
* Fixed clearServerUrl() to also clean the cached server resources json.
|
* Fixed clearServerUrl() to also clean the cached server resources json.
|
||||||
* Auto clean option.server.url from # and ? endings for: FFSpaLoader.options.server.url = window.location.href;
|
* Auto clean option.server.url from # and ? endings for: FFSpaLoader.options.server.url = window.location.href;
|
||||||
* Added server.depath option to strip the ui-prefix from the server.url.
|
* Added server.depath option to strip the ui-prefix from the server.url.
|
||||||
|
@ -228,6 +231,11 @@ Add unit tests for any new or changed functionality. Lint and test your code.
|
||||||
* Fixed duplicate starts on askUrl submit multiple clicks.
|
* Fixed duplicate starts on askUrl submit multiple clicks.
|
||||||
* Switch to karma + jasmine unit tests.
|
* Switch to karma + jasmine unit tests.
|
||||||
* Fixed define.amd module constructor.
|
* Fixed define.amd module constructor.
|
||||||
|
* Integrated example package.json to main file.
|
||||||
|
* Removed options.error.[handler|title].
|
||||||
|
* Added options.boot.error.[enable|title].
|
||||||
|
* start(cb) function callback now includes error.
|
||||||
|
* Moved options.debug.* to options.boot.debug.*.
|
||||||
|
|
||||||
### 0.2.1
|
### 0.2.1
|
||||||
* Fixed clearCache method to added json header.
|
* Fixed clearCache method to added json header.
|
||||||
|
|
|
@ -40,6 +40,7 @@
|
||||||
} else {
|
} else {
|
||||||
root.FFSpaLoader = factory(root);
|
root.FFSpaLoader = factory(root);
|
||||||
}
|
}
|
||||||
|
|
||||||
})(this || window, /** @lends module:FFSpaLoader */ function (rootWindow) {
|
})(this || window, /** @lends module:FFSpaLoader */ function (rootWindow) {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
@ -47,16 +48,16 @@
|
||||||
* The options to customize the loader.
|
* The options to customize the loader.
|
||||||
*/
|
*/
|
||||||
var options = {
|
var options = {
|
||||||
|
boot: {
|
||||||
debug: {
|
debug: {
|
||||||
enable: false,
|
enable: false,
|
||||||
handler: null, // auto filled
|
handler: null, // auto filled
|
||||||
prefix: 'FFSpaLoader.'
|
prefix: 'FFSpaLoader.'
|
||||||
},
|
},
|
||||||
error: {
|
error: {
|
||||||
handler: null, // auto filled
|
enable: true,
|
||||||
title: 'Loader '
|
title: 'Loader '
|
||||||
},
|
},
|
||||||
boot: {
|
|
||||||
cordova: {
|
cordova: {
|
||||||
enable: true,
|
enable: true,
|
||||||
timeout: -1,
|
timeout: -1,
|
||||||
|
@ -150,15 +151,15 @@
|
||||||
var askUrlSubmitLock = false;
|
var askUrlSubmitLock = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Prints the debug message with prefix to the options.debug.handler if options.debug.enable is true.
|
* Prints the debug message with prefix to the options.boot.debug.handler if options.boot.debug.enable is true.
|
||||||
* @param {String} message The message to log.
|
* @param {String} message The message to log.
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
var utilDebug = function (message) {
|
var utilDebug = function (message) {
|
||||||
if (options.debug.enable !== true) {
|
if (options.boot.debug.enable !== true) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
options.debug.handler(options.debug.prefix+message);
|
options.boot.debug.handler(options.boot.debug.prefix+message);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -321,7 +322,7 @@
|
||||||
|
|
||||||
var titleTag = document.createElement('div');
|
var titleTag = document.createElement('div');
|
||||||
titleTag.setAttribute('class','ffTitle');
|
titleTag.setAttribute('class','ffTitle');
|
||||||
titleTag.appendChild(document.createTextNode(options.error.title+err.name));
|
titleTag.appendChild(document.createTextNode(options.boot.error.title+err.name));
|
||||||
rootTag.appendChild(titleTag);
|
rootTag.appendChild(titleTag);
|
||||||
|
|
||||||
var dialogTag = document.createElement('div');
|
var dialogTag = document.createElement('div');
|
||||||
|
@ -336,6 +337,7 @@
|
||||||
var stack = err.stack || '';
|
var stack = err.stack || '';
|
||||||
stack = stack.split('\n').map(function (line) { return line.trim()+'\n'; });
|
stack = stack.split('\n').map(function (line) { return line.trim()+'\n'; });
|
||||||
var stackText = stack.splice(stack[0] === 'Error' ? 2 : 1);
|
var stackText = stack.splice(stack[0] === 'Error' ? 2 : 1);
|
||||||
|
err.stackText = stackText;
|
||||||
|
|
||||||
var traceTag = document.createElement('pre');
|
var traceTag = document.createElement('pre');
|
||||||
traceTag.appendChild(document.createTextNode(stackText));
|
traceTag.appendChild(document.createTextNode(stackText));
|
||||||
|
@ -424,6 +426,7 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
var utilCleanServerUrl = function() {
|
var utilCleanServerUrl = function() {
|
||||||
|
var serverUrlOrg = options.server.url;
|
||||||
var index1 = options.server.url.indexOf('#');
|
var index1 = options.server.url.indexOf('#');
|
||||||
if (index1 > 0){
|
if (index1 > 0){
|
||||||
options.server.url = options.server.url.substring(0,index1);
|
options.server.url = options.server.url.substring(0,index1);
|
||||||
|
@ -433,13 +436,14 @@
|
||||||
options.server.url = options.server.url.substring(0,index2);
|
options.server.url = options.server.url.substring(0,index2);
|
||||||
}
|
}
|
||||||
if (options.server.depath !== null && options.server.url.indexOf(options.server.depath) > 0) {
|
if (options.server.depath !== null && options.server.url.indexOf(options.server.depath) > 0) {
|
||||||
utilDebug('start server url depathing');
|
utilDebug('start server.url depathing');
|
||||||
options.server.url = options.server.url.substring(0,options.server.url.indexOf(options.server.depath) - 1);
|
options.server.url = options.server.url.substring(0,options.server.url.indexOf(options.server.depath) - 1);
|
||||||
}
|
}
|
||||||
if (options.server.url.indexOf('file://') === 0) {
|
if (options.server.url.indexOf('file://') === 0) {
|
||||||
utilDebug('start server url cleared because is file uri');
|
utilDebug('start server.url cleared because is file uri');
|
||||||
options.server.url = null;
|
options.server.url = null;
|
||||||
}
|
}
|
||||||
|
utilDebug('start cleaned server.url \"'+options.server.url+'\" from \"'+serverUrlOrg+'\"');
|
||||||
};
|
};
|
||||||
|
|
||||||
var cacheGetService = function (type) {
|
var cacheGetService = function (type) {
|
||||||
|
@ -1155,32 +1159,41 @@
|
||||||
/**
|
/**
|
||||||
* Starts the loader.
|
* Starts the loader.
|
||||||
*
|
*
|
||||||
* @param {function} cb Optional callback gets called when loader is done.
|
* @param {function} cb Optional callback gets called when loader is done or has error.
|
||||||
*/
|
*/
|
||||||
var start = function (cbArgu) {
|
var start = function (cbArgu) {
|
||||||
var startTime = new Date().getTime();
|
var startTime = new Date().getTime();
|
||||||
|
var cbRoot = function(err) {
|
||||||
|
if (err !== null) {
|
||||||
|
if (options.boot.error.enable !== true) {
|
||||||
|
utilDebug('bootError disabled by options');
|
||||||
|
} else {
|
||||||
|
utilErrorHandler(err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (typeof cbArgu === 'function') {
|
||||||
|
cbArgu(err);
|
||||||
|
}
|
||||||
|
};
|
||||||
var cb = function(err) {
|
var cb = function(err) {
|
||||||
if (err !== null) {
|
if (err !== null) {
|
||||||
options.error.handler(err);
|
cbRoot(err);
|
||||||
} else {
|
} else {
|
||||||
utilDebug('start done in '+(new Date().getTime()-startTime)+' ms.'); // last debug line TODO: move bootAngular to onjsloaded
|
utilDebug('start done in '+(new Date().getTime()-startTime)+' ms.'); // last debug line TODO: move bootAngular to onjsloaded
|
||||||
bootCleanup(); // move after ang.
|
bootCleanup(); // move after ang.
|
||||||
bootAngular(function(err) {
|
bootAngular(function(err) {
|
||||||
if (err !== null) { return options.error.handler(err); }
|
|
||||||
loadDelayedResouces();
|
loadDelayedResouces();
|
||||||
if (typeof cbArgu === 'function') {
|
cbRoot(err);
|
||||||
cbArgu();
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
utilDebug('start spa loader'); // first debug line TODO: Add version
|
utilDebug('start spa-loader'); // first debug line TODO: Add version
|
||||||
|
|
||||||
if (options.server.url !== null) {
|
if (options.server.url !== null) {
|
||||||
utilCleanServerUrl();
|
utilCleanServerUrl();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (options.debug.enable === true) {
|
if (options.boot.debug.enable === true) {
|
||||||
var optionsKeys = Object.keys(options);
|
var optionsKeys = Object.keys(options);
|
||||||
for (var keyId in optionsKeys) {
|
for (var keyId in optionsKeys) {
|
||||||
var key = optionsKeys[keyId];
|
var key = optionsKeys[keyId];
|
||||||
|
@ -1271,8 +1284,7 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
// Auto fill handlers and return public object.
|
// Auto fill handlers and return public object.
|
||||||
options.debug.handler = function(msg) {console.log(msg);};
|
options.boot.debug.handler = function(msg) {console.log(msg);};
|
||||||
options.error.handler = utilErrorHandler;
|
|
||||||
return {
|
return {
|
||||||
options: options,
|
options: options,
|
||||||
factory: factory,
|
factory: factory,
|
||||||
|
|
|
@ -11,6 +11,7 @@ var UglifyJS = require("uglify-js");
|
||||||
var Hashes = require('jshashes');
|
var Hashes = require('jshashes');
|
||||||
var minify = require('minify');
|
var minify = require('minify');
|
||||||
|
|
||||||
|
var appPath = '/test'; // dynamic context path for version or proxy/etc of server app.
|
||||||
var clientResourcesWeb = [];
|
var clientResourcesWeb = [];
|
||||||
var clientResources = {
|
var clientResources = {
|
||||||
js: [],
|
js: [],
|
||||||
|
@ -23,10 +24,11 @@ var addClientResource = function(clientResource, resourceType) {
|
||||||
};
|
};
|
||||||
|
|
||||||
var fetchHashResource = function(fetchEntry,cb) {
|
var fetchHashResource = function(fetchEntry,cb) {
|
||||||
var serverUrl = 'http://localhost:'+httpPort;
|
var serverUrl = 'http://localhost:'+httpPort+appPath;
|
||||||
var hashDigest = new Hashes.SHA1;
|
var hashDigest = new Hashes.SHA1;
|
||||||
fetch.fetchUrl(serverUrl + fetchEntry.url,function(err, meta, data) {
|
fetch.fetchUrl(serverUrl + fetchEntry.url,function(err, meta, data) {
|
||||||
if (err !== null) { return cb(err); }
|
if (err !== null) { return cb(err); }
|
||||||
|
if (meta.status !== 200) { return cb('wrong status: '+meta.status); }
|
||||||
var assetHash = hashDigest.hex(''+data);
|
var assetHash = hashDigest.hex(''+data);
|
||||||
clientResourcesWeb.push({
|
clientResourcesWeb.push({
|
||||||
url: fetchEntry.url,
|
url: fetchEntry.url,
|
||||||
|
@ -39,7 +41,8 @@ var fetchHashResource = function(fetchEntry,cb) {
|
||||||
|
|
||||||
var fetchHashResources = function(fetchList, cb) {
|
var fetchHashResources = function(fetchList, cb) {
|
||||||
var resourceStack = fetchList;
|
var resourceStack = fetchList;
|
||||||
var resourceLoader = function() {
|
var resourceLoader = function(err) {
|
||||||
|
if (err !== null) { return cb(err); }
|
||||||
resourceStack = resourceStack.slice(1);
|
resourceStack = resourceStack.slice(1);
|
||||||
if (resourceStack.length === 0) {
|
if (resourceStack.length === 0) {
|
||||||
cb(null);
|
cb(null);
|
||||||
|
@ -83,7 +86,7 @@ function renderIndex() {
|
||||||
var inlineScript = UglifyJS.minify(__dirname+'/../../es5-ff-spa-loader.js');
|
var inlineScript = UglifyJS.minify(__dirname+'/../../es5-ff-spa-loader.js');
|
||||||
minify(__dirname+'/../../es5-ff-spa-loader.css', {}, function(err, data) {
|
minify(__dirname+'/../../es5-ff-spa-loader.css', {}, function(err, data) {
|
||||||
res.render('index', {
|
res.render('index', {
|
||||||
inlineScript: inlineScript.code,
|
inlineScript: 'console.log(\'test\');'+inlineScript.code,
|
||||||
inlineStyle: data
|
inlineStyle: data
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -102,8 +105,9 @@ addClientResource('/static/js/example-app.js','js'); // deps: jquery,angular
|
||||||
addClientResource('/static/js/controller/page-bar.js','js'); // deps: example-app.js
|
addClientResource('/static/js/controller/page-bar.js','js'); // deps: example-app.js
|
||||||
addClientResource('/static/js/controller/page-foo.js','js');
|
addClientResource('/static/js/controller/page-foo.js','js');
|
||||||
addClientResource('/static/js/controller/page-index.js','js');
|
addClientResource('/static/js/controller/page-index.js','js');
|
||||||
|
// NOTE: appPath should be done as request parameter which auto prefixes the data, as only the client knows the true context path of a http application.
|
||||||
|
|
||||||
|
|
||||||
var appPath = '/test';
|
|
||||||
var server = express();
|
var server = express();
|
||||||
server.use(morgan('dev'));
|
server.use(morgan('dev'));
|
||||||
server.use(cors({credentials: true, origin: '*', exposedHeaders: ['X-My-Api']}));
|
server.use(cors({credentials: true, origin: '*', exposedHeaders: ['X-My-Api']}));
|
||||||
|
@ -111,10 +115,10 @@ server.set('view engine', 'ejs');
|
||||||
server.set('views', path.join(__dirname,'www_views'));
|
server.set('views', path.join(__dirname,'www_views'));
|
||||||
server.use(function(req, res, next) { res.header('X-My-Api', 'noknok');next(); });
|
server.use(function(req, res, next) { res.header('X-My-Api', 'noknok');next(); });
|
||||||
server.use(appPath+'/static', express.static(path.join(__dirname,'www_static')));
|
server.use(appPath+'/static', express.static(path.join(__dirname,'www_static')));
|
||||||
server.use(appPath+'/static/module/bootstrap', express.static(path.join(__dirname,'../node_modules/bootstrap/dist')));
|
server.use(appPath+'/static/module/bootstrap', express.static(path.join(__dirname,'../../node_modules/bootstrap/dist')));
|
||||||
server.use(appPath+'/static/module/jquery', express.static(path.join(__dirname,'../node_modules/jquery/dist')));
|
server.use(appPath+'/static/module/jquery', express.static(path.join(__dirname,'../../node_modules/jquery/dist')));
|
||||||
server.use(appPath+'/static/module/angular', express.static(path.join(__dirname,'../node_modules/angular')));
|
server.use(appPath+'/static/module/angular', express.static(path.join(__dirname,'../../node_modules/angular')));
|
||||||
server.use(appPath+'/static/module/angular-route', express.static(path.join(__dirname,'../node_modules/angular-route')));
|
server.use(appPath+'/static/module/angular-route', express.static(path.join(__dirname,'../../node_modules/angular-route')));
|
||||||
server.get(appPath+'/static/spa-client-resources', function (req,res) {res.json({data: {resources: clientResourcesWeb}});});
|
server.get(appPath+'/static/spa-client-resources', function (req,res) {res.json({data: {resources: clientResourcesWeb}});});
|
||||||
server.get(appPath+'/static/spa-loader.css', function (req,res) {res.sendFile('es5-ff-spa-loader.css', { root: path.join(__dirname, '/../../') });});
|
server.get(appPath+'/static/spa-loader.css', function (req,res) {res.sendFile('es5-ff-spa-loader.css', { root: path.join(__dirname, '/../../') });});
|
||||||
server.get(appPath+'/', function (req, res) {res.redirect(appPath+'/example-ui');});
|
server.get(appPath+'/', function (req, res) {res.redirect(appPath+'/example-ui');});
|
||||||
|
@ -125,9 +129,12 @@ server.get('/', function (req, res) {res.redi
|
||||||
server.listen(httpPort);
|
server.listen(httpPort);
|
||||||
console.info('Server started on port '+httpPort);
|
console.info('Server started on port '+httpPort);
|
||||||
|
|
||||||
var res = createClientResourceFetchList();
|
fetchHashResources(createClientResourceFetchList(), function(err) {
|
||||||
fetchHashResources(res, function(err) {
|
if (err !== null) {
|
||||||
if (err !== null) {console.log(err);}
|
console.log('Fatal error '+err);
|
||||||
|
process.exit(1);
|
||||||
|
} else {
|
||||||
console.log('Total assets build: '+clientResourcesWeb.length);
|
console.log('Total assets build: '+clientResourcesWeb.length);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ document.title = 'FFSpaLoader Example';
|
||||||
var serverUrl = window.FFServerUrl;
|
var serverUrl = window.FFServerUrl;
|
||||||
console.log('FFExample provided serverUrl \"'+serverUrl+'\"');
|
console.log('FFExample provided serverUrl \"'+serverUrl+'\"');
|
||||||
|
|
||||||
// TODO for 0.2.1
|
// TODO for 0.4.0
|
||||||
//var tplCache = FFSpaLoader.factory.cache.websql({table: 'angular_tpl'});
|
//var tplCache = FFSpaLoader.factory.cache.websql({table: 'angular_tpl'});
|
||||||
//tplCache.cacheOpen(function(err) {
|
//tplCache.cacheOpen(function(err) {
|
||||||
// tplCache.cacheSetValue('key123','value456',function(err) {
|
// tplCache.cacheSetValue('key123','value456',function(err) {
|
||||||
|
|
|
@ -3,12 +3,12 @@
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8"/>
|
<meta charset="UTF-8"/>
|
||||||
<title>Loading</title>
|
<title>Loading</title>
|
||||||
<script id="ffCleanupScript"><%- inlineScript %></script>
|
<script id="ffCleanupScript" type="text/javascript"><%- inlineScript %></script>
|
||||||
<style id="ffCleanupStyle"><%- inlineStyle %></style>
|
<style id="ffCleanupStyle" type="text/css"><%- inlineStyle %></style>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<script id="ffCleanupConfig">
|
<script id="ffCleanupConfig" type="text/javascript">
|
||||||
FFSpaLoader.options.debug.enable = true;
|
FFSpaLoader.options.boot.debug.enable = true;
|
||||||
FFSpaLoader.options.boot.angular.modules.push('exampleUI');
|
FFSpaLoader.options.boot.angular.modules.push('exampleUI');
|
||||||
FFSpaLoader.options.boot.cleanup.tags.push('ffCleanupStyle');
|
FFSpaLoader.options.boot.cleanup.tags.push('ffCleanupStyle');
|
||||||
FFSpaLoader.options.boot.cleanup.tags.push('ffCleanupScript');
|
FFSpaLoader.options.boot.cleanup.tags.push('ffCleanupScript');
|
||||||
|
|
12
gulpfile.js
12
gulpfile.js
|
@ -20,11 +20,11 @@ gulp.task('clean', function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('buildScript', ['test'], function() {
|
gulp.task('buildScript', ['test'], function() {
|
||||||
gulp.src(srcFile, {cwd: srcPath}).pipe(gulp.dest(distPathJS));
|
return gulp.src(srcFile, {cwd: srcPath}).pipe(gulp.dest(distPathJS));
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('buildScriptMin', ['buildScript'], function() {
|
gulp.task('buildScriptMin', ['buildScript'], function() {
|
||||||
gulp.src(srcFile, {cwd: srcPath})
|
return gulp.src(srcFile, {cwd: srcPath})
|
||||||
.pipe(srcmaps.init())
|
.pipe(srcmaps.init())
|
||||||
.pipe(uglify({/*preserveComments: 'license'*/}))
|
.pipe(uglify({/*preserveComments: 'license'*/}))
|
||||||
.pipe(rename({ extname: '.min.js' }))
|
.pipe(rename({ extname: '.min.js' }))
|
||||||
|
@ -33,7 +33,7 @@ gulp.task('buildScriptMin', ['buildScript'], function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('buildCss', ['test'], function() {
|
gulp.task('buildCss', ['test'], function() {
|
||||||
gulp.src(srcCss, {cwd: srcPath}).pipe(gulp.dest(distPathCSS));
|
return gulp.src(srcCss, {cwd: srcPath}).pipe(gulp.dest(distPathCSS));
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('buildCssMin',['buildCss'], function () {
|
gulp.task('buildCssMin',['buildCss'], function () {
|
||||||
|
@ -46,7 +46,7 @@ gulp.task('buildCssMin',['buildCss'], function () {
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('testKarma',['clean'], function (done) {
|
gulp.task('testKarma',['clean'], function (done) {
|
||||||
testServer.start(function () {
|
return testServer.start(function () {
|
||||||
new karma.Server({
|
new karma.Server({
|
||||||
configFile: __dirname + '/test/karma.conf.js',
|
configFile: __dirname + '/test/karma.conf.js',
|
||||||
singleRun: true
|
singleRun: true
|
||||||
|
@ -69,10 +69,10 @@ gulp.task('buildJSDoc', function (cb) {
|
||||||
cleverLinks: true
|
cleverLinks: true
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
gulp.src(srcFile, {read: false}).pipe(jsdoc(jsdocConfig, cb));
|
return gulp.src(srcFile, {read: false}).pipe(jsdoc(jsdocConfig, cb));
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('test', ['clean','testKarma']);
|
gulp.task('test', ['testKarma']);
|
||||||
gulp.task('build', ['test','buildCssMin','buildScriptMin'/*,'buildJSDoc'*/]);
|
gulp.task('build', ['test','buildCssMin','buildScriptMin'/*,'buildJSDoc'*/]);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -56,6 +56,7 @@
|
||||||
"karma": "0.13.9",
|
"karma": "0.13.9",
|
||||||
"karma-coverage": "0.5.5",
|
"karma-coverage": "0.5.5",
|
||||||
"karma-jasmine": "0.3.8",
|
"karma-jasmine": "0.3.8",
|
||||||
|
"karma-jasmine-ajax": "0.1.13",
|
||||||
"karma-jshint": "0.1.0",
|
"karma-jshint": "0.1.0",
|
||||||
"karma-junit-reporter": "0.4.2",
|
"karma-junit-reporter": "0.4.2",
|
||||||
"karma-mocha-reporter": "2.0.1",
|
"karma-mocha-reporter": "2.0.1",
|
||||||
|
|
|
@ -4,12 +4,13 @@ module.exports = function(config) {
|
||||||
plugins : ['karma-requirejs',
|
plugins : ['karma-requirejs',
|
||||||
'karma-coverage',
|
'karma-coverage',
|
||||||
'karma-phantomjs-launcher',
|
'karma-phantomjs-launcher',
|
||||||
|
'karma-jasmine-ajax',
|
||||||
'karma-jasmine',
|
'karma-jasmine',
|
||||||
'karma-jshint',
|
'karma-jshint',
|
||||||
'karma-mocha-reporter',
|
'karma-mocha-reporter',
|
||||||
'karma-junit-reporter'
|
'karma-junit-reporter'
|
||||||
],
|
],
|
||||||
frameworks : [ 'jasmine', 'requirejs' ],
|
frameworks : [ 'jasmine-ajax', 'jasmine', 'requirejs' ],
|
||||||
files : [ {
|
files : [ {
|
||||||
pattern : 'es5-ff-spa-loader.js',
|
pattern : 'es5-ff-spa-loader.js',
|
||||||
included : false
|
included : false
|
||||||
|
|
|
@ -3,31 +3,46 @@ define(['es5-ff-spa-loader'], function(FFSpaLoader) {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
describe('Start loader', function() {
|
describe('Start loader', function() {
|
||||||
|
beforeEach(function () {
|
||||||
|
function emptyElement(element) {
|
||||||
|
var myNode = element;
|
||||||
|
while (myNode.firstChild) {
|
||||||
|
myNode.removeChild(myNode.firstChild);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
emptyElement(document.head);
|
||||||
|
emptyElement(document.body);
|
||||||
|
});
|
||||||
it('FFSpaLoader start with error', function(done) {
|
it('FFSpaLoader start with error', function(done) {
|
||||||
FFSpaLoader.options.server.url = 'http://localhost:9999';
|
FFSpaLoader.options.server.url = 'http://localhost:9999';
|
||||||
FFSpaLoader.options.error.handler = function(err) {
|
FFSpaLoader.start(function(err) {
|
||||||
|
if (err !== null) {
|
||||||
done();
|
done();
|
||||||
};
|
} else {
|
||||||
FFSpaLoader.start();
|
fail();
|
||||||
|
}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
it('FFSpaLoader starts', function(done) {
|
it('FFSpaLoader starts', function(done) {
|
||||||
FFSpaLoader.options.server.url = 'http://localhost:9090/test';
|
FFSpaLoader.options.server.url = 'http://localhost:9090/test';
|
||||||
FFSpaLoader.options.server.assets = '/static/spa-client-resources';
|
FFSpaLoader.options.server.assets = '/static/spa-client-resources';
|
||||||
FFSpaLoader.options.error.handler = function(err) {
|
FFSpaLoader.start(function(err) {
|
||||||
fail(); // TIODI
|
if (err !== null) {
|
||||||
};
|
fail();
|
||||||
FFSpaLoader.start(function() {
|
} else {
|
||||||
done();
|
done();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
it('FFSpaLoader starts again', function(done) {
|
it('FFSpaLoader starts again', function(done) {
|
||||||
FFSpaLoader.options.server.url = 'http://localhost:9090/test';
|
FFSpaLoader.options.server.url = 'http://localhost:9090/test';
|
||||||
FFSpaLoader.options.server.assets = '/static/spa-client-resources';
|
FFSpaLoader.options.server.assets = '/static/spa-client-resources';
|
||||||
FFSpaLoader.options.error.handler = function(err) {
|
FFSpaLoader.start(function(err) {
|
||||||
fail(); // TIODI
|
if (err !== null) {
|
||||||
};
|
fail();
|
||||||
FFSpaLoader.start(function() {
|
} else {
|
||||||
done();
|
done();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
42
test/spec/test-cache.js
Normal file
42
test/spec/test-cache.js
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
|
||||||
|
define(['es5-ff-spa-loader'], function(FFSpaLoader) {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('Test Cache', function() {
|
||||||
|
|
||||||
|
beforeEach(function() {
|
||||||
|
jasmine.Ajax.install();
|
||||||
|
});
|
||||||
|
afterEach(function() {
|
||||||
|
jasmine.Ajax.uninstall();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('FFSpaLoader boot ', function(done) {
|
||||||
|
var clientResource = {
|
||||||
|
data: {
|
||||||
|
resources: [{
|
||||||
|
url: '/static/js/foobar.js',
|
||||||
|
type: 'js',
|
||||||
|
hash: 12381273
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
};
|
||||||
|
jasmine.Ajax.stubRequest('http://localhost:999/static/spa-client-resources').andReturn({
|
||||||
|
'responseText': JSON.stringify(clientResource)
|
||||||
|
});
|
||||||
|
jasmine.Ajax.stubRequest('http://localhost:999/static/js/foobar.js').andReturn({
|
||||||
|
'responseText': '\nvar FOOBAR = \'loaded\';\n'
|
||||||
|
});
|
||||||
|
//FFSpaLoader.options.boot.debug.enable = true;
|
||||||
|
FFSpaLoader.options.server.url = 'http://localhost:999';
|
||||||
|
FFSpaLoader.options.server.assets = '/static/spa-client-resources';
|
||||||
|
FFSpaLoader.start(function(err) {
|
||||||
|
if (err !== null) {
|
||||||
|
fail();
|
||||||
|
} else {
|
||||||
|
done();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue