mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-04-21 16:06:16 -04:00
merged remote feature/frontend-tests
This commit is contained in:
commit
95ce0aaba8
6 changed files with 670 additions and 2 deletions
33
tests/frontend/specs/button_italic.js
Normal file
33
tests/frontend/specs/button_italic.js
Normal 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());
|
||||
});
|
||||
});
|
38
tests/frontend/specs/keystroke_delete.js
Normal file
38
tests/frontend/specs/keystroke_delete.js
Normal 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);
|
||||
|
||||
});
|
||||
});
|
29
tests/frontend/specs/keystroke_urls_become_clickable.js
Normal file
29
tests/frontend/specs/keystroke_urls_become_clickable.js
Normal 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);
|
||||
|
||||
});
|
||||
});
|
Loading…
Add table
Add a link
Reference in a new issue