2012-10-03 19:57:04 +00:00
|
|
|
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
|
2012-10-04 18:12:01 +00:00
|
|
|
var elementLength = firstTextElement.text().length;
|
2012-10-03 19:57:04 +00:00
|
|
|
|
2012-10-03 20:25:31 +00:00
|
|
|
// get the original string value minus the last char
|
|
|
|
var originalTextValue = firstTextElement.text();
|
2012-10-04 18:12:01 +00:00
|
|
|
originalTextValueMinusFirstChar = originalTextValue.substring(1, originalTextValue.length );
|
2012-10-03 19:57:04 +00:00
|
|
|
|
2012-10-03 20:25:31 +00:00
|
|
|
// 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
|
2012-10-03 19:57:04 +00:00
|
|
|
|
|
|
|
//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
|
2012-10-04 18:12:01 +00:00
|
|
|
var newElementLength = newFirstTextElement.text().length;
|
2012-10-03 19:57:04 +00:00
|
|
|
|
2012-10-03 20:25:31 +00:00
|
|
|
//expect it to be one char less in length
|
2012-10-03 19:57:04 +00:00
|
|
|
expect(newElementLength).to.be((elementLength-1));
|
|
|
|
|
2012-10-03 20:25:31 +00:00
|
|
|
//make sure the text has changed correctly
|
2012-10-04 18:12:01 +00:00
|
|
|
expect(newFirstTextElement.text()).to.eql(originalTextValueMinusFirstChar);
|
2012-10-03 20:25:31 +00:00
|
|
|
|
2012-10-03 19:57:04 +00:00
|
|
|
});
|
|
|
|
});
|