made test helpers more cross browser compatible

This commit is contained in:
Peter 'Pita' Martischka 2012-10-03 17:37:48 +01:00
parent ba4ebbba3b
commit 7aee98bce8
4 changed files with 79 additions and 56 deletions

View file

@ -1,80 +1,99 @@
var testHelper = {}; var testHelper = {};
(function(){ (function(){
var $iframeContainer = $("#iframe-container"), $iframe; var $iframeContainer, $iframe;
testHelper.randomString = function randomString(len) testHelper.init = function(){
{ $iframeContainer = $("#iframe-container");
var chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; }
var randomstring = '';
for (var i = 0; i < len; i++)
{
var rnum = Math.floor(Math.random() * chars.length);
randomstring += chars.substring(rnum, rnum + 1);
}
return randomstring;
}
testHelper.newPad = function(cb){ testHelper.randomString = function randomString(len)
var padName = "FRONTEND_TEST_" + testHelper.randomString(20); {
$iframe = $("<iframe src='/p/" + padName + "'></iframe>") var chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
var randomstring = '';
for (var i = 0; i < len; i++)
{
var rnum = Math.floor(Math.random() * chars.length);
randomstring += chars.substring(rnum, rnum + 1);
}
return randomstring;
}
$iframeContainer.empty().append($iframe); testHelper.newPad = function(cb){
var padName = "FRONTEND_TEST_" + testHelper.randomString(20);
$iframe = $("<iframe src='/p/" + padName + "'></iframe>");
$iframeContainer.empty().append($iframe);
var checkInterval; var checkInterval;
$iframe.load(function(){ $iframe.load(function(){
checkInterval = setInterval(function(){ checkInterval = setInterval(function(){
var loaded = false; var loaded = false;
try { try {
//check if loading div is hidden //check if loading div is hidden
loaded = !testHelper.$getPadChrome().find("#editorloadingbox").is(":visible"); loaded = !testHelper.$getPadChrome().find("#editorloadingbox").is(":visible");
} catch(e){} } catch(e){}
if(loaded){ if(loaded){
clearTimeout(timeout); clearTimeout(timeout);
clearInterval(checkInterval); clearInterval(checkInterval);
cb(null, {name: padName}); cb(null, {name: padName});
} }
}, 100); }, 100);
}); });
var timeout = setTimeout(function(){ var timeout = setTimeout(function(){
if(checkInterval) clearInterval(checkInterval); if(checkInterval) clearInterval(checkInterval);
cb(new Error("Pad didn't load in 10 seconds")); cb(new Error("Pad didn't load in 10 seconds"));
}, 10000); }, 10000);
return padName; return padName;
} }
testHelper.$getPadChrome = function(){ testHelper.$getPadChrome = function(){
return $iframe.contents() var win = $iframe[0].contentWindow;
} var $content = $iframe.contents();
$content.window = win;
testHelper.$getPadOuter = function(){ return $content;
return testHelper.$getPadChrome().find('iframe.[name="ace_outer"]').contents(); }
}
testHelper.$getPadInner = function(){ testHelper.$getPadOuter = function(){
return testHelper.$getPadOuter().find('iframe.[name="ace_inner"]').contents(); var $iframe = testHelper.$getPadChrome().find('iframe.[name="ace_outer"]');
} var win = $iframe[0].contentWindow;
var $content = $iframe.contents();
$content.window = win;
return $content;
}
testHelper.$getPadInner = function(){
var $iframe = testHelper.$getPadOuter().find('iframe.[name="ace_inner"]');
var win = $iframe[0].contentWindow;
var $content = $iframe.contents();
$content.window = win;
return $content;
}
// copied from http://stackoverflow.com/questions/985272/jquery-selecting-text-in-an-element-akin-to-highlighting-with-your-mouse // copied from http://stackoverflow.com/questions/985272/jquery-selecting-text-in-an-element-akin-to-highlighting-with-your-mouse
testHelper.selectText = function(element){ // selects the whole dom element you give it
var doc = document, range, selection; testHelper.selectText = function(element, $iframe){
var doc = $iframe[0], win = $iframe.window, range, selection;
if (doc.body.createTextRange) { //ms if (doc.body.createTextRange) { //ms
range = doc.body.createTextRange(); range = doc.body.createTextRange();
range.moveToElementText(element); range.moveToElementText(element);
range.select(); range.select();
} else if (window.getSelection) { //all others } else if (win.getSelection) { //all others
selection = window.getSelection(); selection = win.getSelection();
range = doc.createRange(); range = doc.createRange();
range.selectNodeContents(element); range.selectNodeContents(element);
selection.removeAllRanges(); selection.removeAllRanges();
selection.addRange(range); selection.addRange(range);
} }
} }
})() })()

View file

@ -4856,8 +4856,8 @@ process.on = function(e, fn){
var options = mocha.options; var options = mocha.options;
mocha.globals('location'); mocha.globals('location');
var query = Mocha.utils.parseQuery(window.location.search || ''); //var query = Mocha.utils.parseQuery(window.location.search || '');
if (query.grep) mocha.grep(query.grep); //if (query.grep) mocha.grep(query.grep);
return Mocha.prototype.run.call(mocha, function(){ return Mocha.prototype.run.call(mocha, function(){
Mocha.utils.highlightTags('code'); Mocha.utils.highlightTags('code');

View file

@ -1,7 +1,11 @@
(function(){ $(function(){
//allow iframe access //allow cross iframe access
document.domain = document.domain; document.domain = document.domain;
//start test framework //initalize the test helper
mocha.run(); testHelper.init();
})()
//configure and start the test framework
mocha.ignoreLeaks();
mocha.run();
});

View file

@ -5,14 +5,14 @@ describe("bold button", function(){
}); });
it("makes text bold", function() { it("makes text bold", function() {
//get the inner iframe //get the inner iframe
var $inner = testHelper.$getPadInner(); var $inner = testHelper.$getPadInner();
//get the first text element out of the inner iframe //get the first text element out of the inner iframe
var firstTextElement = $inner.find("div").first(); var firstTextElement = $inner.find("div").first();
//select this text element //select this text element
testHelper.selectText(firstTextElement[0]); testHelper.selectText(firstTextElement[0], $inner);
//get the bold button and click it //get the bold button and click it
var $boldButton = testHelper.$getPadChrome().find(".buttonicon-bold"); var $boldButton = testHelper.$getPadChrome().find(".buttonicon-bold");