gulpfile.js 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  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 qunit = require('node-qunit-puppeteer')
  7. const {rollup} = require('rollup')
  8. const {terser} = require('rollup-plugin-terser')
  9. const babel = require('rollup-plugin-babel')
  10. const resolve = require('@rollup/plugin-node-resolve')
  11. const gulp = require('gulp')
  12. const tap = require('gulp-tap')
  13. const zip = require('gulp-zip')
  14. const sass = require('gulp-sass')
  15. const header = require('gulp-header')
  16. const eslint = require('gulp-eslint')
  17. const minify = require('gulp-clean-css')
  18. const connect = require('gulp-connect')
  19. const autoprefixer = require('gulp-autoprefixer')
  20. const root = yargs.argv.root || '.'
  21. const port = yargs.argv.port || 8000
  22. const banner = `/*!
  23. * reveal.js ${pkg.version} (${new Date().toDateString()})
  24. * ${pkg.homepage}
  25. * MIT licensed
  26. *
  27. * Copyright (C) 2020 Hakim El Hattab, https://hakim.se
  28. */\n`
  29. // Prevents warnings from opening too many test pages
  30. process.setMaxListeners(20);
  31. const rollupConfig = {
  32. plugins: [
  33. babel({
  34. exclude: 'node_modules/**',
  35. compact: false,
  36. presets: [
  37. [
  38. '@babel/preset-env',
  39. {
  40. corejs: 3,
  41. useBuiltIns: 'entry',
  42. modules: false
  43. }
  44. ]
  45. ]
  46. }),
  47. resolve(),
  48. terser()
  49. ]
  50. };
  51. gulp.task('js', () => {
  52. return rollup({
  53. input: 'js/index.js',
  54. ...rollupConfig
  55. }).then( bundle => {
  56. bundle.write({
  57. file: './dist/reveal.js',
  58. format: 'es',
  59. banner: banner,
  60. sourcemap: true
  61. });
  62. bundle.write({
  63. name: 'Reveal',
  64. file: './dist/reveal.es5.js',
  65. format: 'umd',
  66. banner: banner,
  67. sourcemap: true
  68. });
  69. });
  70. })
  71. gulp.task('plugins', () => {
  72. return Promise.all([
  73. { name: 'RevealHighlight', input: './plugin/highlight/highlight.js', output: './dist/plugin/highlight.js' },
  74. { name: 'RevealMarkdown', input: './plugin/markdown/markdown.js', output: './dist/plugin/markdown.js' },
  75. { name: 'RevealSearch', input: './plugin/search/search.js', output: './dist/plugin/search.js' },
  76. { name: 'RevealNotes', input: './plugin/notes/notes.js', output: './dist/plugin/notes.js' },
  77. { name: 'RevealZoom', input: './plugin/zoom/zoom.js', output: './dist/plugin/zoom.js' },
  78. { name: 'RevealMath', input: './plugin/math/math.js', output: './dist/plugin/math.js' }
  79. ].map( plugin => {
  80. return rollup({
  81. input: plugin.input,
  82. ...rollupConfig
  83. }).then( bundle => {
  84. return bundle.write({
  85. file: plugin.output,
  86. name: plugin.name,
  87. format: 'umd'
  88. })
  89. });
  90. } ));
  91. })
  92. gulp.task('css-themes', () => gulp.src(['./css/theme/source/*.{sass,scss}'])
  93. .pipe(sass())
  94. .pipe(gulp.dest('./dist/theme')))
  95. gulp.task('css-core', () => gulp.src(['css/reveal.scss'])
  96. .pipe(sass())
  97. .pipe(autoprefixer())
  98. .pipe(minify({compatibility: 'ie9'}))
  99. .pipe(header(banner))
  100. .pipe(gulp.dest('./dist')))
  101. gulp.task('css', gulp.parallel('css-themes', 'css-core'))
  102. gulp.task('qunit', () => {
  103. let serverConfig = {
  104. root,
  105. port: 8009,
  106. host: '0.0.0.0',
  107. name: 'test-server'
  108. }
  109. let server = connect.server( serverConfig )
  110. let testFiles = glob.sync('test/*.html' )
  111. let totalTests = 0;
  112. let failingTests = 0;
  113. let tests = Promise.all( testFiles.map( filename => {
  114. return new Promise( ( resolve, reject ) => {
  115. qunit.runQunitPuppeteer({
  116. targetUrl: `http://${serverConfig.host}:${serverConfig.port}/${filename}`,
  117. timeout: 20000,
  118. redirectConsole: false,
  119. puppeteerArgs: ['--allow-file-access-from-files']
  120. })
  121. .then(result => {
  122. if( result.stats.failed > 0 ) {
  123. console.log(`${'!'} ${filename} [${result.stats.passed}/${result.stats.total}] in ${result.stats.runtime}ms`.red);
  124. // qunit.printResultSummary(result, console);
  125. qunit.printFailedTests(result, console);
  126. }
  127. else {
  128. console.log(`${'✔'} ${filename} [${result.stats.passed}/${result.stats.total}] in ${result.stats.runtime}ms`.green);
  129. }
  130. totalTests += result.stats.total;
  131. failingTests += result.stats.failed;
  132. resolve();
  133. })
  134. .catch(error => {
  135. console.error(error);
  136. reject();
  137. });
  138. } )
  139. } ) );
  140. return new Promise( ( resolve, reject ) => {
  141. tests.then( () => {
  142. if( failingTests > 0 ) {
  143. reject( new Error(`${failingTests}/${totalTests} tests failed`.red) );
  144. }
  145. else {
  146. console.log(`${'✔'} Passed ${totalTests} tests`.green.bold);
  147. resolve();
  148. }
  149. } )
  150. .catch( () => {
  151. reject();
  152. } )
  153. .finally( () => {
  154. server.close();
  155. } );
  156. } );
  157. } )
  158. gulp.task('eslint', () => gulp.src(['./js/**', 'gulpfile.js'])
  159. .pipe(eslint())
  160. .pipe(eslint.format()))
  161. gulp.task('test', gulp.series( 'eslint', 'qunit' ))
  162. gulp.task('default', gulp.series(gulp.parallel('js', 'css', 'plugins'), 'test'))
  163. gulp.task('build', gulp.parallel('js', 'css', 'plugins'))
  164. gulp.task('package', gulp.series('default', () =>
  165. gulp.src([
  166. './index.html',
  167. './dist/**',
  168. './lib/**',
  169. './images/**',
  170. './plugin/**',
  171. './**.md'
  172. ]).pipe(zip('reveal-js-presentation.zip')).pipe(gulp.dest('./'))
  173. ))
  174. gulp.task('serve', () => {
  175. connect.server({
  176. root: root,
  177. port: port,
  178. host: '0.0.0.0',
  179. livereload: true
  180. })
  181. gulp.watch(['js/**'], gulp.series('js', 'test'))
  182. gulp.watch(['plugin/**/*.js'], gulp.series('plugins'))
  183. gulp.watch(['test/*.html'], gulp.series('test'))
  184. gulp.watch([
  185. 'css/theme/source/*.{sass,scss}',
  186. 'css/theme/template/*.{sass,scss}',
  187. ], gulp.series('css-themes'))
  188. gulp.watch([
  189. 'css/reveal.scss',
  190. 'css/print/*.{sass,scss,css}'
  191. ], gulp.series('css-core'))
  192. })