mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-22 07:16:13 +01:00
69c7033a86
* don't include sendkeys in index.html as it's included in helper.init mocha opts: add default timeout and replace ignoreLeaks with checkLeaks, as the former is deprecated * introduce helper.edit to write to a pad * add test to check if helper.edit() supports line numbers * helper tests: waitFor/waitForPromise seem to be a little bit faster sometimes * tests: refactor chat.js * tests: refactor timeslider_numeric_padID * tests: refactor timeslider_labels * tests: refactor timeslider_follow * ensure followContents is enabled, although it should be by default * timeslider_follow: increase number of revision for Edge * make textLines() depend on linesDiv() Co-authored-by: Richard Hansen <rhansen@rhansen.org> * make linesDiv return standard Array * use `contain` instead of `indexOf` * more fixes from the review * review fixes * align waitFor and waitForPromise behaviour * timeslider_follow: check if it's following to the correct lines * lower expected waitFor/waitForPromise interval check * disable responsivness and regression test in timeslider_follow * timeslider_follow: fix Range detection * more explicit test for linesDiv Co-authored-by: Richard Hansen <rhansen@rhansen.org>
89 lines
3.7 KiB
JavaScript
89 lines
3.7 KiB
JavaScript
// Test for https://github.com/ether/etherpad-lite/issues/1763
|
|
|
|
// This test fails in Opera, IE and Safari
|
|
// Opera fails due to a weird way of handling the order of execution, yet actual performance seems fine
|
|
// Safari fails due the delay being too great yet the actual performance seems fine
|
|
// Firefox might panic that the script is taking too long so will fail
|
|
// IE will fail due to running out of memory as it can't fit 2M chars in memory.
|
|
|
|
// Just FYI Google Docs crashes on large docs whilst trying to Save, it's likely the limitations we are
|
|
// experiencing are more to do with browser limitations than improper implementation.
|
|
// A ueber fix for this would be to have a separate lower cpu priority thread that handles operations that aren't
|
|
// visible to the user.
|
|
|
|
// Adapted from John McLear's original test case.
|
|
|
|
xdescribe('Responsiveness of Editor', function() {
|
|
// create a new pad before each test run
|
|
beforeEach(function(cb) {
|
|
helper.newPad(cb);
|
|
this.timeout(6000);
|
|
});
|
|
// JM commented out on 8th Sep 2020 for a release, after release this needs uncommenting
|
|
// And the test needs to be fixed to work in Firefox 52 on Windows 7. I am not sure why it fails on this specific platform
|
|
// The errors show this.timeout... then crash the browser but I am sure something is actually causing the stack trace and
|
|
// I just need to narrow down what, offers to help accepted.
|
|
it('Fast response to keypress in pad with large amount of contents', function(done) {
|
|
|
|
//skip on Windows Firefox 52.0
|
|
if(window.bowser && window.bowser.windows && window.bowser.firefox && window.bowser.version == "52.0") {
|
|
this.skip();
|
|
}
|
|
var inner$ = helper.padInner$;
|
|
var chrome$ = helper.padChrome$;
|
|
var chars = '0000000000'; // row of placeholder chars
|
|
var amount = 200000; //number of blocks of chars we will insert
|
|
var length = (amount * (chars.length) +1); // include a counter for each space
|
|
var text = ''; // the text we're gonna insert
|
|
this.timeout(amount * 150); // Changed from 100 to 150 to allow Mac OSX Safari to be slow.
|
|
|
|
// get keys to send
|
|
var keyMultiplier = 10; // multiplier * 10 == total number of key events
|
|
var keysToSend = '';
|
|
for(var i=0; i <= keyMultiplier; i++) {
|
|
keysToSend += chars;
|
|
}
|
|
|
|
var textElement = inner$('div');
|
|
textElement.sendkeys('{selectall}'); // select all
|
|
textElement.sendkeys('{del}'); // clear the pad text
|
|
|
|
for(var i=0; i <= amount; i++) {
|
|
text = text + chars + ' '; // add the chars and space to the text contents
|
|
}
|
|
inner$('div').first().text(text); // Put the text contents into the pad
|
|
|
|
helper.waitFor(function(){ // Wait for the new contents to be on the pad
|
|
return inner$('div').text().length > length;
|
|
}).done(function(){
|
|
|
|
expect( inner$('div').text().length ).to.be.greaterThan( length ); // has the text changed?
|
|
var start = Date.now(); // get the start time
|
|
|
|
// send some new text to the screen (ensure all 3 key events are sent)
|
|
var el = inner$('div').first();
|
|
for(var i = 0; i < keysToSend.length; ++i) {
|
|
var x = keysToSend.charCodeAt(i);
|
|
['keyup', 'keypress', 'keydown'].forEach(function(type) {
|
|
var e = $.Event(type);
|
|
e.keyCode = x;
|
|
el.trigger(e);
|
|
});
|
|
}
|
|
|
|
helper.waitFor(function(){ // Wait for the ability to process
|
|
var el = inner$('body');
|
|
if(el[0].textContent.length > amount) return true;
|
|
}).done(function(){
|
|
var end = Date.now(); // get the current time
|
|
var delay = end - start; // get the delay as the current time minus the start time
|
|
|
|
expect(delay).to.be.below(600);
|
|
done();
|
|
}, 5000);
|
|
|
|
}, 10000);
|
|
});
|
|
|
|
});
|
|
|