gulpfile.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. const pkg = require('./package.json')
  2. const path = require('path')
  3. const glob = require('glob')
  4. const yargs = require('yargs')
  5. const colors = require('colors')
  6. const webpack = require('webpack-stream')
  7. const { runQunitPuppeteer, printResultSummary, printFailedTests } = require('node-qunit-puppeteer')
  8. const gulp = require('gulp')
  9. const tap = require('gulp-tap')
  10. const zip = require('gulp-zip')
  11. const sass = require('gulp-sass')
  12. const header = require('gulp-header')
  13. const eslint = require('gulp-eslint')
  14. const uglify = require('gulp-uglify')
  15. const rename = require('gulp-rename')
  16. const minify = require('gulp-clean-css')
  17. const connect = require('gulp-connect')
  18. const autoprefixer = require('gulp-autoprefixer')
  19. const root = yargs.argv.root || '.'
  20. const port = yargs.argv.port || 8000
  21. const license = `/*!
  22. * reveal.js <%= pkg.version %> (<%= new Date().toDateString() %>)
  23. * <%= pkg.homepage %>
  24. * MIT licensed
  25. *
  26. * Copyright (C) 2020 Hakim El Hattab, https://hakim.se
  27. */\n`
  28. const swallowError = function(error) {
  29. console.log(error.toString())
  30. this.emit('end')
  31. }
  32. gulp.task('js', () => gulp.src(['./js/index.js'])
  33. .pipe(webpack(require('./webpack.config.js')))
  34. .on('error', swallowError)
  35. .pipe(header(license, {pkg: pkg}))
  36. .pipe(rename('reveal.min.js'))
  37. .pipe(gulp.dest('./dist')))
  38. gulp.task('css-themes', () => gulp.src(['./css/theme/source/*.{sass,scss}'])
  39. .pipe(sass())
  40. .pipe(gulp.dest('./dist/theme')))
  41. gulp.task('css-core', gulp.series(
  42. () => gulp.src(['css/reveal.scss'])
  43. .pipe(sass())
  44. .pipe(autoprefixer())
  45. .pipe(gulp.dest('./dist')),
  46. () => gulp.src(['dist/reveal.css'])
  47. .pipe(minify({compatibility: 'ie9'}))
  48. .pipe(header(license, {pkg: pkg}))
  49. .pipe(gulp.dest('./dist'))
  50. ))
  51. gulp.task('css', gulp.parallel('css-themes', 'css-core'))
  52. gulp.task('test-qunit', function() {
  53. let testFiles = glob.sync('test/*.html' )
  54. let totalTests = 0;
  55. let failingTests = 0;
  56. let tests = Promise.all( testFiles.map( filename => {
  57. return new Promise( ( resolve, reject ) => {
  58. runQunitPuppeteer({
  59. targetUrl: `file://${path.join(__dirname, filename)}`,
  60. timeout: 20000,
  61. redirectConsole: false,
  62. puppeteerArgs: ['--allow-file-access-from-files']
  63. })
  64. .then(result => {
  65. if( result.stats.failed > 0 ) {
  66. console.log(`${'!'} ${filename} [${result.stats.passed}/${result.stats.total}] in ${result.stats.runtime}ms`.red);
  67. // printResultSummary(result, console);
  68. printFailedTests(result, console);
  69. }
  70. else {
  71. console.log(`${'✔'} ${filename} [${result.stats.passed}/${result.stats.total}] in ${result.stats.runtime}ms`.green);
  72. }
  73. totalTests += result.stats.total;
  74. failingTests += result.stats.failed;
  75. resolve();
  76. })
  77. .catch(error => {
  78. console.error(error);
  79. reject();
  80. });
  81. } )
  82. } ) );
  83. return new Promise( ( resolve, reject ) => {
  84. tests.then( () => {
  85. if( failingTests > 0 ) {
  86. reject( new Error(`${failingTests}/${totalTests} tests failed`.red) );
  87. }
  88. else {
  89. console.log(`${'✔'} Passed ${totalTests} tests`.green.bold);
  90. resolve();
  91. }
  92. } )
  93. .catch( () => {
  94. reject();
  95. } );
  96. } );
  97. } )
  98. gulp.task('test', gulp.series(
  99. () => gulp.src(['./js/**', 'gulpfile.js']).pipe(eslint()).pipe(eslint.format()),
  100. 'test-qunit'
  101. ))
  102. gulp.task('default', gulp.series(gulp.parallel('js', 'css'), 'test'))
  103. gulp.task('package', gulp.series('default', () =>
  104. gulp.src([
  105. './index.html',
  106. './dist/**',
  107. './lib/**',
  108. './images/**',
  109. './plugin/**',
  110. './**.md'
  111. ]).pipe(zip('reveal-js-presentation.zip')).pipe(gulp.dest('./'))
  112. ))
  113. gulp.task('serve', () => {
  114. connect.server({
  115. root: root,
  116. port: port,
  117. host: '0.0.0.0',
  118. livereload: true
  119. })
  120. gulp.watch(['js/**'], gulp.series('js', 'test'))
  121. gulp.watch(['test/*.html'], gulp.series('test'))
  122. gulp.watch([
  123. 'css/theme/source/*.{sass,scss}',
  124. 'css/theme/template/*.{sass,scss}',
  125. ], gulp.series('css-themes'))
  126. gulp.watch([
  127. 'css/reveal.scss',
  128. 'css/print/*.{sass,scss,css}'
  129. ], gulp.series('css-core'))
  130. })