Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(13)

Side by Side Diff: LayoutTests/editing/spelling/spelling-huge-text.html

Issue 23332004: Trigger spell check/remove markers if spell checker gets enabled/disabled. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: true=>asynchronous Created 7 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 <!DOCTYPE html>
2 <html>
3 <head>
4 <script src="../../fast/js/resources/js-test-pre.js"></script>
5 </head>
6 <body onload="test();">
7 <div id="console"></div>
8 <div id="editable" contenteditable></div>
9
10 <script>
11 description("Text to check is divided into chunks to make sure checking some hug e text " +
12 "does not freeze the page/UI. With the asynchronous spell checker the whole text is checked. " +
13 "To test manaully trigger spell checking of the editable (e.g. by copy+paste) wi th unified " +
14 "and asynchronous checker on. There should be 6 misspellings marked.");
15
16 var testEditable = null;
17
18 function test()
19 {
20 testEditable = document.getElementById("editable");
21 var loopCount = 150;
22 var longText = "Good good good good good good good good good good good good good. " +
23 "Good good good good good good good good good good good good good. " +
24 "Good good good good good good good good good good good good good. " +
25 "Good good good good good good good good good good good good good.";
26
27 var testLongText = "";
28 for (var i = 0; i < loopCount; ++i)
29 testLongText += longText;
30
31 testLongText = "zz zz zz. " + testLongText + " zz zz zz.";
32 testEditable.innerText = testLongText;
33
34 if (!window.internals) {
35 log("Test manually. See the description for steps");
36 return;
37 }
38
39 internals.settings.setUnifiedTextCheckerEnabled(true);
40 internals.settings.setAsynchronousSpellCheckingEnabled(true);
41
42 function waitForMarkersToAppear(node, nretry)
43 {
44 if (nretry > 0 && internals.markerCountForNode(node, "spelling") < 6) {
45 window.setTimeout(function() { waitForMarkersToAppear(node, nretry - 1); }, 1);
46 } else {
47 shouldBe('internals.markerCountForNode(testEditable.childNodes[0], " spelling")', '6');
48 testEditable.removeChild(testEditable.childNodes[0]);
49 if (window.testRunner)
50 testRunner.notifyDone();
51 }
52 }
53
54 if (window.testRunner) {
55 testRunner.dumpAsText();
56 testRunner.waitUntilDone();
57 }
58
59 internals.setContinuousSpellCheckingEnabled(false);
60 testEditable.focus();
61 internals.setContinuousSpellCheckingEnabled(true);
62 waitForMarkersToAppear(testEditable.childNodes[0], 10);
63 }
64 </script>
65 <script src="../../fast/js/resources/js-test-post.js"></script>
66 </body>
67 </html>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698