I want to test many methods one after the other with one methods output has to be passed to next method.
For Example : I have 2 methods to test, called add and delete. add method's onsuccess will return added object(with its id). same object i want to pass to delete method so that created object gets deleted.
exports.add = function(test) {
nodemanager.add({
name : 'my name'
}, function(node) {
//this is onsuccess callback.
test.ok(node && node.id, 'Failed to get added node\'s info');
test.done();
});
}
exports.del = function(test) {
//Here i need to pass node object returned from onsuccess on add method.
nodemanager.del(node, function(node) {
test.ok(node, 'Deleted node is null');
test.done()
});
}
One way is, defining node object outside of these 2 functions and access from both the methods.
I was just wondering if this is the proper way or is there a better approach.
It is common practice to isolate tests from each other. There are test suites that run tests in random order to make sure that users don't rely on any order.
So if your second test checks that an added node can be deleted, it should ensure that this element is available. Probably something like this:
exports.add = function(test) {
nodemanager.add({
name : 'my name'
}, function(node) {
test.ok(node && node.id, 'Failed to get added node\'s info');
test.done();
});
}
exports.del = function(test) {
nodemanager.add({
name : 'my name'
}, function(addedNode) {
nodemanager.del(addedNode, function(deletedNode) {
test.ok(deletedNode, 'Deleted node is null');
test.done()
});
});
}
Of course this solution has another problem: If nodemanager.add breaks your del test will fail, too. However, I think that's acceptable here, if it is hard to mock the add behavior here.