chore(seed): Refactoring to use logger (#16443)

pull/15980/head
mrugesh mohapatra 2018-01-08 18:38:29 +05:30 committed by Stuart Taylor
parent 575ea380dc
commit 6521839ff4
1 changed files with 38 additions and 33 deletions

View File

@ -1,28 +1,33 @@
/* eslint-disable no-process-exit */ /* eslint-disable no-process-exit */
require('babel-register'); require('babel-register');
require('dotenv').load(); require('dotenv').load();
var adler32 = require('adler32'); const adler32 = require('adler32');
var Rx = require('rx'), const Rx = require('rx');
_ = require('lodash'), const _ = require('lodash');
utils = require('../server/utils'), const utils = require('../server/utils');
getChallenges = require('./getChallenges'), const getChallenges = require('./getChallenges');
app = require('../server/server'); const app = require('../server/server');
const createDebugger = require('debug');
const log = createDebugger('fcc:seed');
// force logger to always output
// this may be brittle
log.enabled = true;
var dasherize = utils.dasherize; const dasherize = utils.dasherize;
var nameify = utils.nameify; const nameify = utils.nameify;
var Observable = Rx.Observable; const Observable = Rx.Observable;
var Challenge = app.models.Challenge; const Challenge = app.models.Challenge;
var destroyChallenges = const destroyChallenges =
Observable.fromNodeCallback(Challenge.destroyAll, Challenge); Observable.fromNodeCallback(Challenge.destroyAll, Challenge);
var createChallenges = const createChallenges =
Observable.fromNodeCallback(Challenge.create, Challenge); Observable.fromNodeCallback(Challenge.create, Challenge);
var Block = app.models.Block; const Block = app.models.Block;
var destroyBlocks = Observable.fromNodeCallback(Block.destroyAll, Block); const destroyBlocks = Observable.fromNodeCallback(Block.destroyAll, Block);
var createBlocks = Observable.fromNodeCallback(Block.create, Block); const createBlocks = Observable.fromNodeCallback(Block.create, Block);
const arrToString = arr => const arrToString = arr =>
Array.isArray(arr) ? arr.join('\n') : _.toString(arr); Array.isArray(arr) ? arr.join('\n') : _.toString(arr);
@ -33,28 +38,28 @@ Observable.combineLatest(
.last() .last()
.flatMap(function() { return Observable.from(getChallenges()); }) .flatMap(function() { return Observable.from(getChallenges()); })
.flatMap(function(challengeSpec) { .flatMap(function(challengeSpec) {
var order = challengeSpec.order; const order = challengeSpec.order;
var blockName = challengeSpec.name; const blockName = challengeSpec.name;
var superBlock = challengeSpec.superBlock; const superBlock = challengeSpec.superBlock;
var superOrder = challengeSpec.superOrder; const superOrder = challengeSpec.superOrder;
var isBeta = !!challengeSpec.isBeta; const isBeta = !!challengeSpec.isBeta;
var isComingSoon = !!challengeSpec.isComingSoon; const isComingSoon = !!challengeSpec.isComingSoon;
var fileName = challengeSpec.fileName; const fileName = challengeSpec.fileName;
var helpRoom = challengeSpec.helpRoom || 'Help'; const helpRoom = challengeSpec.helpRoom || 'Help';
var time = challengeSpec.time || 'N/A'; const time = challengeSpec.time || 'N/A';
var isLocked = !!challengeSpec.isLocked; const isLocked = !!challengeSpec.isLocked;
var message = challengeSpec.message; const message = challengeSpec.message;
var required = challengeSpec.required || []; const required = challengeSpec.required || [];
var template = challengeSpec.template; const template = challengeSpec.template;
console.log('parsed %s successfully', blockName); log('parsed %s successfully', blockName);
// challenge file has no challenges... // challenge file has no challenges...
if (challengeSpec.challenges.length === 0) { if (challengeSpec.challenges.length === 0) {
return Rx.Observable.just([{ block: 'empty ' + blockName }]); return Rx.Observable.just([{ block: 'empty ' + blockName }]);
} }
var block = { const block = {
title: blockName, title: blockName,
name: nameify(blockName), name: nameify(blockName),
dashedName: dasherize(blockName), dashedName: dasherize(blockName),
@ -68,7 +73,7 @@ Observable.combineLatest(
return createBlocks(block) return createBlocks(block)
.map(block => { .map(block => {
console.log('successfully created %s block', block.name); log('successfully created %s block', block.name);
return challengeSpec.challenges return challengeSpec.challenges
.map(function(challenge, index) { .map(function(challenge, index) {
@ -123,11 +128,11 @@ Observable.combineLatest(
}) })
.subscribe( .subscribe(
function(challenges) { function(challenges) {
console.log('%s successfully saved', challenges[0].block); log('%s successfully saved', challenges[0].block);
}, },
function(err) { throw err; }, function(err) { throw err; },
function() { function() {
console.log('challenge seed completed'); log('challenge seed completed');
process.exit(0); process.exit(0);
} }
); );