From ba054dd5fd7c609a7f63620dd54d2ead301eed7c Mon Sep 17 00:00:00 2001 From: SergioCrisostomo Date: Wed, 11 Feb 2015 11:54:15 +0100 Subject: [PATCH] refactor DOMReady specs --- Specs/Utilities/DOMReady.js | 114 +++++++++++++++++++++------ Tests/DOMReady/DOMReady.delayed.html | 27 +++++++ Tests/DOMReady/DOMReady.head.html | 21 +++++ Tests/DOMReady/DOMReady.onAdd.html | 19 +++++ Tests/assets.js | 45 +++++++++++ 5 files changed, 202 insertions(+), 24 deletions(-) create mode 100644 Tests/DOMReady/DOMReady.delayed.html create mode 100644 Tests/DOMReady/DOMReady.head.html create mode 100644 Tests/DOMReady/DOMReady.onAdd.html create mode 100644 Tests/assets.js diff --git a/Specs/Utilities/DOMReady.js b/Specs/Utilities/DOMReady.js index 5a8d15fc5..193509e44 100644 --- a/Specs/Utilities/DOMReady.js +++ b/Specs/Utilities/DOMReady.js @@ -6,30 +6,96 @@ provides: ~ ... */ -/* todo -document.addListener = function(type, fn){ - if (this.addEventListener) this.addEventListener(type, fn, false); - else this.attachEvent('on' + type, fn); - return this; -}; - -document.removeListener = function(type, fn){ - if (this.removeEventListener) this.removeEventListener(type, fn, false); - else this.detachEvent('on' + type, fn); - return this; -}; - - -window.fireEvent = -document.fireEvent = function(type){ - if (type == 'domready') - for (var i = 0; i < domreadyCallbacks.length; ++i){ +describe("DOMReady", function(){ + + var win, frame, cb, ready; + function checkStatus(){ + ready = win && win.callbackFired; + if (ready) cb(); + return ready; } - domreadyCallbacks[i](); -}; -window.addEvent = function(){}; + function newFrame(url){ + var iframe = new IFrame({ + src: 'specsserver/' + url + }); + document.getElement('body').adopt(iframe); + return iframe; + } + + beforeEach(function(){ + cb = jasmine.createSpy('DOMReady!'); + }); + + afterEach(function(){ + frame.destroy(); + win = cb = frame = ready = null; + }); + + it('should fire DOMReady, after flushing, when the DOM is ready', function(){ + frame = newFrame('foo?assets=flush'); + frame.addEvent('load', function(){ + win = frame.contentWindow; + expect(win.moments[0]).toEqual('loading'); + expect(win.moments[1]).toEqual('loading'); + expect(win.moments[2] == 'interactive' || win.moments[2] == 'complete').toBeTruthy(); + }); + + waitsFor(function(){ + return checkStatus(); + }, "the iframe to load", 8000); + runs(function(){ + expect(cb).toHaveBeenCalled(); + }); + }); + + it('should fire DOMReady when the DOM is ready', function(){ + frame = newFrame('DOMReady/DOMReady.head.html'); + frame.addEvent('load', function(){ + win = frame.contentWindow; + }); + waitsFor(function(){ + return checkStatus(); + }, "the iframe to load", 1500); + runs(function(){ + expect(cb).toHaveBeenCalled(); + }); + }); + + it('should fire DOMReady when a new `addEvent("domready"` is added', function(){ + frame = newFrame('DOMReady/DOMReady.onAdd.html'); + frame.addEvent('load', function(){ + win = frame.contentWindow; + win.addEvent('domready', win.callback); + }); + waitsFor(function(){ + return checkStatus(); + }, "the iframe to load", 1500); + runs(function(){ + expect(cb).toHaveBeenCalled(); + }); + }); + + it('should fire when MooTools was loaded into a already-ready page', function(){ + frame = newFrame('DOMReady/DOMReady.delayed.html'); + var ready; + frame.addEvent('load', function(){ + win = frame.contentWindow; + expect(win.MooTools).toBeFalsy(); // because MooTools should not be loaded yet + var i = setInterval(function(){ + if (win.addEvent && win.callback){ + win.addEvent('domready', win.callback); + if (ready) clearInterval(i); + } + }, 50); + }); + waitsFor(function(){ + return checkStatus(); + }, "the iframe to load and MooTools to be deployed", 6000); + runs(function(){ + expect(cb).toHaveBeenCalled(); + }); + }); + +}); -var Element = this.Element || {}; -Element.Events = {}; -*/ diff --git a/Tests/DOMReady/DOMReady.delayed.html b/Tests/DOMReady/DOMReady.delayed.html new file mode 100644 index 000000000..09e644609 --- /dev/null +++ b/Tests/DOMReady/DOMReady.delayed.html @@ -0,0 +1,27 @@ + + + + + Add MooTools when page is already ready + + + + + + diff --git a/Tests/DOMReady/DOMReady.head.html b/Tests/DOMReady/DOMReady.head.html new file mode 100644 index 000000000..f3b6b2f3b --- /dev/null +++ b/Tests/DOMReady/DOMReady.head.html @@ -0,0 +1,21 @@ + + + + + Normal DOMReady scenario + + + + + + + + + diff --git a/Tests/DOMReady/DOMReady.onAdd.html b/Tests/DOMReady/DOMReady.onAdd.html new file mode 100644 index 000000000..d751f6dc3 --- /dev/null +++ b/Tests/DOMReady/DOMReady.onAdd.html @@ -0,0 +1,19 @@ + + + + + DOMReady added when page is already loaded + + + + + + + + diff --git a/Tests/assets.js b/Tests/assets.js new file mode 100644 index 000000000..3640174c9 --- /dev/null +++ b/Tests/assets.js @@ -0,0 +1,45 @@ +"use strict"; + +// custom behaviours to test +var assets = { + + flush: function(req, res, src){ + + var headString = '' + + '' + + '' + + '' + + 'Flushed page scenario' + + '' + + '' + + ''; + var bodyString = '' + + '' + + '
body added...
' + + '' + + ''; + var endString = ''; + + res.writeHead(200, {'Content-Type': 'text/html'}); + res.write(headString); + setTimeout(function() { + res.write(bodyString); + setTimeout(function() { + res.end(endString); + }, 2000); + }, 2000); + } +} + +module.exports = assets;