Commit 0ec4bcfe authored by arthursonzogni's avatar arthursonzogni Committed by Chromium LUCI CQ

WPT test: open error page while sandboxed.

Check what happens when opening an about:srcdoc window from a sandboxed
about:srcdoc iframe.

This patch was intended to be one of the regression tests for
https://crbug.com/1158306. At the end, I realized it isn't. It is still
worth adding it.
The real test where Chrome fails will be added in:
https://chromium-review.googlesource.com/c/chromium/src/+/2587047

Bug: 1158306
Change-Id: I2f6f7468564c66c17b679c4007cc6b4e26cb980c
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/2584812
Commit-Queue: Arthur Sonzogni <arthursonzogni@chromium.org>
Reviewed-by: default avatarAntonio Sartori <antoniosartori@chromium.org>
Cr-Commit-Position: refs/heads/master@{#837089}
parent cd6925c9
<!DOCTYPE html>
<meta charset=utf-8>
<title>window.open("about:srcdoc") from a sandboxed iframe</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<body>
<script>
// Check what happens when executing window.open("about:srcdoc") from a
// sandboxed iframe. Srcdoc can't be loaded in the main frame. It should
// result in an error page. The error page should be cross-origin with the
// opener.
//
// This test covers an interesting edge case. A main frame should inherit
// sandbox flags. However the document loaded is an internal error page. This
// might trigger some assertions, especially if the implementation wrongly
// applies the sandbox flags of the opener to the internal error page document.
//
// This test is mainly a coverage test. It passes if it doesn't crash.
async_test(test => {
let iframe = document.createElement("iframe");
iframe.sandbox = "allow-scripts allow-popups allow-same-origin";
iframe.srcdoc = `
<script>
let w = window.open();
onunload = () => w.close();
let notify = () => {
try {
w.origin; // Will fail after navigating to about:srcdoc.
parent.postMessage("pending", "*");
} catch (e) {
parent.postMessage("done", "*");
};
};
addEventListener("message", notify);
notify();
w.location = "about:srcdoc"; // Error page.
</scr`+`ipt>
`;
let closed = false;
addEventListener("message", event => {
closed = (event.data === "done");
iframe.contentWindow.postMessage("ping","*");
});
document.body.appendChild(iframe);
test.step_wait_func_done(()=>closed);
}, "window.open('about:srcdoc') from sandboxed srcdoc doesn't crash.");
</script>
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment