summaryrefslogtreecommitdiffstats
path: root/extensions/spellcheck/tests/mochitest
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 14:29:10 +0000
commit2aa4a82499d4becd2284cdb482213d541b8804dd (patch)
treeb80bf8bf13c3766139fbacc530efd0dd9d54394c /extensions/spellcheck/tests/mochitest
parentInitial commit. (diff)
downloadfirefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz
firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--extensions/spellcheck/tests/mochitest/helper_bug1170484.js14
-rw-r--r--extensions/spellcheck/tests/mochitest/mochitest.ini8
-rw-r--r--extensions/spellcheck/tests/mochitest/test_bug1170484.html59
-rw-r--r--extensions/spellcheck/tests/mochitest/test_bug1272623.html74
4 files changed, 155 insertions, 0 deletions
diff --git a/extensions/spellcheck/tests/mochitest/helper_bug1170484.js b/extensions/spellcheck/tests/mochitest/helper_bug1170484.js
new file mode 100644
index 0000000000..be6505bb44
--- /dev/null
+++ b/extensions/spellcheck/tests/mochitest/helper_bug1170484.js
@@ -0,0 +1,14 @@
+const { Services } = ChromeUtils.import("resource://gre/modules/Services.jsm");
+
+/* eslint-env mozilla/frame-script */
+
+// Chrome scripts are run with synchronous messages, so make sure we're completely
+// decoupled from the content process before doing this work.
+Cu.dispatch(function() {
+ let chromeWin = Services.ww.activeWindow;
+ let contextMenu = chromeWin.document.getElementById("contentAreaContextMenu");
+ var suggestion = contextMenu.querySelector(".spell-suggestion");
+ suggestion.doCommand();
+ contextMenu.hidePopup();
+ sendAsyncMessage("spellingCorrected");
+});
diff --git a/extensions/spellcheck/tests/mochitest/mochitest.ini b/extensions/spellcheck/tests/mochitest/mochitest.ini
new file mode 100644
index 0000000000..3c7ae08f89
--- /dev/null
+++ b/extensions/spellcheck/tests/mochitest/mochitest.ini
@@ -0,0 +1,8 @@
+[DEFAULT]
+skip-if = os == 'android'
+
+[test_bug1170484.html]
+support-files = helper_bug1170484.js
+skip-if = os == 'linux' #Bug 1202570
+
+[test_bug1272623.html]
diff --git a/extensions/spellcheck/tests/mochitest/test_bug1170484.html b/extensions/spellcheck/tests/mochitest/test_bug1170484.html
new file mode 100644
index 0000000000..e32fcf4c3c
--- /dev/null
+++ b/extensions/spellcheck/tests/mochitest/test_bug1170484.html
@@ -0,0 +1,59 @@
+<!DOCTYPE HTML>
+<html>
+<!--
+https://bugzilla.mozilla.org/show_bug.cgi?id=1170484
+-->
+<head>
+ <meta charset="utf-8">
+ <title>Test for Bug 1170484</title>
+ <script src="/tests/SimpleTest/SimpleTest.js"></script>
+ <script src="/tests/SimpleTest/EventUtils.js"></script>
+ <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
+ <script type="application/javascript">
+
+ /** Test for Bug 1170484 **/
+ SimpleTest.waitForExplicitFinish();
+
+ /* global onSpellCheck */
+ SpecialPowers.Cu.import(
+ "resource://testing-common/AsyncSpellCheckTestHelper.jsm", window);
+
+ SimpleTest.waitForFocus(doTest, window);
+ function doTest() {
+ var mutations = 0;
+ var observer = new MutationObserver(() => { mutations++; });
+ observer.observe($('area'), { childList: true, characterData: true, characterDataOldValue: true, subtree: true });
+ var inputEvents = 0;
+ $('area').addEventListener('input', () => ++inputEvents);
+
+ // Clicking the contentEditable during onload doesn't seem to do anything.
+ // Not sure why, but postponing through the event loop seems to be enough.
+ SimpleTest.executeSoon(function() {
+ synthesizeMouseAtCenter($('misspelled'), {}, window);
+ onSpellCheck($('area'), function() {
+ synthesizeMouseAtCenter($('misspelled'), {type: 'contextmenu'}, window);
+ var mm = SpecialPowers.loadChromeScript(SimpleTest.getTestFileURL('helper_bug1170484.js'))
+ info("Loaded chrome script");
+ mm.addMessageListener('spellingCorrected', function() {
+ is($('area').textContent, 'testing spellcheck', "Spelling corrected properly");
+ is(mutations, 1, "Got correct number of mutations");
+ is(inputEvents, 1, "Got correct number of input events");
+ SimpleTest.finish();
+ });
+ });
+ });
+ }
+
+ </script>
+</head>
+<body>
+<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1170484">Mozilla Bug 1170484</a>
+<p id="display"></p>
+<div id="content" style="display: none">
+
+</div>
+<pre id="test">
+ <div id="area" contenteditable="true">testing <span id="misspelled">spellechek</span></div>
+</pre>
+</body>
+</html>
diff --git a/extensions/spellcheck/tests/mochitest/test_bug1272623.html b/extensions/spellcheck/tests/mochitest/test_bug1272623.html
new file mode 100644
index 0000000000..ed3fa3dfdb
--- /dev/null
+++ b/extensions/spellcheck/tests/mochitest/test_bug1272623.html
@@ -0,0 +1,74 @@
+<!DOCTYPE HTML>
+<html>
+<!--
+https://bugzilla.mozilla.org/show_bug.cgi?id=1272623
+-->
+<head>
+ <meta charset="utf-8">
+ <title>Test for Bug 1272623</title>
+ <script src="/tests/SimpleTest/SimpleTest.js"></script>
+ <script src="/tests/SimpleTest/EventUtils.js"></script>
+ <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
+
+</head>
+<body>
+<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1272623">Mozilla Bug 1272623</a>
+<p id="display"></p>
+<div id="content" style="display: none">
+
+</div>
+<pre id="test">
+ <div id="area" contenteditable="true"><b style="font-weight:normal;">testing <span id="misspelled">spellechek</span></b></div>
+ <div id="area2" contenteditable="true">testing <span id="misspelled2" style="font-weight:bold;">spellechek</span></div>
+</pre>
+<script>
+
+/* eslint-env mozilla/frame-script */
+
+/** Test for Bug 1272623 **/
+
+ async function performCorrection(misspelled, area) {
+ synthesizeMouseAtCenter($(misspelled), {}, window);
+ await new Promise(resolve => onSpellCheck($(area), resolve));
+ synthesizeMouseAtCenter($(misspelled), {type: 'contextmenu'}, window);
+
+ // Perform the spelling correction
+ let mm = SpecialPowers.loadChromeScript(function() {
+ const {Services} = ChromeUtils.import("resource://gre/modules/Services.jsm");
+
+ // Chrome scripts are run with synchronous messages, so make sure we're completely
+ // decoupled from the content process before doing this work.
+ Cu.dispatch(function() {
+ let chromeWin = Services.ww.activeWindow;
+ let contextMenu = chromeWin.document.getElementById("contentAreaContextMenu");
+ let suggestion = contextMenu.querySelector(".spell-suggestion");
+ suggestion.doCommand();
+ contextMenu.hidePopup();
+ sendAsyncMessage("spellingCorrected");
+ });
+ });
+ info("Loaded chrome script");
+ await new Promise(resolve => mm.addMessageListener('spellingCorrected', resolve));
+ }
+
+ add_task(async function() {
+ /* global onSpellCheck */
+ SpecialPowers.Cu.import(
+ "resource://testing-common/AsyncSpellCheckTestHelper.jsm", window);
+
+ // Wait for the page to be ready
+ await new Promise(resolve => SimpleTest.waitForFocus(() => SimpleTest.executeSoon(resolve), window));
+
+ // Check that <b> tags aren't inserted inside of other <b> tags when it would change the style
+ await performCorrection('misspelled', 'area');
+ is($('area').innerHTML, "<b style=\"font-weight:normal;\">testing <span id=\"misspelled\">spellcheck</span></b>");
+ is($('area').textContent, 'testing spellcheck', "Spelling corrected properly");
+
+ // Check that nodes aren't removed when the entire text inside of them is spelling-corrected
+ await performCorrection('misspelled2', 'area2');
+ is($('area2').innerHTML, "testing <span id=\"misspelled2\" style=\"font-weight:bold;\">spellcheck</span>");
+ is($('area2').textContent, 'testing spellcheck', "Spelling corrected properly");
+ });
+</script>
+</body>
+</html>