summaryrefslogtreecommitdiffstats
path: root/accessible/tests/browser/mac/browser_label_title.js
blob: 2532247e0f7ba7219c0ef83abc9b6b6ae9890a68 (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
107
108
109
110
111
/* 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";

/* import-globals-from ../../mochitest/role.js */
/* import-globals-from ../../mochitest/states.js */
loadScripts(
  { name: "role.js", dir: MOCHITESTS_DIR },
  { name: "states.js", dir: MOCHITESTS_DIR }
);

/**
 * Test different labeling/titling schemes for text fields
 */
addAccessibleTask(
  `<label for="n1">Label</label> <input id="n1">
   <label for="n2">Two</label> <label for="n2">Labels</label> <input id="n2">
   <input aria-label="ARIA Label" id="n3">`,
  (browser, accDoc) => {
    let n1 = getNativeInterface(accDoc, "n1");
    let n1Label = n1.getAttributeValue("AXTitleUIElement");
    // XXX: In Safari the label is an AXText with an AXValue,
    // here it is an AXGroup witth an AXTitle
    is(n1Label.getAttributeValue("AXTitle"), "Label");

    let n2 = getNativeInterface(accDoc, "n2");
    is(n2.getAttributeValue("AXDescription"), "TwoLabels");

    let n3 = getNativeInterface(accDoc, "n3");
    is(n3.getAttributeValue("AXDescription"), "ARIA Label");
  }
);

/**
 * Test to see that named groups get labels
 */
addAccessibleTask(
  `<fieldset id="fieldset"><legend>Fields</legend><input aria-label="hello"></fieldset>`,
  (browser, accDoc) => {
    let fieldset = getNativeInterface(accDoc, "fieldset");
    is(fieldset.getAttributeValue("AXDescription"), "Fields");
  }
);

/**
 * Test to see that list items don't get titled groups
 */
addAccessibleTask(
  `<ul style="list-style: none;"><li id="unstyled-item">Hello</li></ul>
   <ul><li id="styled-item">World</li></ul>`,
  (browser, accDoc) => {
    let unstyledItem = getNativeInterface(accDoc, "unstyled-item");
    is(unstyledItem.getAttributeValue("AXTitle"), "");

    let styledItem = getNativeInterface(accDoc, "unstyled-item");
    is(styledItem.getAttributeValue("AXTitle"), "");
  }
);

/**
 * Test that we fire a title changed notification
 */
addAccessibleTask(
  `<div id="elem" aria-label="Hello world"></div>`,
  async (browser, accDoc) => {
    let elem = getNativeInterface(accDoc, "elem");
    is(elem.getAttributeValue("AXTitle"), "Hello world");
    let evt = waitForMacEvent("AXTitleChanged", "elem");
    await SpecialPowers.spawn(browser, [], () => {
      content.document
        .getElementById("elem")
        .setAttribute("aria-label", "Hello universe");
    });
    await evt;
    is(elem.getAttributeValue("AXTitle"), "Hello universe");
  }
);

/**
 * Test articles supply only labels not titles
 */
addAccessibleTask(
  `<article id="article" aria-label="Hello world"></article>`,
  async (browser, accDoc) => {
    let article = getNativeInterface(accDoc, "article");
    is(article.getAttributeValue("AXDescription"), "Hello world");
    ok(!article.getAttributeValue("AXTitle"));
  }
);

/**
 * Test text and number inputs supply only labels not titles
 */
addAccessibleTask(
  `<label for="input">Your favorite number?</label><input type="text" name="input" value="11" id="input" aria-label="The best number you know of">`,
  async (browser, accDoc) => {
    let input = getNativeInterface(accDoc, "input");
    is(input.getAttributeValue("AXDescription"), "The best number you know of");
    ok(!input.getAttributeValue("AXTitle"));
    let evt = waitForEvent(EVENT_SHOW, "input");
    await SpecialPowers.spawn(browser, [], () => {
      content.document.getElementById("input").setAttribute("type", "number");
    });
    await evt;
    input = getNativeInterface(accDoc, "input");
    is(input.getAttributeValue("AXDescription"), "The best number you know of");
    ok(!input.getAttributeValue("AXTitle"));
  }
);