|
1 <?xml version="1.0"?> |
|
2 <?xml-stylesheet href="/tests/SimpleTest/test.css" type="text/css"?> |
|
3 <html xmlns="http://www.w3.org/1999/xhtml" title="Test Plugin Positioning"> |
|
4 <head> |
|
5 <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> |
|
6 </head> |
|
7 <body> |
|
8 |
|
9 <!-- Use a XUL element here so we can get its boxObject.screenX/Y --> |
|
10 <hbox style="height:10px; position:absolute; left:0; top:0; z-index:-100;" id="h1" |
|
11 xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"> |
|
12 <hbox style="width:100px;"></hbox><hbox id="h2"/> |
|
13 </hbox> |
|
14 |
|
15 <embed id="p" type="application/x-test" width="200" height="200" wmode="window"></embed> |
|
16 <embed id="p2" type="application/x-test" wmode="window" |
|
17 style="outline:5px solid blue; width:200px; height:200px; |
|
18 border:solid black; border-width:4px 8px 4px 8px; |
|
19 padding:3px 1px;"> |
|
20 </embed> |
|
21 |
|
22 <script class="testbody" type="application/javascript"> |
|
23 <![CDATA[ |
|
24 |
|
25 var windowFrameX, windowFrameY; |
|
26 |
|
27 function checkGeometry(id, x, y, w, h) { |
|
28 var p = document.getElementById(id); |
|
29 var bounds = p.getBoundingClientRect(); |
|
30 var pX = p.getEdge(0); |
|
31 var pY = p.getEdge(1); |
|
32 var pWidth = p.getEdge(2) - pX; |
|
33 var pHeight = p.getEdge(3) - pY; |
|
34 |
|
35 is(pX, windowFrameX + bounds.left + x, id + " plugin X"); |
|
36 is(pY, windowFrameY + bounds.top + y, id + " plugin Y"); |
|
37 is(pWidth, w, id + " plugin width"); |
|
38 is(pHeight, h, id + " plugin height"); |
|
39 } |
|
40 |
|
41 function runTests() { |
|
42 var h1 = document.getElementById("h1"); |
|
43 var h2 = document.getElementById("h2"); |
|
44 var hwidth = h2.boxObject.screenX - h1.boxObject.screenX; |
|
45 if (hwidth != 100) { |
|
46 // Maybe it's a DPI issue |
|
47 todo(false, "Unexpected DPI?"); |
|
48 SimpleTest.finish(); |
|
49 return; |
|
50 } |
|
51 |
|
52 if (!document.getElementById("p").identifierToStringTest) { |
|
53 todo(false, "Test plugin not available"); |
|
54 SimpleTest.finish(); |
|
55 return; |
|
56 } |
|
57 |
|
58 var bounds = h1.getBoundingClientRect(); |
|
59 windowFrameX = h1.boxObject.screenX - bounds.left - window.screenX; |
|
60 windowFrameY = h1.boxObject.screenY - bounds.top - window.screenY; |
|
61 |
|
62 checkGeometry("p", 0, 0, 200, 200); |
|
63 // This one tests widget positioning in the presence of borders and padding |
|
64 checkGeometry("p2", 9, 7, 182, 186); |
|
65 |
|
66 SimpleTest.finish(); |
|
67 } |
|
68 |
|
69 // When load events run, painting may still be suppressed for the window. |
|
70 // While painting is suppressed, plugins are hidden so won't be positioned |
|
71 // or sized as expected. |
|
72 // So call runTests after the load event has finished, when painting will |
|
73 // be unsuppressed. |
|
74 addLoadEvent(function() { setTimeout(runTests, 1000); }); |
|
75 SimpleTest.waitForExplicitFinish(); |
|
76 |
|
77 ]]> |
|
78 </script> |
|
79 |
|
80 </body> |
|
81 </html> |