gecko/toolkit/content/tests/widgets/test_popup_tree.xul
2007-09-04 08:30:11 -07:00

75 lines
2.2 KiB
XML

<?xml version="1.0"?>
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
<?xml-stylesheet href="/tests/SimpleTest/test.css" type="text/css"?>
<window title="Tree in Popup Test"
onload="setTimeout(runTests, 0);"
xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
<script type="application/javascript" src="/MochiKit/packed.js"></script>
<script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
<script type="application/javascript" src="/tests/SimpleTest/EventUtils.js"></script>
<panel id="panel" onpopupshown="treeClick()" onpopuphidden="SimpleTest.finish()">
<tree id="tree" width="350" rows="5">
<treecols>
<treecol id="name" label="Name" flex="1"/>
<treecol id="address" label="Street" flex="1"/>
</treecols>
<treechildren id="treechildren">
<treeitem>
<treerow>
<treecell label="Justin Thyme"/>
<treecell label="800 Bay Street"/>
</treerow>
</treeitem>
<treeitem>
<treerow>
<treecell label="Mary Goround"/>
<treecell label="47 University Avenue"/>
</treerow>
</treeitem>
</treechildren>
</tree>
</panel>
<script class="testbody" type="application/javascript">
<![CDATA[
SimpleTest.waitForExplicitFinish();
function runTests()
{
$("panel").openPopup(null, "overlap", 2, 2);
}
function treeClick()
{
var tree = $("tree");
is(tree.currentIndex, -1, "selectedIndex before click");
synthesizeMouseExpectEvent($("treechildren"), 2, 2, { }, $("treechildren"), "click", "");
is(tree.currentIndex, 0, "selectedIndex after click");
var x = { }, y = { }, width = { }, height = { };
tree.treeBoxObject.getCoordsForCellItem(1, tree.columns.address, "", x, y, width, height);
synthesizeMouseExpectEvent($("treechildren"), x.value, y.value + 2,
{ }, $("treechildren"), "click", "");
is(tree.currentIndex, 1, "selectedIndex after second click " + x.value + "," + y.value);
$("panel").hidePopup();
}
]]>
</script>
<body xmlns="http://www.w3.org/1999/xhtml">
<p id="display">
</p>
<div id="content" style="display: none">
</div>
<pre id="test">
</pre>
</body>
</window>