mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Bug 614757 - Properly deep wrap via call/construct. r=gal
--HG-- extra : rebase_source : a46e4a24a62d3738f8161f1623bb619cc28bdb79
This commit is contained in:
parent
0d7dcbae06
commit
75e4df25b0
@ -59,6 +59,7 @@ _CHROME_FILES = \
|
|||||||
test_bug571849.xul \
|
test_bug571849.xul \
|
||||||
test_bug601803.xul \
|
test_bug601803.xul \
|
||||||
test_bug610390.xul \
|
test_bug610390.xul \
|
||||||
|
test_bug614757.xul \
|
||||||
$(NULL)
|
$(NULL)
|
||||||
|
|
||||||
# Disabled until this test gets updated to test the new proxy based
|
# Disabled until this test gets updated to test the new proxy based
|
||||||
|
36
js/src/xpconnect/tests/chrome/test_bug614757.xul
Normal file
36
js/src/xpconnect/tests/chrome/test_bug614757.xul
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
<?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=614757
|
||||||
|
-->
|
||||||
|
<window title="Mozilla Bug 601803"
|
||||||
|
xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="chrome://mochikit/content/MochiKit/packed.js"></script>
|
||||||
|
<script type="application/javascript"
|
||||||
|
src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
|
||||||
|
|
||||||
|
<!-- test results are displayed in the html:body -->
|
||||||
|
<body xmlns="http://www.w3.org/1999/xhtml">
|
||||||
|
<a href="https://bugzilla.mozilla.org/show_bug.cgi?id=614757"
|
||||||
|
target="_blank">Mozilla Bug 614757</a>
|
||||||
|
|
||||||
|
<!-- test code goes here -->
|
||||||
|
<script type="application/javascript"><![CDATA[
|
||||||
|
|
||||||
|
/** Test for Bug 614757 **/
|
||||||
|
|
||||||
|
function go() {
|
||||||
|
is($('ifr').contentDocument.wrappedJSObject.getElementsByTagName('body')[0].toString().indexOf('Xray'),
|
||||||
|
-1, "Properly deep wrap");
|
||||||
|
SimpleTest.finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
SimpleTest.waitForExplicitFinish();
|
||||||
|
|
||||||
|
]]></script>
|
||||||
|
<iframe type="content" src="http://mochi.test:8888/tests/js/src/xpconnect/tests/mochitest/file_evalInSandbox.html" onload="go()" id="ifr" />
|
||||||
|
</body>
|
||||||
|
</window>
|
@ -84,6 +84,21 @@ CrossOriginWrapper::get(JSContext *cx, JSObject *wrapper, JSObject *receiver, js
|
|||||||
WrapperFactory::WaiveXrayAndWrap(cx, js::Jsvalify(vp));
|
WrapperFactory::WaiveXrayAndWrap(cx, js::Jsvalify(vp));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
CrossOriginWrapper::call(JSContext *cx, JSObject *wrapper, uintN argc, js::Value *vp)
|
||||||
|
{
|
||||||
|
return JSCrossCompartmentWrapper::call(cx, wrapper, argc, vp) &&
|
||||||
|
WrapperFactory::WaiveXrayAndWrap(cx, js::Jsvalify(vp));
|
||||||
|
}
|
||||||
|
|
||||||
|
bool
|
||||||
|
CrossOriginWrapper::construct(JSContext *cx, JSObject *wrapper,
|
||||||
|
uintN argc, js::Value *argv, js::Value *rval)
|
||||||
|
{
|
||||||
|
return JSCrossCompartmentWrapper::construct(cx, wrapper, argc, argv, rval) &&
|
||||||
|
WrapperFactory::WaiveXrayAndWrap(cx, js::Jsvalify(rval));
|
||||||
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
CrossOriginWrapper::enter(JSContext *cx, JSObject *wrapper, jsid id, Action act)
|
CrossOriginWrapper::enter(JSContext *cx, JSObject *wrapper, jsid id, Action act)
|
||||||
{
|
{
|
||||||
|
@ -57,6 +57,10 @@ class CrossOriginWrapper : public JSCrossCompartmentWrapper {
|
|||||||
virtual bool get(JSContext *cx, JSObject *wrapper, JSObject *receiver, jsid id,
|
virtual bool get(JSContext *cx, JSObject *wrapper, JSObject *receiver, jsid id,
|
||||||
js::Value *vp);
|
js::Value *vp);
|
||||||
|
|
||||||
|
virtual bool call(JSContext *cx, JSObject *wrapper, uintN argc, js::Value *vp);
|
||||||
|
virtual bool construct(JSContext *cx, JSObject *wrapper,
|
||||||
|
uintN argc, js::Value *argv, js::Value *rval);
|
||||||
|
|
||||||
virtual bool enter(JSContext *cx, JSObject *wrapper, jsid id, Action act);
|
virtual bool enter(JSContext *cx, JSObject *wrapper, jsid id, Action act);
|
||||||
virtual void leave(JSContext *cx, JSObject *wrapper);
|
virtual void leave(JSContext *cx, JSObject *wrapper);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user