Myślę, że źle rozumiesz, jak async.series działa.
Twoje funkcje w async.series nie odbieraj callback jako argument i nie nazywają tego. I to request(...) rzeczy prawdopodobnie w ogóle nie są funkcją. Prawdopodobnie dlatego przerywa pętlę asynchroniczną. Spróbuj tego:
async.series(
[
function(callback) { // <--- missing callback
log('starting');
db.connect('mongodb://127.0.0.1:27017/test',
function(err, base){
if(err) throw err;
db = base;
callback(); // <--- missing callback
});
},
function(callback) { // <--- missing function with callback
request(website, function(err,resp,body) {
start(err, resp, body, callback);
})
}
],
function(){
log('closing DB');
db.close();
}
);
Zauważ, że dodałem callback argument podczas wywoływania start . W związku z tym będziesz musiał dokonać refaktoryzacji kodu, aby każda funkcja akceptowała callback które można nazwać na końcu, gdy wiesz, że wszystkie prace są wykonane. Na przykład możesz dodać async.parallel wewnątrz start a ta funkcja może wyglądać tak:
function start(err, resp, body, callback) {
// some stuff happens here
var jobs = []
pageURLS.forEach(function(url, index, array){
jobs.push(function(clb) {
request(url, function(error,response,bodies) {
// some stuff
clb(); // <--- this refers to the local callback for the job
});
});
});
async.parallel(jobs, function() {
// all jobs are done, let's finilize everything
callback();
});
};