salix/gulpfile.js

235 lines
6.5 KiB
JavaScript
Raw Normal View History

var gulp = require('gulp');
var jasmine = require('gulp-jasmine');
var gutil = require('gulp-util');
var wrap = require('gulp-wrap');
var concat = require('gulp-concat');
var merge = require('merge-stream');
2017-06-02 12:17:57 +00:00
var extend = require('gulp-extend');
var install = require('gulp-install');
var print = require('gulp-print');
2017-10-18 16:26:40 +00:00
var runSequence = require('run-sequence');
var del = require('del');
2017-05-29 16:48:50 +00:00
var fs = require('fs');
var webpack = require('webpack');
var WebpackDevServer = require('webpack-dev-server');
2017-10-18 04:41:17 +00:00
var exec = require('child_process').exec;
// Configuration
2017-03-01 08:55:17 +00:00
var srcDir = './client';
var buildDir = './services/nginx/static';
var langs = ['es', 'en'];
2017-10-05 10:38:28 +00:00
var modules = require('./client/modules.json');
var webpackConfig = require('./webpack.config.js');
2017-05-16 10:37:48 +00:00
// Main tasks
gulp.task('default', () => {
return gulp.start('services', 'client');
2017-05-16 10:37:48 +00:00
});
gulp.task('client', ['clean'], () => {
2017-05-16 10:37:48 +00:00
return gulp.start('watch', 'routes', 'locales', 'webpack-dev-server');
});
gulp.task('services', callback => {
let isWindows = /^win/.test(process.platform);
let command = isWindows ? 'docker inspect dblocal | findstr Status' : 'docker inspect dblocal | grep Status';
exec(command, (err, stdout, stderr) => {
let isNotRunning = !stdout.includes('running');
if (isNotRunning) {
2018-02-01 11:52:58 +00:00
runSequence('docker-wait', 'services-run', callback);
} else {
2018-02-01 11:52:58 +00:00
runSequence('services-run', callback);
}
});
});
2018-01-31 11:17:17 +00:00
2018-02-01 11:52:58 +00:00
gulp.task('services-run', ['nginx'], () => {
const servicesPath = './services/';
const services = fs.readdirSync(servicesPath);
services.splice(services.indexOf('loopback'), 1);
return services.forEach(service => {
const serviceJs = servicesPath.concat(service, '/server/server.js');
if (fs.existsSync(serviceJs))
require(serviceJs).start();
});
});
2018-02-01 15:01:49 +00:00
gulp.task('e2e', ['docker-wait'], () => {
2018-02-01 11:52:58 +00:00
return gulp.start('e2e-run');
2018-02-01 07:48:54 +00:00
});
2018-02-01 15:01:49 +00:00
gulp.task('e2e-run', () => {
2018-02-01 07:48:54 +00:00
gulp.src('./e2e_tests.js')
.pipe(jasmine({reporter: 'none'}));
});
2018-02-01 15:01:49 +00:00
gulp.task('clean', () => {
return del([`${buildDir}/*`, `!${buildDir}/templates`, `!${buildDir}/images`], {force: true});
});
gulp.task('install', () => {
const servicesPath = './services/';
const jsonFile = [];
const services = fs.readdirSync(servicesPath);
services.push('..');
services.forEach(service => {
jsonFile.push(servicesPath.concat(service, '/package.json'));
});
return gulp.src(jsonFile)
.pipe(print(filepath => {
return `Installing packages in ${filepath}`;
}))
.pipe(install({
npm: ['--no-package-lock']
}));
});
gulp.task('build', ['clean'], () => {
return gulp.start('routes', 'locales', 'webpack');
});
// Nginx
gulp.task('nginx', callback => {
let isWindows = /^win/.test(process.platform);
let command = isWindows ? 'start.cmd' : 'start.sh';
command = `./services/nginx/${command}`;
exec(command, (err, stdout, stderr) => {
console.log(stdout);
callback(err);
});
});
// Webpack
2017-10-05 10:38:28 +00:00
gulp.task('webpack', function(cb) {
var configCopy = Object.create(webpackConfig);
var compiler = webpack(configCopy);
compiler.run(function(err, stats) {
if (err) throw new gutil.PluginError('webpack', err);
gutil.log('[webpack]', stats.toString({colors: true}));
2017-05-17 10:07:42 +00:00
cb();
});
});
2017-10-05 10:38:28 +00:00
gulp.task('webpack-dev-server', function() {
var configCopy = Object.create(webpackConfig);
2017-03-01 08:55:17 +00:00
for (var entry in configCopy.entry) {
configCopy.entry[entry]
2017-09-17 13:09:10 +00:00
.unshift('webpack-dev-server/client?http://127.0.0.1:8081/');
2017-03-01 08:55:17 +00:00
}
var compiler = webpack(configCopy);
2017-03-01 08:55:17 +00:00
new WebpackDevServer(compiler, {
publicPath: '/',
contentBase: buildDir,
quiet: false,
noInfo: false,
// hot: true,
stats: {
assets: true,
colors: true,
version: false,
hash: false,
timings: true,
chunks: false,
chunkModules: false
}
2017-09-17 13:09:10 +00:00
}).listen(8081, '127.0.0.1', function(err) {
if (err) throw new gutil.PluginError('webpack-dev-server', err);
});
});
// Locale
var localeFiles = `${srcDir}/**/locale/*.json`;
gulp.task('locales', function() {
var streams = [];
2017-03-07 16:11:56 +00:00
for (var mod in modules)
2017-03-01 08:55:17 +00:00
for (var lang of langs) {
var localeFiles = `./client/${mod}/**/locale/${lang}.json`;
streams.push(gulp.src(localeFiles)
.pipe(extend(`${lang}.json`))
.pipe(gulp.dest(`${buildDir}/locale/${mod}`)));
}
return merge(streams);
});
// Routes
var routeFiles = `${srcDir}/**/routes.json`;
gulp.task('routes', function() {
return gulp.src(routeFiles)
.pipe(concat('routes.js', {newLine: ','}))
.pipe(wrap('var routes = [<%=contents%>\n];'))
.pipe(gulp.dest(buildDir));
});
// Watch
gulp.task('watch', function() {
gulp.watch(routeFiles, ['routes']);
gulp.watch(localeFiles, ['locales']);
});
2017-10-18 04:41:17 +00:00
2018-02-01 15:01:49 +00:00
// Docker
gulp.task('docker', callback => {
2018-02-01 11:52:58 +00:00
runSequence('docker-delete', 'docker-delete-image', 'docker-build', 'docker-run', callback);
});
2018-02-01 11:52:58 +00:00
gulp.task('docker-wait', ['docker'], callback => {
let maxInterval = 30 * 60000;
2018-02-01 07:48:54 +00:00
let interval = 1000;
let timer = 0;
console.log('Waiting for MySQL init process...');
let waitForLocaldb = setInterval(() => {
if (timer < maxInterval) {
timer += interval;
exec('docker logs --tail 4 dblocal', (err, stdout, stderr) => {
if (stdout.includes('MySQL init process done. Ready for start up.')) {
clearInterval(waitForLocaldb);
callback(err);
}
});
} else {
console.log(`MySQL connection not established whithin ${maxInterval / 1000} secs!`);
clearInterval(waitForLocaldb);
}
}, interval);
});
2018-02-01 11:52:58 +00:00
gulp.task('docker-run', callback => {
exec('docker run -d --name dblocal -p 3306:3306 dblocal', (err, stdout, stderr) => {
callback(err);
});
});
gulp.task('docker-build', callback => {
exec('docker build -t dblocal:latest ./services/db', (err, stdout, stderr) => {
callback(err);
});
});
gulp.task('docker-delete-image', callback => {
exec('docker rmi dblocal:latest', (err, stdout, stderr) => {
callback(err);
});
});
gulp.task('docker-delete', callback => {
exec('docker stop dblocal && docker wait dblocal && docker rm -f dblocal', (err, stdout, stderr) => {
callback(err);
});
});