gulpfile.js 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  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('plugins', () => gulp.src(['./js/index.js'])
  39. .pipe(webpack({
  40. ...require('./webpack.config.js'),
  41. entry: {
  42. 'highlight': './plugin/highlight/highlight.es5',
  43. 'markdown': './plugin/markdown/markdown.es5',
  44. 'search': './plugin/search/search.es5',
  45. 'notes': './plugin/notes/notes.es5',
  46. 'zoom': './plugin/zoom/zoom.es5',
  47. 'math': './plugin/math/math.es5'
  48. },
  49. output: {
  50. filename: '[name].js'
  51. }
  52. }))
  53. .on('error', swallowError)
  54. .pipe(gulp.dest('./dist/plugin')))
  55. gulp.task('css-themes', () => gulp.src(['./css/theme/source/*.{sass,scss}'])
  56. .pipe(sass())
  57. .pipe(gulp.dest('./dist/theme')))
  58. gulp.task('css-core', gulp.series(
  59. () => gulp.src(['css/reveal.scss'])
  60. .pipe(sass())
  61. .pipe(autoprefixer())
  62. .pipe(gulp.dest('./dist')),
  63. () => gulp.src(['dist/reveal.css'])
  64. .pipe(minify({compatibility: 'ie9'}))
  65. .pipe(header(license, {pkg: pkg}))
  66. .pipe(gulp.dest('./dist'))
  67. ))
  68. gulp.task('css', gulp.parallel('css-themes', 'css-core'))
  69. gulp.task('test-qunit', function() {
  70. let testFiles = glob.sync('test/*.html' )
  71. let totalTests = 0;
  72. let failingTests = 0;
  73. let tests = Promise.all( testFiles.map( filename => {
  74. return new Promise( ( resolve, reject ) => {
  75. runQunitPuppeteer({
  76. targetUrl: `file://${path.join(__dirname, filename)}`,
  77. timeout: 20000,
  78. redirectConsole: false,
  79. puppeteerArgs: ['--allow-file-access-from-files']
  80. })
  81. .then(result => {
  82. if( result.stats.failed > 0 ) {
  83. console.log(`${'!'} ${filename} [${result.stats.passed}/${result.stats.total}] in ${result.stats.runtime}ms`.red);
  84. // printResultSummary(result, console);
  85. printFailedTests(result, console);
  86. }
  87. else {
  88. console.log(`${'✔'} ${filename} [${result.stats.passed}/${result.stats.total}] in ${result.stats.runtime}ms`.green);
  89. }
  90. totalTests += result.stats.total;
  91. failingTests += result.stats.failed;
  92. resolve();
  93. })
  94. .catch(error => {
  95. console.error(error);
  96. reject();
  97. });
  98. } )
  99. } ) );
  100. return new Promise( ( resolve, reject ) => {
  101. tests.then( () => {
  102. if( failingTests > 0 ) {
  103. reject( new Error(`${failingTests}/${totalTests} tests failed`.red) );
  104. }
  105. else {
  106. console.log(`${'✔'} Passed ${totalTests} tests`.green.bold);
  107. resolve();
  108. }
  109. } )
  110. .catch( () => {
  111. reject();
  112. } );
  113. } );
  114. } )
  115. gulp.task('test', gulp.series(
  116. () => gulp.src(['./js/**', 'gulpfile.js']).pipe(eslint()).pipe(eslint.format()),
  117. 'test-qunit'
  118. ))
  119. gulp.task('default', gulp.series(gulp.parallel('js', 'css'), 'test'))
  120. gulp.task('build', gulp.parallel('js', 'css'))
  121. gulp.task('package', gulp.series('default', () =>
  122. gulp.src([
  123. './index.html',
  124. './dist/**',
  125. './lib/**',
  126. './images/**',
  127. './plugin/**',
  128. './**.md'
  129. ]).pipe(zip('reveal-js-presentation.zip')).pipe(gulp.dest('./'))
  130. ))
  131. gulp.task('serve', () => {
  132. connect.server({
  133. root: root,
  134. port: port,
  135. host: '0.0.0.0',
  136. livereload: true
  137. })
  138. gulp.watch(['js/**'], gulp.series('js', 'test'))
  139. gulp.watch(['test/*.html'], gulp.series('test'))
  140. gulp.watch([
  141. 'css/theme/source/*.{sass,scss}',
  142. 'css/theme/template/*.{sass,scss}',
  143. ], gulp.series('css-themes'))
  144. gulp.watch([
  145. 'css/reveal.scss',
  146. 'css/print/*.{sass,scss,css}'
  147. ], gulp.series('css-core'))
  148. })