| Index: third_party/WebKit/LayoutTests/http/tests/security/dangling-markup/src-attribute.html
|
| diff --git a/third_party/WebKit/LayoutTests/http/tests/security/dangling-markup/src-attribute.html b/third_party/WebKit/LayoutTests/http/tests/security/dangling-markup/src-attribute.html
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..7c3639e5dd143c926efd79d72f543ea06f3ecd5e
|
| --- /dev/null
|
| +++ b/third_party/WebKit/LayoutTests/http/tests/security/dangling-markup/src-attribute.html
|
| @@ -0,0 +1,76 @@
|
| +<!DOCTYPE html>
|
| +<script src="/resources/testharness.js"></script>
|
| +<script src="/resources/testharnessreport.js"></script>
|
| +<script src="./resources/helper.js"></script>
|
| +<body>
|
| +<script>
|
| + // We're injecting markup via `srcdoc` so, confusingly, we need to
|
| + // entity-escape the "raw" content, and double-escape the "escaped"
|
| + // content.
|
| + var rawBrace = "<";
|
| + var escapedBrace = "&lt;";
|
| + var rawNewline = " ";
|
| + var escapedNewline = "&#10;";
|
| +
|
| + var abeSizedPng = "";
|
| + var abeSizedPngWithNewline = abeSizedPng.replace("i", "i\n");
|
| +
|
| + var should_block = [
|
| + `<img id="dangling" src="http://127.0.0.1:8000/security/resources/abe.png?img=a${rawNewline}b${rawBrace}c">`,
|
| + `
|
| + <img id="dangling" src="http://127.0.0.1:8000/security/resources/abe.png?img=a
|
| + b${rawBrace}c
|
| + ">
|
| + `,
|
| + ];
|
| +
|
| + should_block.forEach(markup => {
|
| + async_test(t => {
|
| + var i = createFrame(`${markup}`);
|
| + assert_img_not_loaded(t, i);
|
| + }, markup.replace(/[\n\r]/g, ''));
|
| + });
|
| +
|
| + var should_load = [
|
| +
|
| + // `data:` and `javascript:` URLs don't check the content:
|
| + `<img id="dangling" src="${abeSizedPngWithNewline}">`,
|
| +
|
| + // Just one or the other isn't enough:
|
| + `<img id="dangling" src="http://127.0.0.1:8000/security/resources/abe.png?data=a${rawNewline}b">`,
|
| + `<img id="dangling" src="http://127.0.0.1:8000/security/resources/abe.png?img=a${rawBrace}b">`,
|
| +
|
| + // Entity-escaped characters don't trigger blocking:
|
| + `<img id="dangling" src="http://127.0.0.1:8000/security/resources/abe.png?data=a${escapedNewline}b">`,
|
| + `<img id="dangling" src="http://127.0.0.1:8000/security/resources/abe.png?img=a${escapedBrace}b">`,
|
| + `<img id="dangling" src="http://127.0.0.1:8000/security/resources/abe.png?img=a${escapedNewline}b${escapedBrace}c">`,
|
| +
|
| + // Leading and trailing whitespace is stripped:
|
| + `
|
| + <img id="dangling" src="
|
| + http://127.0.0.1:8000/security/resources/abe.png
|
| + ">
|
| + <input type=hidden name=csrf value=sekrit>
|
| + `,
|
| + `
|
| + <img id="dangling" src="
|
| + http://127.0.0.1:8000/security/resources/abe.png?img=${escapedBrace}
|
| + ">
|
| + <input type=hidden name=csrf value=sekrit>
|
| + `,
|
| + `
|
| + <img id="dangling" src="
|
| + http://127.0.0.1:8000/security/resources/abe.png?img=${escapedNewline}
|
| + ">
|
| + <input type=hidden name=csrf value=sekrit>
|
| + `,
|
| + ];
|
| +
|
| + should_load.forEach(markup => {
|
| + async_test(t => {
|
| + var i = createFrame(`${markup} <element attr="" another=''>`);
|
| + assert_img_loaded(t, i);
|
| + }, markup.replace(/[\n\r]/g, ''));
|
| + });
|
| +</script>
|
| +
|
|
|