summaryrefslogtreecommitdiffstats
path: root/editor/libeditor/tests/browser_bug629172.js
blob: 0c4f34069250327896e96ba2b3a7e863b91c0937 (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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
add_task(function*() {
  yield new Promise(resolve => waitForFocus(resolve, window));

  const kPageURL = "http://example.org/browser/editor/libeditor/tests/bug629172.html";
  yield BrowserTestUtils.withNewTab({
    gBrowser,
    url: kPageURL
  }, function*(aBrowser) {
    yield ContentTask.spawn(aBrowser, {}, function*() {
      var window = content.window.wrappedJSObject;
      var document = window.document;

      // Note: Using the with keyword, we would have been able to write this as:
      //
      // with (window) {
      //   Screenshots = {};
      //   // so on
      // }
      //
      // However, browser-chrome tests are somehow forced to run in strict mode,
      // which doesn't permit the usage of the with keyword, turning the following
      // into the ugliest test you've ever seen.  :(
      var LTRRef = document.getElementById("ltr-ref");
      var RTLRef = document.getElementById("rtl-ref");
      window.Screenshots = {};

      // generate the reference screenshots
      LTRRef.style.display = "";
      document.body.clientWidth;
      window.Screenshots.ltr = window.snapshotWindow(window);
      LTRRef.parentNode.removeChild(LTRRef);
      RTLRef.style.display = "";
      document.body.clientWidth;
      window.Screenshots.rtl = window.snapshotWindow(window);
      RTLRef.parentNode.removeChild(RTLRef);
      window.Screenshots.get = function(dir, flip) {
        if (flip) {
          return this[dir == "rtl" ? "ltr" : "rtl"];
        } else {
          return this[dir];
        }
      };
    });

    function simulateCtrlShiftX(aBrowser) {
      // In e10s, the keypress event will be dispatched to the content process,
      // but in non-e10s it is handled by the browser UI code and hence won't
      // reach the web page.  As a result, we need to observe the event in
      // the content process only in e10s mode.
      var waitForKeypressContent = BrowserTestUtils.waitForContentEvent(aBrowser, "keypress");
      EventUtils.synthesizeKey("x", {accelKey: true, shiftKey: true});
      if (gMultiProcessBrowser) {
        return waitForKeypressContent;
      }
      return Promise.resolve();
    }

    function* testDirection(initialDir, aBrowser) {
      yield ContentTask.spawn(aBrowser, {initialDir}, function({initialDir}) {
        var window = content.window.wrappedJSObject;
        var document = window.document;

        var t = window.t = document.createElement("textarea");
        t.setAttribute("dir", initialDir);
        t.value = "test.";
        window.inputEventCount = 0;
        t.oninput = function() { window.inputEventCount++; };
        document.getElementById("content").appendChild(t);
        document.body.clientWidth;
        var s1 = window.snapshotWindow(window);
        ok(window.compareSnapshots(s1, window.Screenshots.get(initialDir, false), true)[0],
           "Textarea should appear correctly before switching the direction (" + initialDir + ")");
        t.focus();
        is(window.inputEventCount, 0, "input event count must be 0 before");
      });
      yield simulateCtrlShiftX(aBrowser);
      yield ContentTask.spawn(aBrowser, {initialDir}, function({initialDir}) {
        var window = content.window.wrappedJSObject;

        is(window.t.getAttribute("dir"), initialDir == "ltr" ? "rtl" : "ltr", "The dir attribute must be correctly updated");
        is(window.inputEventCount, 1, "input event count must be 1 after");
        window.t.blur();
        var s2 = window.snapshotWindow(window);
        ok(window.compareSnapshots(s2, window.Screenshots.get(initialDir, true), true)[0],
           "Textarea should appear correctly after switching the direction (" + initialDir + ")");
        window.t.focus();
        is(window.inputEventCount, 1, "input event count must be 1 before");
      });
      yield simulateCtrlShiftX(aBrowser);
      yield ContentTask.spawn(aBrowser, {initialDir}, function({initialDir}) {
        var window = content.window.wrappedJSObject;

        is(window.inputEventCount, 2, "input event count must be 2 after");
        is(window.t.getAttribute("dir"), initialDir == "ltr" ? "ltr" : "rtl", "The dir attribute must be correctly updated");
        window.t.blur();
        var s3 = window.snapshotWindow(window);
        ok(window.compareSnapshots(s3, window.Screenshots.get(initialDir, false), true)[0],
           "Textarea should appear correctly after switching back the direction (" + initialDir + ")");
        window.t.parentNode.removeChild(window.t);
      });
    }

    yield testDirection("ltr", aBrowser);
    yield testDirection("rtl", aBrowser);
  });
});