//-- copyright // OpenProject is a project management system. // Copyright (C) 2012-2015 the OpenProject Foundation (OPF) // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License version 3. // // OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows: // Copyright (C) 2006-2013 Jean-Philippe Lang // Copyright (C) 2010-2013 the ChiliProject Team // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License // as published by the Free Software Foundation; either version 2 // of the License, or (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // // See doc/COPYRIGHT.rdoc for more details. //++ var gulp = require('gulp'); var jshint = require('gulp-jshint'); var gulpWebpack = require('gulp-webpack'); var webpack = require('webpack'); var config = require('./webpack.config.js'); var sass = require('gulp-ruby-sass'); var watch = require('gulp-watch'); var livingstyleguide = require('gulp-livingstyleguide'); var protractor = require('gulp-protractor').protractor, webdriverStandalone = require('gulp-protractor').webdriver_standalone, webdriverUpdate = require('gulp-protractor').webdriver_update; var server; var paths = { scripts: [ 'app/**/*.js', '!app/vendor/**/*.js' ], fonts: '../app/assets/fonts/**/*' }; gulp.task('lint', function() { return gulp.src(paths.scripts) .pipe(jshint('.jshintrc')) .pipe(jshint.reporter('jshint-stylish')); }); gulp.task('webpack', function() { return gulp.src('app/openproject-app.js') .pipe(gulpWebpack(config)) .pipe(gulp.dest('../app/assets/javascripts/bundles')); }); gulp.task('fonts', function() { return gulp.src(paths.fonts).pipe(gulp.dest('./public')); }); gulp.task('sass', function() { return gulp.src('../app/assets/stylesheets/default.css.sass') .pipe(sass({ bundleExec: true, loadPath: [ './bower_components/foundation-apps/scss', './bower_components/bourbon/app/assets/stylesheets' ] })) .on('error', function(err) { console.log(err.message); }) .pipe(gulp.dest('tmp/stylesheets')); }); gulp.task('styleguide', function () { process.env.SASS_PATH = [ '../app/assets/stylesheets', './bower_components/foundation-apps/scss', './bower_components/bourbon/app/assets/stylesheets' ].join(':') gulp.src('../app/assets/stylesheets/styleguide.html.lsg') .pipe(livingstyleguide()) .pipe(gulp.dest('public')); }); gulp.task('express', function(done) { var expressApp = require('./server'); var port = process.env.PORT || 8080; (function startServer(port) { server = expressApp.listen(port, function() { console.log('Starting express server at localhost:%d', port); done(); }); server.on('error', function(err) { if (err.code === 'EADDRINUSE') { console.warn('Port %d already in use.', port); startServer(++port); } }); })(port); }); gulp.task('webdriver:update', webdriverUpdate); gulp.task('webdriver:standalone', ['webdriver:update'], webdriverStandalone); gulp.task('tests:protractor', ['webdriver:update', 'webpack', 'sass', 'express'], function(done) { gulp.src('tests/integration/**/*_spec.js') .pipe(protractor({ configFile: 'tests/integration/protractor.conf.js', args: ['--baseUrl', 'http://' + server.address().address + ':' + server.address().port] })) .on('error', function(e) { throw e; }) .on('end', function() { server.close(); done(); }); }); gulp.task('default', ['webpack', 'fonts', 'styleguide', 'sass', 'express']); gulp.task('dev', ['default', 'watch']); gulp.task('watch', function() { gulp.watch('app/**/*.js', ['webpack']); gulp.watch('config/locales/js-*.yml', ['webpack']); gulp.watch('public/templates/**/*.html', ['webpack']); gulp.watch('../app/assets/stylesheets/**/*.sass', ['sass', 'styleguide']); gulp.watch('../app/assets/stylesheets/**/*.md', ['styleguide']); });