mirror of
https://github.com/node-red/node-red.git
synced 2023-10-10 13:36:53 +02:00
Remove unnecessary context storage APIs
and rename context storage APIs
This commit is contained in:
parent
dd81d947fc
commit
e6411d11b1
@ -180,17 +180,17 @@ function createContext(id,seed) {
|
||||
obj.getAsync = function(key) {
|
||||
var keyPath = parseKey(key);
|
||||
var context = getContextStorage(keyPath.storage);
|
||||
return context.getAsync(scope, keyPath.key);
|
||||
return context.get(scope, keyPath.key);
|
||||
};
|
||||
obj.setAsync = function(key, value) {
|
||||
var keyPath = parseKey(key);
|
||||
var context = getContextStorage(keyPath.storage);
|
||||
return context.setAsync(scope, keyPath.key, value);
|
||||
return context.set(scope, keyPath.key, value);
|
||||
};
|
||||
obj.keysAsync = function(storage) {
|
||||
var storageName = parseStorage(storage);
|
||||
var context = getContextStorage(storageName);
|
||||
return context.keysAsync(scope);
|
||||
return context.keys(scope);
|
||||
};
|
||||
return obj;
|
||||
}
|
||||
|
@ -86,7 +86,7 @@ LocalFileSystem.prototype.close = function(){
|
||||
return Promise.resolve();
|
||||
}
|
||||
|
||||
LocalFileSystem.prototype.getAsync = function(scope, key) {
|
||||
LocalFileSystem.prototype.get = function(scope, key) {
|
||||
var storagePath = getStoragePath(this.storageBaseDir ,scope);
|
||||
return loadFile(storagePath + ".json").then(function(data){
|
||||
if(data){
|
||||
@ -99,7 +99,7 @@ LocalFileSystem.prototype.getAsync = function(scope, key) {
|
||||
});
|
||||
};
|
||||
|
||||
LocalFileSystem.prototype.setAsync =function(scope, key, value) {
|
||||
LocalFileSystem.prototype.set =function(scope, key, value) {
|
||||
var storagePath = getStoragePath(this.storageBaseDir ,scope);
|
||||
return loadFile(storagePath + ".json").then(function(data){
|
||||
var obj = data ? JSON.parse(data) : {}
|
||||
@ -113,7 +113,7 @@ LocalFileSystem.prototype.setAsync =function(scope, key, value) {
|
||||
});
|
||||
};
|
||||
|
||||
LocalFileSystem.prototype.keysAsync = function(scope){
|
||||
LocalFileSystem.prototype.keys = function(scope){
|
||||
var storagePath = getStoragePath(this.storageBaseDir ,scope);
|
||||
return loadFile(storagePath + ".json").then(function(data){
|
||||
if(data){
|
||||
|
@ -55,18 +55,6 @@ Memory.prototype.keys = function(scope){
|
||||
}
|
||||
};
|
||||
|
||||
Memory.prototype.getAsync = function(scope, key) {
|
||||
return Promise.resolve(this.get(scope, key));
|
||||
};
|
||||
|
||||
Memory.prototype.setAsync =function(scope, key, value) {
|
||||
return Promise.resolve(this.set(scope, key, value));
|
||||
};
|
||||
|
||||
Memory.prototype.keysAsync = function(scope){
|
||||
return Promise.resolve(this.keys(scope));
|
||||
};
|
||||
|
||||
Memory.prototype.delete = function(scope){
|
||||
delete this.data[scope];
|
||||
return Promise.resolve();
|
||||
|
@ -168,25 +168,25 @@ describe('context', function() {
|
||||
|
||||
describe('external context storage',function() {
|
||||
var sandbox = sinon.sandbox.create();
|
||||
var stubGetAsync = sandbox.stub().returns(Promise.resolve());
|
||||
var stubSetAsync = sandbox.stub().returns(Promise.resolve());
|
||||
var stubKeysAsync = sandbox.stub().returns(Promise.resolve());
|
||||
var stubGet = sandbox.stub().returns(Promise.resolve());
|
||||
var stubSet = sandbox.stub().returns(Promise.resolve());
|
||||
var stubKeys = sandbox.stub().returns(Promise.resolve());
|
||||
var stubDelete = sandbox.stub().returns(Promise.resolve());
|
||||
var stubClean = sandbox.stub().returns(Promise.resolve());
|
||||
var stubOpen = sandbox.stub().returns(Promise.resolve());
|
||||
var stubClose = sandbox.stub().returns(Promise.resolve());
|
||||
var stubGetAsync2 = sandbox.stub().returns(Promise.resolve());
|
||||
var stubSetAsync2 = sandbox.stub().returns(Promise.resolve());
|
||||
var stubKeysAsync2 = sandbox.stub().returns(Promise.resolve());
|
||||
var stubGet2 = sandbox.stub().returns(Promise.resolve());
|
||||
var stubSet2 = sandbox.stub().returns(Promise.resolve());
|
||||
var stubKeys2 = sandbox.stub().returns(Promise.resolve());
|
||||
var stubDelete2 = sandbox.stub().returns(Promise.resolve());
|
||||
var stubClean2 = sandbox.stub().returns(Promise.resolve());
|
||||
var stubOpen2 = sandbox.stub().returns(Promise.resolve());
|
||||
var stubClose2 = sandbox.stub().returns(Promise.resolve());
|
||||
var testPlugin = function(config){
|
||||
function Test(){}
|
||||
Test.prototype.getAsync = stubGetAsync;
|
||||
Test.prototype.setAsync = stubSetAsync;
|
||||
Test.prototype.keysAsync = stubKeysAsync;
|
||||
Test.prototype.get = stubGet;
|
||||
Test.prototype.set = stubSet;
|
||||
Test.prototype.keys = stubKeys;
|
||||
Test.prototype.delete = stubDelete;
|
||||
Test.prototype.clean = stubClean;
|
||||
Test.prototype.open = stubOpen;
|
||||
@ -195,9 +195,9 @@ describe('context', function() {
|
||||
};
|
||||
var testPlugin2 = function(config){
|
||||
function Test2(){}
|
||||
Test2.prototype.getAsync = stubGetAsync2;
|
||||
Test2.prototype.setAsync = stubSetAsync2;
|
||||
Test2.prototype.keysAsync = stubKeysAsync2;
|
||||
Test2.prototype.get = stubGet2;
|
||||
Test2.prototype.set = stubSet2;
|
||||
Test2.prototype.keys = stubKeys2;
|
||||
Test2.prototype.delete = stubDelete2;
|
||||
Test2.prototype.clean = stubClean2;
|
||||
Test2.prototype.open = stubOpen2;
|
||||
@ -262,14 +262,14 @@ describe('context', function() {
|
||||
return Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
return Promise.all([
|
||||
context.setAsync("##%&.sign","sign1").then(function(){
|
||||
return context.getAsync("##%&.sign").should.finally.equal("sign1");
|
||||
context.set("##%&.sign","sign1").then(function(){
|
||||
return context.get("##%&.sign").should.finally.equal("sign1");
|
||||
}),
|
||||
context.setAsync("#\u3042.file2","file2").then(function(){
|
||||
return context.getAsync("#\u3042.file2").should.finally.equal("file2");
|
||||
context.set("#\u3042.file2","file2").then(function(){
|
||||
return context.get("#\u3042.file2").should.finally.equal("file2");
|
||||
}),
|
||||
context.setAsync("#1.num","num3").then(function(){
|
||||
return context.getAsync("#1.num").should.finally.equal("num3");
|
||||
context.set("#1.num","num3").then(function(){
|
||||
return context.get("#1.num").should.finally.equal("num3");
|
||||
})
|
||||
]);
|
||||
});
|
||||
@ -279,13 +279,13 @@ describe('context', function() {
|
||||
return Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
return Promise.all([
|
||||
context.setAsync("#_.foo","bar"),
|
||||
context.getAsync("#_.foo"),
|
||||
context.keysAsync("#_")
|
||||
context.set("#_.foo","bar"),
|
||||
context.get("#_.foo"),
|
||||
context.keys("#_")
|
||||
]).then(function(){
|
||||
stubSetAsync.called.should.be.false();
|
||||
stubGetAsync.called.should.be.false();
|
||||
stubKeysAsync.called.should.be.false();
|
||||
stubSet.called.should.be.false();
|
||||
stubGet.called.should.be.false();
|
||||
stubKeys.called.should.be.false();
|
||||
});
|
||||
});
|
||||
});
|
||||
@ -333,13 +333,13 @@ describe('context', function() {
|
||||
return Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
return Promise.all([
|
||||
context.setAsync("#test.foo","test"),
|
||||
context.getAsync("#test.foo"),
|
||||
context.keysAsync("#test")
|
||||
context.set("#test.foo","test"),
|
||||
context.get("#test.foo"),
|
||||
context.keys("#test")
|
||||
]).then(function(){
|
||||
stubSetAsync.calledWithExactly("1:flow","foo","test").should.be.true();
|
||||
stubGetAsync.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeysAsync.calledWithExactly("1:flow").should.be.true();
|
||||
stubSet.calledWithExactly("1:flow","foo","test").should.be.true();
|
||||
stubGet.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeys.calledWithExactly("1:flow").should.be.true();
|
||||
});
|
||||
});
|
||||
});
|
||||
@ -348,13 +348,13 @@ describe('context', function() {
|
||||
return Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
return Promise.all([
|
||||
context.flow.setAsync("#test.foo","test"),
|
||||
context.flow.getAsync("#test.foo"),
|
||||
context.flow.keysAsync("#test")
|
||||
context.flow.set("#test.foo","test"),
|
||||
context.flow.get("#test.foo"),
|
||||
context.flow.keys("#test")
|
||||
]).then(function(){
|
||||
stubSetAsync.calledWithExactly("flow","foo","test").should.be.true();
|
||||
stubGetAsync.calledWithExactly("flow","foo").should.be.true();
|
||||
stubKeysAsync.calledWithExactly("flow").should.be.true();
|
||||
stubSet.calledWithExactly("flow","foo","test").should.be.true();
|
||||
stubGet.calledWithExactly("flow","foo").should.be.true();
|
||||
stubKeys.calledWithExactly("flow").should.be.true();
|
||||
});
|
||||
});
|
||||
});
|
||||
@ -363,13 +363,13 @@ describe('context', function() {
|
||||
return Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
return Promise.all([
|
||||
context.global.setAsync("#test.foo","test"),
|
||||
context.global.getAsync("#test.foo"),
|
||||
context.global.keysAsync("#test")
|
||||
context.global.set("#test.foo","test"),
|
||||
context.global.get("#test.foo"),
|
||||
context.global.keys("#test")
|
||||
]).then(function(){
|
||||
stubSetAsync.calledWithExactly("global","foo","test").should.be.true();
|
||||
stubGetAsync.calledWithExactly("global","foo").should.be.true();
|
||||
stubKeysAsync.calledWithExactly("global").should.be.true();
|
||||
stubSet.calledWithExactly("global","foo","test").should.be.true();
|
||||
stubGet.calledWithExactly("global","foo").should.be.true();
|
||||
stubKeys.calledWithExactly("global").should.be.true();
|
||||
});
|
||||
});
|
||||
});
|
||||
@ -378,16 +378,16 @@ describe('context', function() {
|
||||
return Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
return Promise.all([
|
||||
context.setAsync("#nonexist.foo","test"),
|
||||
context.getAsync("#nonexist.foo"),
|
||||
context.keysAsync("#nonexist")
|
||||
context.set("#nonexist.foo","test"),
|
||||
context.get("#nonexist.foo"),
|
||||
context.keys("#nonexist")
|
||||
]).then(function(){
|
||||
stubGetAsync.called.should.be.false();
|
||||
stubSetAsync.called.should.be.false();
|
||||
stubKeysAsync.called.should.be.false();
|
||||
stubSetAsync2.calledWithExactly("1:flow","foo","test").should.be.true();
|
||||
stubGetAsync2.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeysAsync2.calledWithExactly("1:flow").should.be.true();
|
||||
stubGet.called.should.be.false();
|
||||
stubSet.called.should.be.false();
|
||||
stubKeys.called.should.be.false();
|
||||
stubSet2.calledWithExactly("1:flow","foo","test").should.be.true();
|
||||
stubGet2.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeys2.calledWithExactly("1:flow").should.be.true();
|
||||
});
|
||||
});
|
||||
});
|
||||
@ -396,16 +396,16 @@ describe('context', function() {
|
||||
return Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
return Promise.all([
|
||||
context.setAsync("#default.foo","default"),
|
||||
context.getAsync("#default.foo"),
|
||||
context.keysAsync("#default")
|
||||
context.set("#default.foo","default"),
|
||||
context.get("#default.foo"),
|
||||
context.keys("#default")
|
||||
]).then(function(){
|
||||
stubGetAsync.called.should.be.false();
|
||||
stubSetAsync.called.should.be.false();
|
||||
stubKeysAsync.called.should.be.false();
|
||||
stubSetAsync2.calledWithExactly("1:flow","foo","default").should.be.true();
|
||||
stubGetAsync2.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeysAsync2.calledWithExactly("1:flow").should.be.true();
|
||||
stubGet.called.should.be.false();
|
||||
stubSet.called.should.be.false();
|
||||
stubKeys.called.should.be.false();
|
||||
stubSet2.calledWithExactly("1:flow","foo","default").should.be.true();
|
||||
stubGet2.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeys2.calledWithExactly("1:flow").should.be.true();
|
||||
});
|
||||
});
|
||||
});
|
||||
@ -414,16 +414,16 @@ describe('context', function() {
|
||||
return Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
return Promise.all([
|
||||
context.setAsync("#.foo","alias"),
|
||||
context.getAsync("#.foo"),
|
||||
context.keysAsync("#")
|
||||
context.set("#.foo","alias"),
|
||||
context.get("#.foo"),
|
||||
context.keys("#")
|
||||
]).then(function(){
|
||||
stubGetAsync.called.should.be.false();
|
||||
stubSetAsync.called.should.be.false();
|
||||
stubKeysAsync.called.should.be.false();
|
||||
stubSetAsync2.calledWithExactly("1:flow","foo","alias").should.be.true();
|
||||
stubGetAsync2.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeysAsync2.calledWithExactly("1:flow").should.be.true();
|
||||
stubGet.called.should.be.false();
|
||||
stubSet.called.should.be.false();
|
||||
stubKeys.called.should.be.false();
|
||||
stubSet2.calledWithExactly("1:flow","foo","alias").should.be.true();
|
||||
stubGet2.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeys2.calledWithExactly("1:flow").should.be.true();
|
||||
});
|
||||
});
|
||||
});
|
||||
@ -432,13 +432,13 @@ describe('context', function() {
|
||||
return Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
return Promise.all([
|
||||
context.setAsync("#.foo","alias"),
|
||||
context.getAsync("#.foo"),
|
||||
context.keysAsync("#")
|
||||
context.set("#.foo","alias"),
|
||||
context.get("#.foo"),
|
||||
context.keys("#")
|
||||
]).then(function(){
|
||||
stubSetAsync.calledWithExactly("1:flow","foo","alias").should.be.true();
|
||||
stubGetAsync.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeysAsync.calledWithExactly("1:flow").should.be.true();
|
||||
stubSet.calledWithExactly("1:flow","foo","alias").should.be.true();
|
||||
stubGet.calledWithExactly("1:flow","foo").should.be.true();
|
||||
stubKeys.calledWithExactly("1:flow").should.be.true();
|
||||
});
|
||||
});
|
||||
});
|
||||
@ -446,7 +446,7 @@ describe('context', function() {
|
||||
Context.init({contextStorage:contextStorage});
|
||||
Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
context.getAsync("#nonexist.local");
|
||||
context.get("#nonexist.local");
|
||||
should.fail(null, null, "An error was not thrown using undefined storage for local context");
|
||||
}).catch(function(err) {
|
||||
if (err.name === "ContextError") {
|
||||
@ -460,7 +460,7 @@ describe('context', function() {
|
||||
Context.init({contextStorage:contextStorage});
|
||||
Context.load().then(function(){
|
||||
var context = Context.get("1","flow");
|
||||
context.flow.setAsync("#nonexist.flow");
|
||||
context.flow.set("#nonexist.flow");
|
||||
should.fail(null, null, "An error was not thrown using undefined storage for flow context");
|
||||
}).catch(function(err) {
|
||||
if (err.name === "ContextError") {
|
||||
@ -510,35 +510,35 @@ describe('context', function() {
|
||||
});
|
||||
it('should work correctly with the valid key name',function() {
|
||||
return Promise.all([
|
||||
context.setAsync("#memory.azAZ09#_","valid"),
|
||||
context.setAsync("#memory.a.b","ab")
|
||||
context.set("#memory.azAZ09#_","valid"),
|
||||
context.set("#memory.a.b","ab")
|
||||
]).then(function(){
|
||||
context.getAsync("#memory.azAZ09#_").should.finally.equal("valid");
|
||||
context.getAsync("#memory.a.b").should.finally.equal("ab");
|
||||
context.get("#memory.azAZ09#_").should.finally.equal("valid");
|
||||
context.get("#memory.a.b").should.finally.equal("ab");
|
||||
});
|
||||
});
|
||||
it('should treat the key name without dot as a normal context',function() {
|
||||
return context.setAsync("#memory","normal").then(function(){
|
||||
return context.getAsync("#memory").should.finally.equal("normal");
|
||||
return context.set("#memory","normal").then(function(){
|
||||
return context.get("#memory").should.finally.equal("normal");
|
||||
});
|
||||
});
|
||||
it('should fail when specifying invalid characters',function() {
|
||||
(function() {
|
||||
context.setAsync("#memory.a.-","invalid1");
|
||||
context.set("#memory.a.-","invalid1");
|
||||
}).should.throw();
|
||||
(function() {
|
||||
context.setAsync("#memory.'abc","invalid2");
|
||||
context.set("#memory.'abc","invalid2");
|
||||
}).should.throw();
|
||||
});
|
||||
it('should fail when specifying unnecesary space characters for key name',function() {
|
||||
(function() {
|
||||
context.setAsync("# memory.space","space1");
|
||||
context.set("# memory.space","space1");
|
||||
}).should.throw();
|
||||
(function() {
|
||||
context.setAsync("#memory .space","space2");
|
||||
context.set("#memory .space","space2");
|
||||
}).should.throw();
|
||||
(function() {
|
||||
context.setAsync("#memory. space","space3");
|
||||
context.set("#memory. space","space3");
|
||||
}).should.throw();
|
||||
});
|
||||
});
|
||||
|
@ -37,68 +37,68 @@ describe('localfilesystem',function() {
|
||||
});
|
||||
});
|
||||
|
||||
describe('#getAsync/setAsync',function() {
|
||||
describe('#get/set',function() {
|
||||
it('should store property',function() {
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined()
|
||||
return context.get("nodeX","foo").should.be.finally.undefined()
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo","test");
|
||||
return context.set("nodeX","foo","test");
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo").should.be.finally.equal("test");
|
||||
return context.get("nodeX","foo").should.be.finally.equal("test");
|
||||
});
|
||||
});
|
||||
|
||||
it('should store property - creates parent properties',function() {
|
||||
return context.setAsync("nodeX","foo.bar","test").then(function(){
|
||||
return context.getAsync("nodeX","foo").should.be.finally.eql({bar:"test"});
|
||||
return context.set("nodeX","foo.bar","test").then(function(){
|
||||
return context.get("nodeX","foo").should.be.finally.eql({bar:"test"});
|
||||
});
|
||||
});
|
||||
|
||||
it('should delete property',function() {
|
||||
return context.setAsync("nodeX","foo.abc.bar1","test1")
|
||||
return context.set("nodeX","foo.abc.bar1","test1")
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo.abc.bar2","test2")
|
||||
return context.set("nodeX","foo.abc.bar2","test2")
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo.abc").should.be.finally.eql({bar1:"test1",bar2:"test2"});
|
||||
return context.get("nodeX","foo.abc").should.be.finally.eql({bar1:"test1",bar2:"test2"});
|
||||
}).then(function(){
|
||||
return context.setAsync("nodeX","foo.abc.bar1",undefined).then(function(){
|
||||
return context.getAsync("nodeX","foo.abc").should.be.finally.eql({bar2:"test2"});
|
||||
return context.set("nodeX","foo.abc.bar1",undefined).then(function(){
|
||||
return context.get("nodeX","foo.abc").should.be.finally.eql({bar2:"test2"});
|
||||
});
|
||||
}).then(function(){
|
||||
return context.setAsync("nodeX","foo.abc",undefined).then(function(){
|
||||
return context.getAsync("nodeX","foo.abc").should.be.finally.undefined();
|
||||
return context.set("nodeX","foo.abc",undefined).then(function(){
|
||||
return context.get("nodeX","foo.abc").should.be.finally.undefined();
|
||||
});
|
||||
}).then(function(){
|
||||
return context.setAsync("nodeX","foo",undefined).then(function(){
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined();
|
||||
return context.set("nodeX","foo",undefined).then(function(){
|
||||
return context.get("nodeX","foo").should.be.finally.undefined();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it('should not shared context with other scope', function() {
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.undefined(),
|
||||
context.getAsync("nodeY","foo").should.be.finally.undefined()
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.undefined(),
|
||||
context.get("nodeY","foo").should.be.finally.undefined()
|
||||
]).then(function(){
|
||||
return Promise.all([context.setAsync("nodeX","foo","testX"),
|
||||
context.setAsync("nodeY","foo","testY")])
|
||||
return Promise.all([context.set("nodeX","foo","testX"),
|
||||
context.set("nodeY","foo","testY")])
|
||||
}).then(function(){
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.equal("testX"),
|
||||
context.getAsync("nodeY","foo").should.be.finally.equal("testY")]);
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.equal("testX"),
|
||||
context.get("nodeY","foo").should.be.finally.equal("testY")]);
|
||||
});
|
||||
});
|
||||
|
||||
it('should store string',function() {
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined()
|
||||
return context.get("nodeX","foo").should.be.finally.undefined()
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo","bar");
|
||||
return context.set("nodeX","foo","bar");
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo")
|
||||
return context.get("nodeX","foo")
|
||||
}).then(function(result){
|
||||
result.should.be.String();
|
||||
result.should.be.equal("bar");
|
||||
}).then(function(){
|
||||
return context.setAsync("nodeX","foo","1");
|
||||
return context.set("nodeX","foo","1");
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo")
|
||||
return context.get("nodeX","foo")
|
||||
}).then(function(result){
|
||||
result.should.be.String();
|
||||
result.should.be.equal("1");
|
||||
@ -106,11 +106,11 @@ describe('localfilesystem',function() {
|
||||
});
|
||||
|
||||
it('should store number',function() {
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined()
|
||||
return context.get("nodeX","foo").should.be.finally.undefined()
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo",1);
|
||||
return context.set("nodeX","foo",1);
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo")
|
||||
return context.get("nodeX","foo")
|
||||
}).then(function(result){
|
||||
result.should.be.Number();
|
||||
result.should.be.equal(1);
|
||||
@ -118,33 +118,33 @@ describe('localfilesystem',function() {
|
||||
});
|
||||
|
||||
it('should store null',function() {
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined()
|
||||
return context.get("nodeX","foo").should.be.finally.undefined()
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo",null);
|
||||
return context.set("nodeX","foo",null);
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo").should.be.finally.null();
|
||||
return context.get("nodeX","foo").should.be.finally.null();
|
||||
});
|
||||
});
|
||||
|
||||
it('should store boolean',function() {
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined()
|
||||
return context.get("nodeX","foo").should.be.finally.undefined()
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo",true);
|
||||
return context.set("nodeX","foo",true);
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo").should.be.finally.Boolean().and.true();
|
||||
return context.get("nodeX","foo").should.be.finally.Boolean().and.true();
|
||||
}).then(function(){
|
||||
return context.setAsync("nodeX","foo",false);
|
||||
return context.set("nodeX","foo",false);
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo").should.be.finally.Boolean().and.false();
|
||||
return context.get("nodeX","foo").should.be.finally.Boolean().and.false();
|
||||
});
|
||||
});
|
||||
|
||||
it('should store object',function() {
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined()
|
||||
return context.get("nodeX","foo").should.be.finally.undefined()
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo",{obj:"bar"});
|
||||
return context.set("nodeX","foo",{obj:"bar"});
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo")
|
||||
return context.get("nodeX","foo")
|
||||
}).then(function(result){
|
||||
result.should.be.Object();
|
||||
result.should.eql({obj:"bar"});
|
||||
@ -152,16 +152,16 @@ describe('localfilesystem',function() {
|
||||
});
|
||||
|
||||
it('should store array',function() {
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined()
|
||||
return context.get("nodeX","foo").should.be.finally.undefined()
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo",["a","b","c"]);
|
||||
return context.set("nodeX","foo",["a","b","c"]);
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo")
|
||||
return context.get("nodeX","foo")
|
||||
}).then(function(result){
|
||||
result.should.be.Array();
|
||||
result.should.eql(["a","b","c"]);
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo[1]")
|
||||
return context.get("nodeX","foo[1]")
|
||||
}).then(function(result){
|
||||
result.should.be.String();
|
||||
result.should.equal("b");
|
||||
@ -169,11 +169,11 @@ describe('localfilesystem',function() {
|
||||
});
|
||||
|
||||
it('should store array of arrays',function() {
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined()
|
||||
return context.get("nodeX","foo").should.be.finally.undefined()
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo",[["a","b","c"],[1,2,3,4],[true,false]]);
|
||||
return context.set("nodeX","foo",[["a","b","c"],[1,2,3,4],[true,false]]);
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo")
|
||||
return context.get("nodeX","foo")
|
||||
}).then(function(result){
|
||||
result.should.be.Array();
|
||||
result.should.have.length(3);
|
||||
@ -181,7 +181,7 @@ describe('localfilesystem',function() {
|
||||
result[1].should.have.length(4);
|
||||
result[2].should.have.length(2);
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo[1]")
|
||||
return context.get("nodeX","foo[1]")
|
||||
}).then(function(result){
|
||||
result.should.be.Array();
|
||||
result.should.have.length(4);
|
||||
@ -190,11 +190,11 @@ describe('localfilesystem',function() {
|
||||
});
|
||||
|
||||
it('should store array of objects',function() {
|
||||
return context.getAsync("nodeX","foo").should.be.finally.undefined()
|
||||
return context.get("nodeX","foo").should.be.finally.undefined()
|
||||
.then(function(){
|
||||
return context.setAsync("nodeX","foo",[{obj:"bar1"},{obj:"bar2"},{obj:"bar3"}]);
|
||||
return context.set("nodeX","foo",[{obj:"bar1"},{obj:"bar2"},{obj:"bar3"}]);
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo")
|
||||
return context.get("nodeX","foo")
|
||||
}).then(function(result){
|
||||
result.should.be.Array();
|
||||
result.should.have.length(3);
|
||||
@ -202,7 +202,7 @@ describe('localfilesystem',function() {
|
||||
result[1].should.be.Object();
|
||||
result[2].should.be.Object();
|
||||
}).then(function(){
|
||||
return context.getAsync("nodeX","foo[1]")
|
||||
return context.get("nodeX","foo[1]")
|
||||
}).then(function(result){
|
||||
result.should.be.Object();
|
||||
result.should.be.eql({obj:"bar2"});
|
||||
@ -210,22 +210,22 @@ describe('localfilesystem',function() {
|
||||
});
|
||||
});
|
||||
|
||||
describe('#keysAsync',function() {
|
||||
describe('#keys',function() {
|
||||
it('should enumerate context keys', function() {
|
||||
return context.keysAsync("nodeX").then(function(result){
|
||||
return context.keys("nodeX").then(function(result){
|
||||
result.should.be.an.Array();
|
||||
result.should.be.empty();
|
||||
}).then(function(){
|
||||
return context.setAsync("nodeX","foo","bar");
|
||||
return context.set("nodeX","foo","bar");
|
||||
}).then(function(){
|
||||
return context.keysAsync("nodeX").then(function(result){
|
||||
return context.keys("nodeX").then(function(result){
|
||||
result.should.have.length(1);
|
||||
result[0].should.equal("foo");
|
||||
});
|
||||
}).then(function(){
|
||||
return context.setAsync("nodeX","abc.def","bar");
|
||||
return context.set("nodeX","abc.def","bar");
|
||||
}).then(function(){
|
||||
return context.keysAsync("nodeX").then(function(result){
|
||||
return context.keys("nodeX").then(function(result){
|
||||
result.should.have.length(2);
|
||||
result[1].should.equal("abc");
|
||||
});
|
||||
@ -233,19 +233,19 @@ describe('localfilesystem',function() {
|
||||
});
|
||||
|
||||
it('should enumerate context keys in each scopes', function() {
|
||||
return Promise.all([context.keysAsync("nodeX"),
|
||||
context.keysAsync("nodeY")
|
||||
return Promise.all([context.keys("nodeX"),
|
||||
context.keys("nodeY")
|
||||
]).then(function(results){
|
||||
results[0].should.be.an.Array();
|
||||
results[0].should.be.empty();
|
||||
results[1].should.be.an.Array();
|
||||
results[1].should.be.empty();
|
||||
}).then(function(){
|
||||
return Promise.all([context.setAsync("nodeX","foo","bar"),
|
||||
context.setAsync("nodeY","hoge","piyo")]);
|
||||
return Promise.all([context.set("nodeX","foo","bar"),
|
||||
context.set("nodeY","hoge","piyo")]);
|
||||
}).then(function(){
|
||||
return Promise.all([context.keysAsync("nodeX"),
|
||||
context.keysAsync("nodeY")]);
|
||||
return Promise.all([context.keys("nodeX"),
|
||||
context.keys("nodeY")]);
|
||||
}).then(function(results){
|
||||
results[0].should.have.length(1);
|
||||
results[0][0].should.equal("foo");
|
||||
@ -257,55 +257,55 @@ describe('localfilesystem',function() {
|
||||
|
||||
describe('#delete',function() {
|
||||
it('should delete context',function() {
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.undefined(),
|
||||
context.getAsync("nodeY","foo").should.be.finally.undefined()
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.undefined(),
|
||||
context.get("nodeY","foo").should.be.finally.undefined()
|
||||
]).then(function(){
|
||||
return Promise.all([context.setAsync("nodeX","foo","abc"),
|
||||
context.setAsync("nodeY","foo","abc")]);
|
||||
return Promise.all([context.set("nodeX","foo","abc"),
|
||||
context.set("nodeY","foo","abc")]);
|
||||
}).then(function(){
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.equal("abc"),
|
||||
context.getAsync("nodeY","foo").should.be.finally.equal("abc")])
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.equal("abc"),
|
||||
context.get("nodeY","foo").should.be.finally.equal("abc")])
|
||||
}).then(function(){
|
||||
return context.delete("nodeX");
|
||||
}).then(function(){
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.undefined(),
|
||||
context.getAsync("nodeY","foo").should.be.finally.equal("abc")]);
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.undefined(),
|
||||
context.get("nodeY","foo").should.be.finally.equal("abc")]);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('#clean',function() {
|
||||
it('should clean unnecessary context',function() {
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.undefined(),
|
||||
context.getAsync("nodeY","foo").should.be.finally.undefined()
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.undefined(),
|
||||
context.get("nodeY","foo").should.be.finally.undefined()
|
||||
]).then(function(){
|
||||
return Promise.all([context.setAsync("nodeX","foo","abc"),
|
||||
context.setAsync("nodeY","foo","abc")]);
|
||||
return Promise.all([context.set("nodeX","foo","abc"),
|
||||
context.set("nodeY","foo","abc")]);
|
||||
}).then(function(){
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.equal("abc"),
|
||||
context.getAsync("nodeY","foo").should.be.finally.equal("abc")])
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.equal("abc"),
|
||||
context.get("nodeY","foo").should.be.finally.equal("abc")])
|
||||
}).then(function(){
|
||||
return context.clean([]);
|
||||
}).then(function(){
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.undefined(),
|
||||
context.getAsync("nodeY","foo").should.be.finally.undefined()]);
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.undefined(),
|
||||
context.get("nodeY","foo").should.be.finally.undefined()]);
|
||||
});
|
||||
});
|
||||
|
||||
it('should not clean active context',function() {
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.undefined(),
|
||||
context.getAsync("nodeY","foo").should.be.finally.undefined()
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.undefined(),
|
||||
context.get("nodeY","foo").should.be.finally.undefined()
|
||||
]).then(function(){
|
||||
return Promise.all([context.setAsync("nodeX","foo","abc"),
|
||||
context.setAsync("nodeY","foo","abc")]);
|
||||
return Promise.all([context.set("nodeX","foo","abc"),
|
||||
context.set("nodeY","foo","abc")]);
|
||||
}).then(function(){
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.equal("abc"),
|
||||
context.getAsync("nodeY","foo").should.be.finally.equal("abc")])
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.equal("abc"),
|
||||
context.get("nodeY","foo").should.be.finally.equal("abc")])
|
||||
}).then(function(){
|
||||
return context.clean(["nodeX"]);
|
||||
}).then(function(){
|
||||
return Promise.all([context.getAsync("nodeX","foo").should.be.finally.equal("abc"),
|
||||
context.getAsync("nodeY","foo").should.be.finally.undefined()]);
|
||||
return Promise.all([context.get("nodeX","foo").should.be.finally.equal("abc"),
|
||||
context.get("nodeY","foo").should.be.finally.undefined()]);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
Loading…
x
Reference in New Issue
Block a user