merged remote feature/frontend-tests

This commit is contained in:
Peter 'Pita' Martischka 2012-10-04 14:35:25 +02:00
commit 95ce0aaba8
6 changed files with 670 additions and 2 deletions

View file

@ -0,0 +1,33 @@
describe("italic button", function(){
//create a new pad before each test run
beforeEach(function(cb){
testHelper.newPad(cb);
});
it("makes text italic", function() {
//get the inner iframe
var $inner = testHelper.$getPadInner();
//get the first text element out of the inner iframe
var firstTextElement = $inner.find("div").first();
//select this text element
testHelper.selectText(firstTextElement[0], $inner);
//get the bold button and click it
var $italicButton = testHelper.$getPadChrome().find(".buttonicon-italic");
$italicButton.click();
//ace creates a new dom element when you press a button, so just get the first text element again
var newFirstTextElement = $inner.find("div").first();
// is there a <b> element now?
var isItalic = newFirstTextElement.find("i").length === 1;
//expect it to be bold
expect(isItalic).to.be(true);
//make sure the text hasn't changed
expect(newFirstTextElement.text()).to.eql(firstTextElement.text());
});
});

View file

@ -0,0 +1,38 @@
describe("delete keystroke", function(){
//create a new pad before each test run
beforeEach(function(cb){
testHelper.newPad(cb);
});
it("makes text delete", function() {
//get the inner iframe
var $inner = testHelper.$getPadInner();
//get the first text element out of the inner iframe
var firstTextElement = $inner.find("div").first();
// get the original length of this element
var elementLength = firstTextElement.html().length;
// get the original string value minus the last char
var originalTextValue = firstTextElement.text();
originalTextValue = originalTextValue.substring(0, originalTextValue.length -1);
// simulate key presses to delete content
firstTextElement.sendkeys('{leftarrow}'); // simulate a keypress of the left arrow key
firstTextElement.sendkeys('{del}'); // simulate a keypress of delete
//ace creates a new dom element when you press a keystroke, so just get the first text element again
var newFirstTextElement = $inner.find("div").first();
// get the new length of this element
var newElementLength = newFirstTextElement.html().length;
//expect it to be one char less in length
expect(newElementLength).to.be((elementLength-1));
//make sure the text has changed correctly
expect(newFirstTextElement.text()).to.eql(originalTextValue);
});
});

View file

@ -0,0 +1,29 @@
describe("urls become clickable", function(){
//create a new pad before each test run
beforeEach(function(cb){
testHelper.newPad(cb);
});
it("adds a url and makes sure it's clickable", function() {
//get the inner iframe
var $inner = testHelper.$getPadInner();
//get the first text element out of the inner iframe
var firstTextElement = $inner.find("div").first();
// simulate key presses to delete content
firstTextElement.sendkeys('{selectall}'); // select all
firstTextElement.sendkeys('{del}'); // clear the first line
firstTextElement.sendkeys('http://etherpad.org'); // add a url to the pad
//ace creates a new dom element when you press a keystroke, so just get the first text element again
var newFirstTextElement = $inner.find("div").first();
// is there a url class now?
var isURL = newFirstTextElement.find("href").length === 1;
//expect it to be bold
expect(isURL).to.be(true);
});
});