也许我只是在搞清楚回调性,但我无法找到一种方法来测试node.js中的保存和加载。
我的测试是这样的:
vows.describe('Saving').addBatch({
'Single item can be saved':{
topic:function () {
myStore.saveItems(1, [{id:3,name:'squat'}]);
myStore.getItems(1, this.callback);
},
'saved item is returned by getItems':function (err, items) {
assert.equal(items.length, 1);
assert.equal(items[0].deviceId, 1);
assert.equal(items[0].id, 3);
}
}
}).export(module);
经过测试:
exports.saveItems = function (deviceId, items) {
var itemsCollection = db.collection('items');
itemsCollection.find({deviceId:deviceId}).toArray(function (err, existingItems) {
_.each(items, function (item) {
item['deviceId'] = deviceId;
var existingItem = _.find(existingItems, function (existingItem) {
return existingItem.id === item.id
});
if (typeof(existingItem) === 'undefined') {
itemsCollection.save(item);//callback here?
} else {
}
});
});
};
exports.getItems = function (deviceId, callback) {
var itemsCollection = db.collection('items');
itemsCollection.find({deviceId:deviceId}).toArray(callback);
};
我是否有办法将回调传递给saveItems
,以便在所有 mongo保存完成之前不会调用getItems
?
答案 0 :(得分:2)
试试这个:)
vows.describe('Saving').addBatch({
'Single item can be saved':{
topic:function () {
var topicThis = this;
// NEW: having a callback here
myStore.saveItems(1, [{id:3,name:'squat'}], function(err, results){
myStore.getItems(1, topicThis.callback);
});
},
'saved item is returned by getItems':function (err, items) {
assert.equal(items.length, 1);
assert.equal(items[0].deviceId, 1);
assert.equal(items[0].id, 3);
}
}
}).export(module);
// https://github.com/caolan/async
var async = require('async');
// NEW: having a callback here
exports.saveItems = function (deviceId, items, cb) {
var itemsCollection = db.collection('items');
itemsCollection.find({deviceId:deviceId}).toArray(function (err, existingItems) {
var tasks = [];
// here you are iterating over each item, doing some work, and then conditionally doing an async op
_.each(items, function (item) {
item['deviceId'] = deviceId;
var existingItem = _.find(existingItems, function (existingItem) {
return existingItem.id === item.id
});
if (typeof(existingItem) === 'undefined') {
// so this is async, b/c it's talking to mongo
// NEW: add it to our list of tasks, when are later run in parallel
tasks.push(function(nextTask){
itemsCollection.save(item, nextTask);
});
}
});
// NEW: run it all in parrallel, when done, call back
async.parallel(tasks, function(err, results) {
cb(err, results);
})
});
};
答案 1 :(得分:1)
使用node.js mongo db驱动程序: http://mongodb.github.com/node-mongodb-native/api-articles/nodekoarticle1.html
插入和更新功能都是使用回调定义的。我只使用更新函数,因为它也可以作为插入(如果下面的第一个参数不能获取任何记录)。
itemsCollection.update({_id: itemId}, item, {upsert:true, safe:true}, function (err, result) {
// callback here
});