add to seed script: exit on error

filter challenge blocks that do not have challenges
This commit is contained in:
Berkeley Martinez
2015-08-10 12:14:38 -07:00
parent 2f714f1541
commit b1003b403c

View File

@ -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);
}); });
}); });