at bruge async kunne være meget praktisk.
al forretningslogik/opgaver i sidste ende er blot en sekvens af operationer. vandfald er en abstraktion meget nyttig til din løsning.
for eksempel:seed.js
var User = require('../path/to/your/models/User');
var Post = require('../path/to/your/models/Post');
var DB = require('../path/to/your/database/boot/module');
var config = require('../path/to/your/configuration');
function startDB(config, callback) {
DB.start(config, callback);
}
function createUsers(userParams, callback) {
User.save(userParams, callback);
}
function createPost(users, callback) {
Post.save(users, callback);
}
function resolvedCallback(err, posts) {
if (err)
return your-error-handling-here;
console.log(posts);
DB.cleanup(console.log.bind(null, 'clean up finished: '));
}
async.waterfall([
async.constant({ db: config.dbOpts}),
startDB, // we don't need the wrapper, we could use DB.start
createUsers,
createPost ], resolvedCallback);
Hvis du bruger en testramme (mokka/tape), kan du initialisere databasen før alle dine test og oprydning før start/efter alle test.
skål