зеркало из https://github.com/mozilla/gecko-dev.git
Bug 760076 - Make |construct| use Wrapper::CALL. r=mrbkap
This commit is contained in:
Родитель
6e84653730
Коммит
b62583625b
|
@ -219,7 +219,7 @@ Wrapper::construct(JSContext *cx, JSObject *wrapper, unsigned argc, Value *argv,
|
|||
{
|
||||
vp->setUndefined(); // default result if we refuse to perform this action
|
||||
const jsid id = JSID_VOID;
|
||||
GET(IndirectProxyHandler::construct(cx, wrapper, argc, argv, vp));
|
||||
CHECKED(IndirectProxyHandler::construct(cx, wrapper, argc, argv, vp), CALL);
|
||||
}
|
||||
|
||||
bool
|
||||
|
|
|
@ -48,6 +48,7 @@ _CHROME_FILES = \
|
|||
test_weakref.xul \
|
||||
test_bug726949.xul \
|
||||
test_bug758563.xul \
|
||||
test_bug760076.xul \
|
||||
$(NULL)
|
||||
|
||||
# Disabled until this test gets updated to test the new proxy based
|
||||
|
|
|
@ -0,0 +1,49 @@
|
|||
<?xml version="1.0"?>
|
||||
<?xml-stylesheet type="text/css" href="chrome://global/skin"?>
|
||||
<?xml-stylesheet type="text/css" href="chrome://mochikit/content/tests/SimpleTest/test.css"?>
|
||||
<!--
|
||||
https://bugzilla.mozilla.org/show_bug.cgi?id=760076
|
||||
-->
|
||||
<window title="Mozilla Bug 760076"
|
||||
xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
|
||||
<script type="application/javascript" src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"/>
|
||||
|
||||
<!-- 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=760076"
|
||||
target="_blank">Mozilla Bug 760076</a>
|
||||
</body>
|
||||
|
||||
<!-- test code goes here -->
|
||||
<script type="application/javascript">
|
||||
<![CDATA[
|
||||
/** Test for constructing COW-ed functions in content. **/
|
||||
|
||||
// This gets decompiled and run in the sandbox.
|
||||
function sandboxCode() {
|
||||
try {
|
||||
is(chromeFunction(), 42, "Should call successfully");
|
||||
} catch(e) { ok(false, "Shouldn't throw when calling"); }
|
||||
|
||||
try {
|
||||
ok(typeof (new chromeFunction()) !== 'undefined',
|
||||
"Should construct successfully");
|
||||
} catch(e) { ok(false, "Shouldn't throw when constructing"); }
|
||||
}
|
||||
|
||||
// Set up the sandbox.
|
||||
const Cu = Components.utils;
|
||||
var sb = new Cu.Sandbox('http://www.example.com');
|
||||
|
||||
// Import the functions it needs.
|
||||
sb.ok = ok;
|
||||
sb.is = is;
|
||||
sb.chromeFunction = function() { ok(true, "Called chrome function"); return 42; }
|
||||
Cu.evalInSandbox(sandboxCode.toSource(), sb);
|
||||
|
||||
// Do the test.
|
||||
Cu.evalInSandbox("sandboxCode();", sb);
|
||||
|
||||
]]>
|
||||
</script>
|
||||
</window>
|
Загрузка…
Ссылка в новой задаче