chore(seed): Refactoring to use logger (#16443)
parent
575ea380dc
commit
6521839ff4
|
@ -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);
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in New Issue