mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-19 14:13:34 +01:00
made test helpers more cross browser compatible
This commit is contained in:
parent
ba4ebbba3b
commit
7aee98bce8
4 changed files with 79 additions and 56 deletions
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})()
|
})()
|
||||||
|
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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();
|
||||||
|
});
|
|
@ -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");
|
||||||
|
|
Loading…
Reference in a new issue