summaryrefslogtreecommitdiffstats
path: root/toolkit/content/tests/chrome/test_bug360220.xhtml
blob: a942e0acd6fb1afdfc7401d4c4fdd174f5ac8cd1 (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
<?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"?>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=360220
-->
<window title="Mozilla Bug 360220"
  xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">

  <script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>      

<body  xmlns="http://www.w3.org/1999/xhtml">
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=360220">Mozilla Bug 360220</a>
<p id="display"></p>
<div id="content" style="display: none">
  
</div>
<pre id="test">
</pre>
</body>

<menulist id="menulist">
  <menupopup>
    <menuitem id="firstItem" label="foo" selected="true"/>
    <menuitem id="secondItem" label="bar"/>
  </menupopup>
</menulist>
<script class="testbody" type="application/javascript">
<![CDATA[

SimpleTest.waitForExplicitFinish();

/** Test for Bug 360220 **/

var menulist = document.getElementById("menulist");
var secondItem = document.getElementById("secondItem");
menulist.selectedItem = secondItem;

is(menulist.label, "bar", "second item was not selected");

let mutObserver = new MutationObserver(() => {
  is(menulist.label, "new label", "menulist label was not updated to the label of its selected item");
  done();
});
mutObserver.observe(menulist, { attributeFilter: ['label'] });
secondItem.label = "new label";

let failureTimeout = setTimeout(function() {
  ok(false, "menulist label should have updated");
  done();
}, 2000);

function done() {
  mutObserver.disconnect();
  clearTimeout(failureTimeout);
  SimpleTest.finish();
}
]]>
</script>

</window>