summaryrefslogtreecommitdiffstats
path: root/extensions/spellcheck/tests/mochitest/test_bug1272623.html
blob: 22e9d9a09a4e7c962c352c72e915c93ed4c46fa8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
<!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>

/** Test for Bug 1272623 **/

  var maybeOnSpellCheck;

  async function performCorrection(misspelled, area) {
    synthesizeMouseAtCenter($(misspelled), {}, window);
    await new Promise(resolve => maybeOnSpellCheck($(area), resolve));
    synthesizeMouseAtCenter($(misspelled), {type: 'contextmenu'}, window);

    // Perform the spelling correction
    let mm = SpecialPowers.loadChromeScript(function() {
      /* eslint-env mozilla/chrome-script */
      const {BrowserTestUtils} = ChromeUtils.import("resource://testing-common/BrowserTestUtils.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(async function() {
        let chromeWin = Services.ww.activeWindow;
        let contextMenu = chromeWin.document.getElementById("contentAreaContextMenu");
        let suggestion = contextMenu.querySelector(".spell-suggestion");
        if (!suggestion) {
          await BrowserTestUtils.waitForMutationCondition(
            contextMenu,
            { childList: true },
            () => contextMenu.querySelector(".spell-suggestion")
          );
          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() {
    maybeOnSpellCheck = SpecialPowers.ChromeUtils.import(
      "resource://testing-common/AsyncSpellCheckTestHelper.jsm"
    ).maybeOnSpellCheck;

    // 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>