mirror of
https://github.com/node-red/node-red.git
synced 2023-10-10 13:36:53 +02:00
Defining storage interface.
This commit is contained in:
parent
b50b23318b
commit
d58788f721
@ -14,21 +14,61 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
**/
|
**/
|
||||||
|
|
||||||
|
var when = require('when');
|
||||||
|
|
||||||
var settings = require('../red').settings;
|
var storageModule;
|
||||||
|
|
||||||
var mod;
|
function moduleSelector(aSettings) {
|
||||||
|
var toReturn;
|
||||||
if (settings.storageModule) {
|
if (aSettings.storageModule) {
|
||||||
if (typeof settings.storageModule === "string") {
|
if (typeof aSettings.storageModule === "string") {
|
||||||
// TODO: allow storage modules to be specified by absolute path
|
// TODO: allow storage modules to be specified by absolute path
|
||||||
mod = require("./"+settings.storageModule);
|
toReturn = require("./"+aSettings.storageModule);
|
||||||
} else {
|
} else {
|
||||||
mod = settings.storageModule;
|
toReturn = aSettings.storageModule;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
mod = require("./localfilesystem");
|
toReturn = require("./localfilesystem");
|
||||||
|
}
|
||||||
|
return toReturn;
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = mod;
|
var storageModuleInterface = {
|
||||||
|
init : function(settings) {
|
||||||
|
try {
|
||||||
|
storageModule = moduleSelector(settings);
|
||||||
|
} catch (e) {
|
||||||
|
return when.reject(e);
|
||||||
|
}
|
||||||
|
return storageModule.init(settings);
|
||||||
|
},
|
||||||
|
getFlows : function() {
|
||||||
|
return storageModule.getFlows();
|
||||||
|
},
|
||||||
|
saveFlows : function(flows) {
|
||||||
|
return storageModule.saveFlows(flows);
|
||||||
|
},
|
||||||
|
getCredentials : function() {
|
||||||
|
return storageModule.getCredentials();
|
||||||
|
},
|
||||||
|
saveCredentials : function(credentials) {
|
||||||
|
return storageModule.saveCredentials(credentials);
|
||||||
|
},
|
||||||
|
getAllFlows : function() {
|
||||||
|
return storageModule.getAllFlows();
|
||||||
|
},
|
||||||
|
getFlow : function(fn) {
|
||||||
|
return storageModule.getFlow(fn);
|
||||||
|
},
|
||||||
|
saveFlow : function(fn, data) {
|
||||||
|
return storageModule.saveFlow(fn, data);
|
||||||
|
},
|
||||||
|
getLibraryEntry : function(type, path) {
|
||||||
|
return storageModule.getLibraryEntry(type, path);
|
||||||
|
},
|
||||||
|
saveLibraryEntry : function(type, path, meta, body) {
|
||||||
|
return storageModule.saveLibraryEntry(type, path, meta, body);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = storageModuleInterface;
|
||||||
|
@ -16,9 +16,117 @@
|
|||||||
var should = require("should");
|
var should = require("should");
|
||||||
|
|
||||||
describe("red/storage/index", function() {
|
describe("red/storage/index", function() {
|
||||||
it('can be required without errors', function() {
|
it('can be required without errors', function(done) {
|
||||||
var RED = require('../../../red/red');
|
var storage = require("../../../red/storage/index");
|
||||||
RED.init({},{});
|
done();
|
||||||
require("../../../red/storage/index");
|
});
|
||||||
|
|
||||||
|
it('rejects the promise when settings suggest loading a bad module', function(done) {
|
||||||
|
|
||||||
|
var wrongModule = {
|
||||||
|
storageModule : "thisaintloading"
|
||||||
|
};
|
||||||
|
|
||||||
|
var storage = require("../../../red/storage/index");
|
||||||
|
storage.init(wrongModule).then( function() {
|
||||||
|
var one = 1;
|
||||||
|
var zero = 0;
|
||||||
|
try {
|
||||||
|
zero.should.equal(one, "The initialization promise should never get resolved");
|
||||||
|
} catch(err) {
|
||||||
|
done(err);
|
||||||
|
}
|
||||||
|
}).catch(function(e) {
|
||||||
|
done(); //successfully rejected promise
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('non-string storage module', function(done) {
|
||||||
|
var initSetsMeToTrue = false;
|
||||||
|
|
||||||
|
var moduleWithBooleanSettingInit = {
|
||||||
|
init : function() {
|
||||||
|
initSetsMeToTrue = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var setsBooleanModule = {
|
||||||
|
storageModule : moduleWithBooleanSettingInit
|
||||||
|
};
|
||||||
|
|
||||||
|
var storage = require("../../../red/storage/index");
|
||||||
|
storage.init(setsBooleanModule);
|
||||||
|
initSetsMeToTrue.should.be.true;
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('respects storage interface', function(done) {
|
||||||
|
var calledFlagGetFlows = false;
|
||||||
|
var calledFlagGetCredentials = false;
|
||||||
|
var calledFlagGetAllFlows = false;
|
||||||
|
var calledInit = false;
|
||||||
|
|
||||||
|
var interfaceCheckerModule = {
|
||||||
|
init : function (settings) {
|
||||||
|
settings.should.be.an.Object;
|
||||||
|
calledInit = true;
|
||||||
|
},
|
||||||
|
getFlows : function() {
|
||||||
|
calledFlagGetFlows = true;
|
||||||
|
},
|
||||||
|
saveFlows : function (flows) {
|
||||||
|
flows.should.be.true;
|
||||||
|
},
|
||||||
|
getCredentials : function() {
|
||||||
|
calledFlagGetCredentials = true;
|
||||||
|
},
|
||||||
|
saveCredentials : function(credentials) {
|
||||||
|
credentials.should.be.true;
|
||||||
|
},
|
||||||
|
getAllFlows : function() {
|
||||||
|
calledFlagGetAllFlows = true;
|
||||||
|
},
|
||||||
|
getFlow : function(fn) {
|
||||||
|
fn.should.be.true;
|
||||||
|
},
|
||||||
|
saveFlow : function(fn, data) {
|
||||||
|
fn.should.be.true;
|
||||||
|
data.should.be.true;
|
||||||
|
},
|
||||||
|
getLibraryEntry : function(type, path) {
|
||||||
|
type.should.be.true;
|
||||||
|
path.should.be.true;
|
||||||
|
},
|
||||||
|
saveLibraryEntry : function(type, path, meta, body) {
|
||||||
|
type.should.be.true;
|
||||||
|
path.should.be.true;
|
||||||
|
meta.should.be.true;
|
||||||
|
body.should.be.true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var moduleToLoad = {
|
||||||
|
storageModule : interfaceCheckerModule
|
||||||
|
};
|
||||||
|
var storage = require("../../../red/storage/index");
|
||||||
|
|
||||||
|
storage.init(moduleToLoad);
|
||||||
|
storage.getFlows();
|
||||||
|
storage.saveFlows(true);
|
||||||
|
storage.getCredentials();
|
||||||
|
storage.saveCredentials(true);
|
||||||
|
storage.getAllFlows();
|
||||||
|
storage.getFlow(true);
|
||||||
|
storage.saveFlow(true, true);
|
||||||
|
storage.getLibraryEntry(true, true);
|
||||||
|
storage.saveLibraryEntry(true, true, true, true);
|
||||||
|
|
||||||
|
calledInit.should.be.true;
|
||||||
|
calledFlagGetFlows.should.be.true;
|
||||||
|
calledFlagGetCredentials.should.be.true;
|
||||||
|
calledFlagGetAllFlows.should.be.true;
|
||||||
|
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user