<?xml version="1.0"?> <html xmlns="http://www.w3.org/1999/xhtml"> <!-- https://bugzilla.mozilla.org/show_bug.cgi?id=790265 --> <head> <title>Test for Bug 790265</title> <script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" /> <bindings xmlns="http://www.mozilla.org/xbl"> <binding id="binding"> <implementation> <method name="foo" exposeToUntrustedContent="true"> <body><![CDATA[ return this; ]]></body> </method> </implementation> </binding> </bindings> <style> #toBind { display: none; } #toBind.bound { -moz-binding: url(#binding); } </style> </head> <body> <a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=790265">Mozilla Bug 790265</a> <p id="display"></p> <div id="content"> <div id="toBind">Bound element</div> </div> <pre id="test"> <script class="testbody" type="text/javascript"> <![CDATA[ SimpleTest.waitForExplicitFinish(); // Flush out style on $("toBind") $("toBind").offsetWidth; ok(!("foo" in $("toBind")), "Should not have binding applied"); is(getComputedStyle($("toBind")).MozBinding, "none", "Computed binding should be none"); $("toBind").className = "bound"; // Flush the style change, so we kick off the binding load before onload // fires and thus block onload. $("toBind").offsetWidth; addLoadEvent(function() { ok("foo" in $("toBind"), "Should have binding applied"); is($("toBind").foo(), $("toBind"), "Should have correct return value"); SimpleTest.finish(); }); ]]> </script> </pre> </body> </html>