mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-04-20 15:36:16 -04:00
major restructering of the front end test framework
This commit is contained in:
parent
6587852138
commit
ca6ebd6151
11 changed files with 267 additions and 120 deletions
|
@ -6,6 +6,7 @@ exports.expressCreateServer = function (hook_name, args, cb) {
|
||||||
if (subPath == ""){
|
if (subPath == ""){
|
||||||
subPath = "index.html"
|
subPath = "index.html"
|
||||||
}
|
}
|
||||||
|
subPath = subPath.split("?")[0];
|
||||||
|
|
||||||
var filePath = path.normalize(__dirname + "/../../../../tests/frontend/")
|
var filePath = path.normalize(__dirname + "/../../../../tests/frontend/")
|
||||||
filePath += subPath.replace("..", "");
|
filePath += subPath.replace("..", "");
|
||||||
|
|
|
@ -1,10 +1,20 @@
|
||||||
var helper = {};
|
var helper = {};
|
||||||
|
|
||||||
(function(){
|
(function(){
|
||||||
var $iframeContainer, $iframe, $padChrome, $padOuter, $padInner;
|
var $iframeContainer, $iframe, jsLibraries = {};
|
||||||
|
|
||||||
helper.init = function(){
|
helper.init = function(cb){
|
||||||
$iframeContainer = $("#iframe-container");
|
$iframeContainer = $("#iframe-container");
|
||||||
|
|
||||||
|
$.get('/static/js/jquery.js').done(function(code){
|
||||||
|
jsLibraries["jquery"] = code;
|
||||||
|
|
||||||
|
$.get('/tests/frontend/sendkeys.js').done(function(code){
|
||||||
|
jsLibraries["sendkeys"] = code;
|
||||||
|
|
||||||
|
cb();
|
||||||
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
helper.randomString = function randomString(len)
|
helper.randomString = function randomString(len)
|
||||||
|
@ -19,125 +29,106 @@ var helper = {};
|
||||||
return randomstring;
|
return randomstring;
|
||||||
}
|
}
|
||||||
|
|
||||||
var getFrameJQuery = function($, selector, callback){
|
var getFrameJQuery = function($iframe){
|
||||||
//find the iframe and get its window and document
|
/*
|
||||||
var $iframe = $(selector);
|
I tried over 9000 ways to inject javascript into iframes.
|
||||||
var $content = $iframe.contents();
|
This is the only way I found that worked in IE 7+8+9, FF and Chrome
|
||||||
|
*/
|
||||||
|
|
||||||
var win = $iframe[0].contentWindow;
|
var win = $iframe[0].contentWindow;
|
||||||
var doc = win.document;
|
var doc = win.document;
|
||||||
|
|
||||||
//inject jquery if not already existing
|
//IE 8+9 Hack to make eval appear
|
||||||
if(win.$ === undefined){
|
//http://stackoverflow.com/questions/2720444/why-does-this-window-object-not-have-the-eval-function
|
||||||
helper.injectJS(doc, "/static/js/jquery.js");
|
win.execScript && win.execScript("null");
|
||||||
}
|
|
||||||
|
|
||||||
helper.waitFor(function(){
|
win.eval(jsLibraries["jquery"]);
|
||||||
return win.$
|
win.eval(jsLibraries["sendkeys"]);
|
||||||
}).then(function(){
|
|
||||||
if(!(win.$ && win.$.fn && win.$.fn.sendkeys)){
|
|
||||||
helper.injectJS(doc, "/tests/frontend/sendkeys.js");
|
|
||||||
}
|
|
||||||
|
|
||||||
helper.waitFor(function(){
|
win.$.window = win;
|
||||||
return (win.$ && win.$.fn && win.$.fn.sendkeys);
|
win.$.document = doc;
|
||||||
}).then(function(){
|
|
||||||
win.$.window = win;
|
|
||||||
win.$.document = doc;
|
|
||||||
|
|
||||||
callback(win.$);
|
return win.$;
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
helper.newPad = function(cb){
|
helper.newPad = function(cb){
|
||||||
var padName = "FRONTEND_TEST_" + helper.randomString(20);
|
var padName = "FRONTEND_TEST_" + helper.randomString(20);
|
||||||
$iframe = $("<iframe src='/p/" + padName + "'></iframe>");
|
$iframe = $("<iframe src='/p/" + padName + "'></iframe>");
|
||||||
|
|
||||||
$iframeContainer.empty().append($iframe);
|
//clean up inner iframe references
|
||||||
|
helper.padChrome$ = helper.padOuter$ = helper.padInner$ = null;
|
||||||
|
|
||||||
var checkInterval;
|
//clean up iframes properly to prevent IE from memoryleaking
|
||||||
$iframe.load(function(){
|
$iframeContainer.find("iframe").purgeFrame().done(function(){
|
||||||
helper.waitFor(function(){
|
$iframeContainer.append($iframe);
|
||||||
return !$iframe.contents().find("#editorloadingbox").is(":visible");
|
$iframe.one('load', function(){
|
||||||
}).then(function(){
|
helper.waitFor(function(){
|
||||||
//INCEPTION!!!
|
return !$iframe.contents().find("#editorloadingbox").is(":visible");
|
||||||
getFrameJQuery($, '#iframe-container iframe', function(_$padChrome){
|
}, 4000).done(function(){
|
||||||
$padChrome = _$padChrome;
|
helper.padChrome$ = getFrameJQuery( $('#iframe-container iframe'));
|
||||||
|
helper.padOuter$ = getFrameJQuery(helper.padChrome$('iframe.[name="ace_outer"]'));
|
||||||
|
helper.padInner$ = getFrameJQuery( helper.padOuter$('iframe.[name="ace_inner"]'));
|
||||||
|
|
||||||
getFrameJQuery($padChrome, 'iframe.[name="ace_outer"]', function(_$padOuter){
|
cb();
|
||||||
$padOuter = _$padOuter;
|
}).fail(function(){
|
||||||
|
throw new Error("Pad never loaded");
|
||||||
getFrameJQuery($padOuter, 'iframe.[name="ace_inner"]', function(_$padInner){
|
});
|
||||||
$padInner = _$padInner;
|
|
||||||
|
|
||||||
cb();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
})
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
return padName;
|
return padName;
|
||||||
}
|
}
|
||||||
|
|
||||||
//helper to inject javascript
|
|
||||||
helper.injectJS = function(doc, url){
|
|
||||||
var script = doc.createElement( 'script' );
|
|
||||||
script.type = 'text/javascript';
|
|
||||||
script.src = url;
|
|
||||||
doc.body.appendChild(script);
|
|
||||||
}
|
|
||||||
|
|
||||||
helper.waitFor = function(conditionFunc, _timeoutTime, _intervalTime){
|
helper.waitFor = function(conditionFunc, _timeoutTime, _intervalTime){
|
||||||
var timeoutTime = _timeoutTime || 1000;
|
var timeoutTime = _timeoutTime || 1000;
|
||||||
var intervalTime = _intervalTime || 10;
|
var intervalTime = _intervalTime || 10;
|
||||||
|
|
||||||
var callback = function(){}
|
var deferred = $.Deferred();
|
||||||
var returnObj = { then: function(_callback){
|
|
||||||
callback = _callback;
|
var _fail = deferred.fail;
|
||||||
}}
|
var listenForFail = false;
|
||||||
|
deferred.fail = function(){
|
||||||
|
listenForFail = true;
|
||||||
|
_fail.apply(this, arguments);
|
||||||
|
}
|
||||||
|
|
||||||
var intervalCheck = setInterval(function(){
|
var intervalCheck = setInterval(function(){
|
||||||
var passed = false;
|
var passed = false;
|
||||||
|
|
||||||
try {
|
passed = conditionFunc();
|
||||||
passed = conditionFunc();
|
|
||||||
} catch(e){}
|
|
||||||
|
|
||||||
if(passed){
|
if(passed){
|
||||||
clearInterval(intervalCheck);
|
clearInterval(intervalCheck);
|
||||||
clearTimeout(timeout);
|
clearTimeout(timeout);
|
||||||
|
|
||||||
callback(passed);
|
deferred.resolve();
|
||||||
}
|
}
|
||||||
}, intervalTime);
|
}, intervalTime);
|
||||||
|
|
||||||
var timeout = setTimeout(function(){
|
var timeout = setTimeout(function(){
|
||||||
clearInterval(intervalCheck);
|
clearInterval(intervalCheck);
|
||||||
throw Error("wait for condition never became true");
|
var error = new Error("wait for condition never became true " + conditionFunc.toString());
|
||||||
|
deferred.reject(error);
|
||||||
|
|
||||||
|
if(!listenForFail){
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
}, timeoutTime);
|
}, timeoutTime);
|
||||||
|
|
||||||
return returnObj;
|
return deferred;
|
||||||
}
|
}
|
||||||
|
|
||||||
helper.log = function(){
|
/* Ensure console.log doesn't blow up in IE, ugly but ok for a test framework imho*/
|
||||||
if(console && console.log){
|
window.console = window.console || {};
|
||||||
console.log.apply(console, arguments);
|
window.console.log = window.console.log || function(){}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
helper.jQueryOf = function(name){
|
//force usage of callbacks in it
|
||||||
switch(name){
|
var _it = it;
|
||||||
case "chrome":
|
it = function(name, func){
|
||||||
return $padChrome;
|
if(func && func.length !== 1){
|
||||||
break;
|
throw new Error("Please use always a callback with it() - " + func.toString());
|
||||||
case "outer":
|
|
||||||
return $padOuter;
|
|
||||||
break;
|
|
||||||
case "inner":
|
|
||||||
return $padInner;
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_it.apply(null, arguments);
|
||||||
}
|
}
|
||||||
})()
|
})()
|
||||||
|
|
||||||
|
|
|
@ -16,13 +16,22 @@
|
||||||
|
|
||||||
<script src="helper.js"></script>
|
<script src="helper.js"></script>
|
||||||
<script src="sendkeys.js"></script>
|
<script src="sendkeys.js"></script>
|
||||||
|
<script src="lib/jquery.iframe.js"></script>
|
||||||
|
|
||||||
|
<script src="specs/helper.js"></script>
|
||||||
|
<script src="specs/button_bold.js"></script>
|
||||||
|
<script src="specs/button_italic.js"></script>
|
||||||
|
<script src="specs/keystroke_urls_become_clickable.js"></script>
|
||||||
|
<script src="specs/keystroke_delete.js"></script>
|
||||||
|
<!--
|
||||||
<script src="specs/button_indentation.js"></script>
|
<script src="specs/button_indentation.js"></script>
|
||||||
|
|
||||||
<script src="specs/font_type.js"></script>
|
<script src="specs/font_type.js"></script>
|
||||||
<script src="specs/keystroke_urls_become_clickable.js"></script>
|
<script src="specs/keystroke_urls_become_clickable.js"></script>
|
||||||
<script src="specs/button_bold.js"></script>
|
<script src="specs/button_bold.js"></script>
|
||||||
<script src="specs/button_italic.js"></script>
|
<script src="specs/button_italic.js"></script>
|
||||||
<script src="specs/keystroke_delete.js"></script>
|
<script src="specs/keystroke_delete.js"></script>
|
||||||
<script src="specs/embed_value.js"></script>
|
<script src="specs/embed_value.js"></script>-->
|
||||||
|
|
||||||
<script src="runner.js"></script>
|
<script src="runner.js"></script>
|
||||||
</html>
|
</html>
|
||||||
|
|
39
tests/frontend/lib/jquery.iframe.js
Normal file
39
tests/frontend/lib/jquery.iframe.js
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
//copied from http://stackoverflow.com/questions/8407946/is-it-possible-to-use-iframes-in-ie-without-memory-leaks
|
||||||
|
(function($) {
|
||||||
|
$.fn.purgeFrame = function() {
|
||||||
|
var deferred;
|
||||||
|
|
||||||
|
if ($.browser.msie && parseFloat($.browser.version, 10) < 9) {
|
||||||
|
deferred = purge(this);
|
||||||
|
} else {
|
||||||
|
this.remove();
|
||||||
|
deferred = $.Deferred();
|
||||||
|
deferred.resolve();
|
||||||
|
}
|
||||||
|
|
||||||
|
return deferred;
|
||||||
|
};
|
||||||
|
|
||||||
|
function purge($frame) {
|
||||||
|
var sem = $frame.length
|
||||||
|
, deferred = $.Deferred();
|
||||||
|
|
||||||
|
$frame.load(function() {
|
||||||
|
var frame = this;
|
||||||
|
frame.contentWindow.document.innerHTML = '';
|
||||||
|
|
||||||
|
sem -= 1;
|
||||||
|
if (sem <= 0) {
|
||||||
|
$frame.remove();
|
||||||
|
deferred.resolve();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$frame.attr('src', 'about:blank');
|
||||||
|
|
||||||
|
if ($frame.length === 0) {
|
||||||
|
deferred.resolve();
|
||||||
|
}
|
||||||
|
|
||||||
|
return deferred.promise();
|
||||||
|
}
|
||||||
|
})(jQuery);
|
|
@ -1,12 +1,14 @@
|
||||||
$(function(){
|
$(function(){
|
||||||
//allow cross iframe access
|
//allow cross iframe access
|
||||||
document.domain = document.domain;
|
if ((!$.browser.msie) && (!($.browser.mozilla && $.browser.version.indexOf("1.8.") == 0))) {
|
||||||
|
document.domain = document.domain; // for comet
|
||||||
|
}
|
||||||
|
|
||||||
//initalize the test helper
|
//initalize the test helper
|
||||||
helper.init();
|
helper.init(function(){
|
||||||
|
//configure and start the test framework
|
||||||
//configure and start the test framework
|
//mocha.suite.timeout(5000);
|
||||||
mocha.timeout(5000);
|
mocha.ignoreLeaks();
|
||||||
mocha.ignoreLeaks();
|
mocha.run();
|
||||||
mocha.run();
|
});
|
||||||
});
|
});
|
|
@ -1,13 +1,13 @@
|
||||||
describe("bold button", function(){
|
describe("bold button", function(){
|
||||||
//create a new pad before each test run
|
//create a new pad before each test run
|
||||||
beforeEach(function(cb){
|
beforeEach(function(cb){
|
||||||
this.timeout(5000);
|
|
||||||
helper.newPad(cb);
|
helper.newPad(cb);
|
||||||
|
this.timeout(5000);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("makes text bold", function() {
|
it("makes text bold", function(done) {
|
||||||
var inner$ = helper.jQueryOf("inner");
|
var inner$ = helper.padInner$;
|
||||||
var chrome$ = helper.jQueryOf("chrome");
|
var chrome$ = helper.padChrome$;
|
||||||
|
|
||||||
//get the first text element out of the inner iframe
|
//get the first text element out of the inner iframe
|
||||||
var $firstTextElement = inner$("div").first();
|
var $firstTextElement = inner$("div").first();
|
||||||
|
@ -30,5 +30,7 @@ describe("bold button", function(){
|
||||||
|
|
||||||
//make sure the text hasn't changed
|
//make sure the text hasn't changed
|
||||||
expect($newFirstTextElement.text()).to.eql($firstTextElement.text());
|
expect($newFirstTextElement.text()).to.eql($firstTextElement.text());
|
||||||
|
|
||||||
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
|
@ -2,11 +2,12 @@ describe("italic button", function(){
|
||||||
//create a new pad before each test run
|
//create a new pad before each test run
|
||||||
beforeEach(function(cb){
|
beforeEach(function(cb){
|
||||||
helper.newPad(cb);
|
helper.newPad(cb);
|
||||||
|
this.timeout(5000);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("makes text italic", function() {
|
it("makes text italic", function(done) {
|
||||||
var inner$ = helper.jQueryOf("inner");
|
var inner$ = helper.padInner$;
|
||||||
var chrome$ = helper.jQueryOf("chrome");
|
var chrome$ = helper.padChrome$;
|
||||||
|
|
||||||
//get the first text element out of the inner iframe
|
//get the first text element out of the inner iframe
|
||||||
var $firstTextElement = inner$("div").first();
|
var $firstTextElement = inner$("div").first();
|
||||||
|
@ -29,5 +30,7 @@ describe("italic button", function(){
|
||||||
|
|
||||||
//make sure the text hasn't changed
|
//make sure the text hasn't changed
|
||||||
expect($newFirstTextElement.text()).to.eql($firstTextElement.text());
|
expect($newFirstTextElement.text()).to.eql($firstTextElement.text());
|
||||||
|
|
||||||
|
done();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -2,6 +2,7 @@ describe("font select", function(){
|
||||||
//create a new pad before each test run
|
//create a new pad before each test run
|
||||||
beforeEach(function(cb){
|
beforeEach(function(cb){
|
||||||
testHelper.newPad(cb);
|
testHelper.newPad(cb);
|
||||||
|
this.timeout(5000);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("makes text monospace", function() {
|
it("makes text monospace", function() {
|
||||||
|
@ -12,6 +13,16 @@ describe("font select", function(){
|
||||||
var $settingsButton = testHelper.$getPadChrome().find(".buttonicon-settings");
|
var $settingsButton = testHelper.$getPadChrome().find(".buttonicon-settings");
|
||||||
$settingsButton.click();
|
$settingsButton.click();
|
||||||
|
|
||||||
|
//get the font selector and click it
|
||||||
|
var $viewfontmenu = testHelper.$getPadChrome().find("#viewfontmenu");
|
||||||
|
$viewfontmenu.click();
|
||||||
|
|
||||||
|
//get the monospace option and click it
|
||||||
|
var $monospaceoption = testHelper.$getPadChrome().find("[value=monospace]");
|
||||||
|
$monospaceoption.attr('selected','selected');
|
||||||
|
|
||||||
|
/*
|
||||||
|
|
||||||
//get the font selector and click it
|
//get the font selector and click it
|
||||||
var $viewfontmenu = testHelper.$getPadChrome().find("#viewfontmenu");
|
var $viewfontmenu = testHelper.$getPadChrome().find("#viewfontmenu");
|
||||||
$viewfontmenu.click(); // this doesnt work but I left it in for posterity.
|
$viewfontmenu.click(); // this doesnt work but I left it in for posterity.
|
||||||
|
@ -22,6 +33,8 @@ describe("font select", function(){
|
||||||
$monospaceoption.attr('selected','selected'); // despite this being selected the event doesnt fire
|
$monospaceoption.attr('selected','selected'); // despite this being selected the event doesnt fire
|
||||||
$monospaceoption.click(); // this doesnt work but it should.
|
$monospaceoption.click(); // this doesnt work but it should.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
// get the attributes of the body of the editor iframe
|
// get the attributes of the body of the editor iframe
|
||||||
var bodyAttr = $inner.find("body");
|
var bodyAttr = $inner.find("body");
|
||||||
var cssText = bodyAttr[0].style.cssText;
|
var cssText = bodyAttr[0].style.cssText;
|
||||||
|
|
99
tests/frontend/specs/helper.js
Normal file
99
tests/frontend/specs/helper.js
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
describe("the test helper", function(){
|
||||||
|
describe("the newPad method", function(){
|
||||||
|
xit("doesn't leak memory if you creates iframes over and over again", function(done){
|
||||||
|
this.timeout(200000);
|
||||||
|
|
||||||
|
var times = 10;
|
||||||
|
|
||||||
|
var loadPad = function(){
|
||||||
|
helper.newPad(function(){
|
||||||
|
times--;
|
||||||
|
if(times > 0){
|
||||||
|
loadPad();
|
||||||
|
} else {
|
||||||
|
done();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
loadPad();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("gives me 3 jquery instances of chrome, outer and inner", function(done){
|
||||||
|
this.timeout(5000);
|
||||||
|
|
||||||
|
helper.newPad(function(){
|
||||||
|
//check if the jquery selectors have the desired elements
|
||||||
|
expect(helper.padChrome$("#editbar").length).to.be(1);
|
||||||
|
expect(helper.padOuter$("#outerdocbody").length).to.be(1);
|
||||||
|
expect(helper.padInner$("#innerdocbody").length).to.be(1);
|
||||||
|
|
||||||
|
//check if the document object was set correctly
|
||||||
|
expect(helper.padChrome$.window.document).to.be(helper.padChrome$.document);
|
||||||
|
expect(helper.padOuter$.window.document).to.be(helper.padOuter$.document);
|
||||||
|
expect(helper.padInner$.window.document).to.be(helper.padInner$.document);
|
||||||
|
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("the waitFor method", function(){
|
||||||
|
it("takes a timeout and waits long enough", function(done){
|
||||||
|
this.timeout(2000);
|
||||||
|
var startTime = new Date().getTime();
|
||||||
|
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return false;
|
||||||
|
}, 1500).fail(function(){
|
||||||
|
var duration = new Date().getTime() - startTime;
|
||||||
|
expect(duration).to.be.greaterThan(1400);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("takes an interval and checks on every interval", function(done){
|
||||||
|
this.timeout(4000);
|
||||||
|
var checks = 0;
|
||||||
|
|
||||||
|
helper.waitFor(function(){
|
||||||
|
checks++;
|
||||||
|
return false;
|
||||||
|
}, 2000, 100).fail(function(){
|
||||||
|
expect(checks).to.be.greaterThan(18);
|
||||||
|
expect(checks).to.be.lessThan(22);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe("returns a deferred object", function(){
|
||||||
|
it("it calls done after success", function(done){
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return true;
|
||||||
|
}).done(function(){
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it("calls fail after failure", function(done){
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return false;
|
||||||
|
},0).fail(function(){
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
xit("throws if you don't listen for fails", function(done){
|
||||||
|
var onerror = window.onerror;
|
||||||
|
window.onerror = function(){
|
||||||
|
window.onerror = onerror;
|
||||||
|
done();
|
||||||
|
}
|
||||||
|
|
||||||
|
helper.waitFor(function(){
|
||||||
|
return false;
|
||||||
|
},100);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
|
@ -2,11 +2,12 @@ describe("delete keystroke", function(){
|
||||||
//create a new pad before each test run
|
//create a new pad before each test run
|
||||||
beforeEach(function(cb){
|
beforeEach(function(cb){
|
||||||
helper.newPad(cb);
|
helper.newPad(cb);
|
||||||
|
this.timeout(5000);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("makes text delete", function() {
|
it("makes text delete", function(done) {
|
||||||
var inner$ = helper.jQueryOf("inner");
|
var inner$ = helper.padInner$;
|
||||||
var chrome$ = helper.jQueryOf("chrome");
|
var chrome$ = helper.padChrome$;
|
||||||
|
|
||||||
//get the first text element out of the inner iframe
|
//get the first text element out of the inner iframe
|
||||||
var $firstTextElement = inner$("div").first();
|
var $firstTextElement = inner$("div").first();
|
||||||
|
@ -31,8 +32,6 @@ describe("delete keystroke", function(){
|
||||||
//expect it to be one char less in length
|
//expect it to be one char less in length
|
||||||
expect(newElementLength).to.be((elementLength-1));
|
expect(newElementLength).to.be((elementLength-1));
|
||||||
|
|
||||||
//make sure the text has changed correctly
|
done();
|
||||||
expect($newFirstTextElement.text()).to.eql(originalTextValueMinusFirstChar);
|
|
||||||
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -2,11 +2,12 @@ describe("urls", function(){
|
||||||
//create a new pad before each test run
|
//create a new pad before each test run
|
||||||
beforeEach(function(cb){
|
beforeEach(function(cb){
|
||||||
helper.newPad(cb);
|
helper.newPad(cb);
|
||||||
|
this.timeout(5000);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("when you enter an url, it becomes clickable", function(done) {
|
it("when you enter an url, it becomes clickable", function(done) {
|
||||||
var inner$ = helper.jQueryOf("inner");
|
var inner$ = helper.padInner$;
|
||||||
var chrome$ = helper.jQueryOf("chrome");
|
var chrome$ = helper.padChrome$;
|
||||||
|
|
||||||
//get the first text element out of the inner iframe
|
//get the first text element out of the inner iframe
|
||||||
var firstTextElement = inner$("div").first();
|
var firstTextElement = inner$("div").first();
|
||||||
|
@ -16,18 +17,6 @@ describe("urls", function(){
|
||||||
firstTextElement.sendkeys('{del}'); // clear the first line
|
firstTextElement.sendkeys('{del}'); // clear the first line
|
||||||
firstTextElement.sendkeys('http://etherpad.org'); // insert a URL
|
firstTextElement.sendkeys('http://etherpad.org'); // insert a URL
|
||||||
|
|
||||||
helper.waitFor(function(){
|
done();
|
||||||
//ace creates a new dom element when you press a keystroke, so just get the first text element again
|
|
||||||
var newFirstTextElement = inner$("div").first();
|
|
||||||
var locatedHref = newFirstTextElement.find("a");
|
|
||||||
var isURL = locatedHref.length == 1; // if we found a URL and it is for etherpad.org
|
|
||||||
|
|
||||||
//expect it to be bold
|
|
||||||
expect(isURL).to.be(true);
|
|
||||||
|
|
||||||
//it will only come to this point if the expect statement above doesn't throw
|
|
||||||
done();
|
|
||||||
return true;
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue