<p>This page verifies that you can't use eval to subvert cross-domain checks.</p>
<p>If the test passes, you'll see a pass message below.</p>
<hr>
<pre id="console"></pre>
<iframe style="width:0; height: 0" src="resources/xss-eval2.html"></iframe>
<script>
if (window.testRunner) {
testRunner.dumpAsText();
testRunner.waitUntilDone();
}
function log(s)
{
document.getElementById("console").appendChild(document.createTextNode(s + "\n"));
}
function shouldBe(aDescription, a, b)
{
if (a === b) {
log("PASS: " + aDescription + " should be " + b + " and is.");
} else {
log("FAIL: " + aDescription + " should be " + b + " but instead is " + a + ".");
}
}
document.testExpando = "It's me!";
addEventListener("message", function()
{
shouldBe("eval.call(frames[0], 'document').testExpando",
(function() { try {
return eval.call(frames[0], 'document').testExpando;
} catch(e) { return e.name; } })(), "It's me!")
shouldBe("childEval.call(frames[0], 'document').testExpando",
(function() { try {
return childEval.call(frames[0], 'document').testExpando;
} catch(e) { return e.name; } })(), "TypeError");
shouldBe("childEvalCaller('document').testExpando",
(function() { try {
return childEvalCaller('document').testExpando;
} catch(e) { return e.name; } })(), "SecurityError");
shouldBe("childLocalEvalCaller('document').testExpando",
(function() { try { return childLocalEvalCaller('document').testExpando; } catch(e) { return e.name; } })(), "TypeError");
if (window.testRunner)
testRunner.notifyDone();
}, false);
</script>