<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>reveal.js - Test Plugins</title> <link rel="stylesheet" href="../dist/reveal.css"> <link rel="stylesheet" href="qunit-2.5.0.css"> <script src="qunit-2.5.0.js"></script> </head> <body style="overflow: auto;"> <div id="qunit"></div> <div id="qunit-fixture"></div> <div class="reveal" style="display: none;"> <div class="slides"> <section>Slide content</section> </div> </div> <script src="../dist/reveal.min.js"></script> <script> QUnit.module( 'Plugins' ); var initCounter = { PluginB: 0, PluginC: 0, PluginD: 0 }; // Plugin with no init method var PluginA = {}; // Plugin with init method var PluginB = { init: function() { initCounter['PluginB'] += 1; } }; // Async plugin with init method var PluginC = { init: function() { return new Promise(function( resolve ) { setTimeout( () => { initCounter['PluginC'] += 1; resolve(); }, 1000 ); }); } }; // Plugin initialized after reveal.js is ready var PluginD = { init: function() { initCounter['PluginD'] += 1; } }; var PluginE = {}; var reveal = new Reveal(); reveal.registerPlugin( 'PluginA', PluginA ); reveal.registerPlugin( 'PluginB', PluginB ); reveal.registerPlugin( 'PluginC', PluginC ); reveal.initialize(); QUnit.test( 'Can initialize synchronously', function( assert ) { assert.strictEqual( initCounter['PluginB'], 1 ); reveal.registerPlugin( 'PluginB', PluginB ); assert.strictEqual( initCounter['PluginB'], 1, 'prevents duplicate registration' ); }); QUnit.test( 'Can initialize asynchronously', function( assert ) { assert.expect( 3 ); var done = assert.async( 2 ); assert.strictEqual( initCounter['PluginC'], 0, 'async plugin not immediately initialized' ); reveal.addEventListener( 'ready', function() { assert.strictEqual( initCounter['PluginC'], 1, 'finsihed initializing when reveal.js dispatches "ready"' ); done(); reveal.registerPlugin( 'PluginD', PluginD ); assert.strictEqual( initCounter['PluginD'], 1, 'plugin registered after reveal.js is ready still initiailizes' ); done(); }); } ); QUnit.test( 'Can check if plugin is registered', function( assert ) { assert.strictEqual( reveal.hasPlugin( 'PluginA' ), true ); assert.strictEqual( reveal.hasPlugin( 'PluginE' ), false ); reveal.registerPlugin( 'PluginE', PluginE ); assert.strictEqual( reveal.hasPlugin( 'PluginE' ), true ); } ); QUnit.test( 'Can retrieve plugin instance', function( assert ) { assert.strictEqual( reveal.getPlugin( 'PluginB' ), PluginB ); } ); </script> </body> </html>