summaryrefslogtreecommitdiffstats
path: root/toolkit/content/tests/widgets/test_contextmenu_menugroup.xhtml
blob: 88511001b7d8b097116b8d7714172e8ad357186f (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
<?xml version="1.0"?>
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
<?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css" type="text/css"?>

<window title="Context menugroup Tests"
        xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">

  <script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
  <script src="chrome://mochikit/content/tests/SimpleTest/EventUtils.js"></script>
  <script type="application/javascript" src="popup_shared.js"></script>

<menupopup id="context">
  <menugroup>
    <menuitem id="a"/>
    <menuitem id="b"/>
  </menugroup>
  <menuitem id="c" label="c"/>
  <menugroup/>
</menupopup>

<button label="Check"/>

<vbox id="popuparea" popup="context" style="width: 20px; height: 20px"/>

<script type="application/javascript">
<![CDATA[

SimpleTest.waitForExplicitFinish();

var gMenuPopup = $("context");
ok(gMenuPopup, "Got the reference to the context menu");

var popupTests = [
{
  testname: "one-down-key",
  condition() { return (!navigator.platform.includes("Mac")); },
  events: [ "popupshowing context", "popupshown context", "DOMMenuItemActive a" ],
  test() {
    synthesizeMouse($("popuparea"), 4, 4, {});
    synthesizeKey("KEY_ArrowDown");
  },
  result(testname) {
    checkActive(gMenuPopup, "a", testname);
  }
},
{
  testname: "two-down-keys",
  condition() { return (!navigator.platform.includes("Mac")); },
  events: [ "DOMMenuItemInactive a", "DOMMenuItemActive b" ],
  test: () => synthesizeKey("KEY_ArrowDown"),
  result(testname) {
    checkActive(gMenuPopup, "b", testname);
  }
},
{
  testname: "three-down-keys",
  condition() { return (!navigator.platform.includes("Mac")); },
  events: [ "DOMMenuItemInactive b", "DOMMenuItemActive c" ],
  test: () => synthesizeKey("KEY_ArrowDown"),
  result(testname) {
    checkActive(gMenuPopup, "c", testname);
  }
},
{
  testname: "three-down-keys-one-up-key",
  condition() { return (!navigator.platform.includes("Mac")); },
  events: [ "DOMMenuItemInactive c", "DOMMenuItemActive b" ],
  test: () => synthesizeKey("KEY_ArrowUp"),
  result (testname) {
    checkActive(gMenuPopup, "b", testname);
  }
},
{
  testname: "three-down-keys-two-up-keys",
  condition() { return (!navigator.platform.includes("Mac")); },
  events: [ "DOMMenuItemInactive b", "DOMMenuItemActive a" ],
  test: () => synthesizeKey("KEY_ArrowUp"),
  result(testname) {
    checkActive(gMenuPopup, "a", testname);
  }
},
{
  testname: "three-down-keys-three-up-key",
  condition() { return (!navigator.platform.includes("Mac")); },
  events: [ "DOMMenuItemInactive a", "DOMMenuItemActive c" ],
  test: () => synthesizeKey("KEY_ArrowUp"),
  result(testname) {
    checkActive(gMenuPopup, "c", testname);
  }
},
];

SimpleTest.waitForFocus(function runTest() {
  startPopupTests(popupTests);
});

]]>
</script>

<body xmlns="http://www.w3.org/1999/xhtml"><p id="display"/></body>

</window>