add to seed script: exit on error
filter challenge blocks that do not have challenges
This commit is contained in:
29
index.js
29
index.js
@ -17,23 +17,25 @@ var Nonprofit = app.models.Nonprofit;
|
|||||||
var Job = app.models.Job;
|
var Job = app.models.Job;
|
||||||
var counter = 0;
|
var counter = 0;
|
||||||
var challenges = getFilesFor('challenges');
|
var challenges = getFilesFor('challenges');
|
||||||
|
// plus two accounts for nonprofits and jobs seed.
|
||||||
|
var numberToSave = challenges.length + 1;
|
||||||
|
|
||||||
function completionMonitor() {
|
function completionMonitor() {
|
||||||
// Increment counter
|
// Increment counter
|
||||||
counter++;
|
counter++;
|
||||||
|
|
||||||
// Exit if all challenges have been checked
|
// Exit if all challenges have been checked
|
||||||
if (counter > challenges.length) {
|
if (counter >= numberToSave) {
|
||||||
process.exit(0);
|
process.exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Log where in the seed order we're currently at
|
// Log where in the seed order we're currently at
|
||||||
console.log('Call: ' + counter + "/" + challenges.length);
|
console.log('Call: ' + counter + '/' + numberToSave);
|
||||||
}
|
}
|
||||||
|
|
||||||
Challenge.destroyAll(function(err, info) {
|
Challenge.destroyAll(function(err, info) {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.error(err);
|
throw err;
|
||||||
} else {
|
} else {
|
||||||
console.log('Deleted ', info);
|
console.log('Deleted ', info);
|
||||||
}
|
}
|
||||||
@ -42,6 +44,13 @@ Challenge.destroyAll(function(err, info) {
|
|||||||
var order = challengeSpec.order;
|
var order = challengeSpec.order;
|
||||||
var block = challengeSpec.name;
|
var block = challengeSpec.name;
|
||||||
|
|
||||||
|
// challenge file has no challenges...
|
||||||
|
if (challengeSpec.challenges.length === 0) {
|
||||||
|
console.log('file %s has no challenges', file);
|
||||||
|
completionMonitor();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
var challenges = challengeSpec.challenges
|
var challenges = challengeSpec.challenges
|
||||||
.map(function(challenge, index) {
|
.map(function(challenge, index) {
|
||||||
// NOTE(berks): add title for displaying in views
|
// NOTE(berks): add title for displaying in views
|
||||||
@ -64,10 +73,10 @@ Challenge.destroyAll(function(err, info) {
|
|||||||
challenges,
|
challenges,
|
||||||
function(err) {
|
function(err) {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log(err);
|
throw err;
|
||||||
} else {
|
} else {
|
||||||
console.log('Successfully parsed %s', file);
|
console.log('Successfully parsed %s', file);
|
||||||
completionMonitor();
|
completionMonitor(err);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
@ -82,28 +91,28 @@ Nonprofit.destroyAll(function(err, info) {
|
|||||||
}
|
}
|
||||||
Nonprofit.create(nonprofits, function(err, data) {
|
Nonprofit.create(nonprofits, function(err, data) {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log(err);
|
throw err;
|
||||||
} else {
|
} else {
|
||||||
console.log('Saved ', data);
|
console.log('Saved ', data);
|
||||||
}
|
}
|
||||||
completionMonitor();
|
completionMonitor(err);
|
||||||
console.log('nonprofits');
|
console.log('nonprofits');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
Job.destroyAll(function(err, info) {
|
Job.destroyAll(function(err, info) {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.error(err);
|
throw err;
|
||||||
} else {
|
} else {
|
||||||
console.log('Deleted ', info);
|
console.log('Deleted ', info);
|
||||||
}
|
}
|
||||||
Job.create(jobs, function(err, data) {
|
Job.create(jobs, function(err, data) {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log(err);
|
console.log('error: ', err);
|
||||||
} else {
|
} else {
|
||||||
console.log('Saved ', data);
|
console.log('Saved ', data);
|
||||||
}
|
}
|
||||||
console.log('jobs');
|
console.log('jobs');
|
||||||
completionMonitor();
|
completionMonitor(err);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
Reference in New Issue
Block a user