1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/accessible/tests/mochitest/states/test_visibility.xul Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,152 @@ 1.4 +<?xml version="1.0"?> 1.5 +<?xml-stylesheet href="chrome://global/skin" type="text/css"?> 1.6 +<?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css" 1.7 + type="text/css"?> 1.8 + 1.9 +<window xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul" 1.10 + title="XUL elements visibility states testing"> 1.11 + 1.12 + <script type="application/javascript" 1.13 + src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js" /> 1.14 + 1.15 + <script type="application/javascript" 1.16 + src="../common.js" /> 1.17 + <script type="application/javascript" 1.18 + src="../role.js" /> 1.19 + <script type="application/javascript" 1.20 + src="../states.js" /> 1.21 + <script type="application/javascript" 1.22 + src="../events.js" /> 1.23 + 1.24 + <script type="application/javascript"> 1.25 + <![CDATA[ 1.26 + function openMenu(aID, aSubID, aOffscreenSubID) 1.27 + { 1.28 + this.menuNode = getNode(aID); 1.29 + 1.30 + this.eventSeq = [ 1.31 + new invokerChecker(EVENT_FOCUS, this.menuNode) 1.32 + ]; 1.33 + 1.34 + this.invoke = function openMenu_invoke() 1.35 + { 1.36 + this.menuNode.open = true; 1.37 + } 1.38 + 1.39 + this.finalCheck = function openMenu_finalCheck() 1.40 + { 1.41 + testStates(aID, 0, 0, STATE_INVISIBLE | STATE_OFFSCREEN); 1.42 + testStates(aSubID, 0, 0, STATE_INVISIBLE | STATE_OFFSCREEN); 1.43 + if (aOffscreenSubID) 1.44 + testStates(aOffscreenSubID, STATE_OFFSCREEN, 0, STATE_INVISIBLE); 1.45 + } 1.46 + 1.47 + this.getID = function openMenu_invoke() 1.48 + { 1.49 + return "open menu '" + aID + "' and test states"; 1.50 + } 1.51 + } 1.52 + 1.53 + function closeMenu(aID, aSubID, aSub2ID) 1.54 + { 1.55 + this.menuNode = getNode(aID); 1.56 + 1.57 + this.eventSeq = [ 1.58 + new invokerChecker(EVENT_FOCUS, document) 1.59 + ]; 1.60 + 1.61 + this.invoke = function openMenu_invoke() 1.62 + { 1.63 + this.menuNode.open = false; 1.64 + } 1.65 + 1.66 + this.finalCheck = function openMenu_finalCheck() 1.67 + { 1.68 + testStates(aID, 0, 0, STATE_INVISIBLE | STATE_OFFSCREEN); 1.69 + testStates(aSubID, STATE_INVISIBLE, 0, STATE_OFFSCREEN); 1.70 + testStates(aSub2ID, STATE_INVISIBLE, 0, STATE_OFFSCREEN); 1.71 + } 1.72 + 1.73 + this.getID = function openMenu_invoke() 1.74 + { 1.75 + return "open menu and test states"; 1.76 + } 1.77 + } 1.78 + 1.79 + var gQueue = null; 1.80 + function doTest() 1.81 + { 1.82 + testStates("deck_pane2", 0, 0, STATE_INVISIBLE | STATE_OFFSCREEN); 1.83 + testStates("tabs_pane1", 0, 0, STATE_INVISIBLE | STATE_OFFSCREEN); 1.84 + testStates("tabs_pane2", STATE_OFFSCREEN, 0, STATE_INVISIBLE); 1.85 + 1.86 + gQueue = new eventQueue(); 1.87 + gQueue.push(new openMenu("mi_file1", "mi_file1.1")); 1.88 + gQueue.push(new openMenu("mi_file1.2", "mi_file1.2.1", "mi_file1.2.4")); 1.89 + gQueue.push(new closeMenu("mi_file1", "mi_file1.1", "mi_file1.2.1")); 1.90 + gQueue.invoke(); // Will call SimpleTest.finish(); 1.91 + } 1.92 + 1.93 + SimpleTest.waitForExplicitFinish(); 1.94 + addA11yLoadEvent(doTest); 1.95 + ]]> 1.96 + </script> 1.97 + 1.98 + <hbox flex="1" style="overflow: auto;"> 1.99 + <body xmlns="http://www.w3.org/1999/xhtml"> 1.100 + <a target="_blank" 1.101 + href="https://bugzilla.mozilla.org/show_bug.cgi?id=810260" 1.102 + title="xul:deck hidden pages shouldn't be offscreen"> 1.103 + Mozilla Bug 810260 1.104 + </a> 1.105 + <a target="_blank" 1.106 + href="https://bugzilla.mozilla.org/show_bug.cgi?id=865591" 1.107 + title="Visible menu item have offscreen state"> 1.108 + Mozilla Bug 865591 1.109 + </a> 1.110 + 1.111 + <p id="display"></p> 1.112 + <div id="content" style="display: none"> 1.113 + </div> 1.114 + <pre id="test"> 1.115 + </pre> 1.116 + </body> 1.117 + 1.118 + <vbox flex="1"> 1.119 + 1.120 + <deck selectedIndex="1"> 1.121 + <description value="This is the first page" id="deck_pane1"/> 1.122 + <button label="This is the second page" id="deck_pane2"/> 1.123 + </deck> 1.124 + 1.125 + <tabbox> 1.126 + <tabs> 1.127 + <tab>tab1</tab> 1.128 + <tab>tab2</tab> 1.129 + </tabs> 1.130 + <tabpanels> 1.131 + <description value="This is the first page" id="tabs_pane1"/> 1.132 + <button label="This is the second page" id="tabs_pane2"/> 1.133 + </tabpanels> 1.134 + </tabbox> 1.135 + 1.136 + <menubar> 1.137 + <menu label="File" id="mi_file1"> 1.138 + <menupopup> 1.139 + <menuitem label="SubFile" id="mi_file1.1"/> 1.140 + <menu label="SubFile2" id="mi_file1.2"> 1.141 + <menupopup style="max-height: 5em;"> 1.142 + <menuitem label="SubSubFile" id="mi_file1.2.1"/> 1.143 + <menuitem label="SubSubFile2" id="mi_file1.2.2"/> 1.144 + <menuitem label="SubSubFile3" id="mi_file1.2.3"/> 1.145 + <menuitem label="SubSubFile4" id="mi_file1.2.4"/> 1.146 + </menupopup> 1.147 + </menu> 1.148 + </menupopup> 1.149 + </menu> 1.150 + </menubar> 1.151 + </vbox> 1.152 + </hbox> 1.153 + 1.154 +</window> 1.155 +