summaryrefslogtreecommitdiffstats
path: root/accessible/tests/browser/hittest/browser_test_zoom_text.js
blob: 9e429c16b3c3463c57a5829d30eca49927f6a6e5 (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
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

"use strict";

async function runTests(browser, accDoc) {
  const expectedLength = await invokeContentTask(browser, [], () => {
    const { CommonUtils } = ChromeUtils.importESModule(
      "chrome://mochitests/content/browser/accessible/tests/browser/Common.sys.mjs"
    );
    const hyperText = CommonUtils.getNode("paragraph", content.document);
    return Math.floor(hyperText.textContent.length / 2);
  });
  const hyperText = findAccessibleChildByID(accDoc, "paragraph", [
    Ci.nsIAccessibleText,
  ]);
  const textNode = hyperText.firstChild;

  let [x, y, width, height] = Layout.getBounds(
    textNode,
    await getContentDPR(browser)
  );

  await testOffsetAtPoint(
    hyperText,
    x + width / 2,
    y + height / 2,
    COORDTYPE_SCREEN_RELATIVE,
    expectedLength
  );

  await invokeContentTask(browser, [], () => {
    const { Layout } = ChromeUtils.importESModule(
      "chrome://mochitests/content/browser/accessible/tests/browser/Layout.sys.mjs"
    );

    Layout.zoomDocument(content.document, 2.0);
    content.document.body.offsetTop; // getBounds doesn't flush layout on its own.
  });

  [x, y, width, height] = Layout.getBounds(
    textNode,
    await getContentDPR(browser)
  );

  await testOffsetAtPoint(
    hyperText,
    x + width / 2,
    y + height / 2,
    COORDTYPE_SCREEN_RELATIVE,
    expectedLength
  );
}

addAccessibleTask(
  `<p id="paragraph" style="font-family: monospace;">hello world hello world</p>`,
  runTests,
  {
    iframe: true,
    remoteIframe: true,
    iframeAttrs: { style: "width: 600px; height: 600px;" },
  }
);