chromium/third_party/blink/web_tests/external/wpt/content-security-policy/connect-src/connect-src-syncxmlhttprequest-redirect-to-blocked.sub.html

<!DOCTYPE html>
<html>

<head>
    <!-- Programmatically converted from a WebKit Reftest, please forgive resulting idiosyncracies.-->
    <meta http-equiv="Content-Security-Policy" content="connect-src 'self'; script-src 'self' 'unsafe-inline';">
    <title>connect-src-syncxmlhttprequest-redirect-to-blocked</title>
    <script src="/resources/testharness.js"></script>
    <script src="/resources/testharnessreport.js"></script>
    <script src='../support/logTest.sub.js?logs=["PASS Sync XMLHttpRequest.send() did not follow the disallowed redirect.","TEST COMPLETE","violated-directive=connect-src"]'></script>
    <script src="../support/alertAssert.sub.js?alerts=[]"></script>
    <script id="inject_here"></script>
</head>

<body>
    <script>
        window.addEventListener('securitypolicyviolation', function(e) {
            log("violated-directive=" + e.violatedDirective);
        });

        var xhr = new XMLHttpRequest;
        try {
            xhr.open("GET", "/common/redirect.py?location=http://www1.{{host}}:{{ports[http][0]}}/content-security-policy/support/fail.asis", false);
        } catch (e) {
            log("FAIL " + "Sync XMLHttpRequest.open() should not throw an exception.");
        }
        xhr.onload = function() {
            log("FAIL " + "Sync XMLHttpRequest.send() should fail to follow the disallowed redirect.");
            log("TEST COMPLETE");
        };
        try {
            xhr.send();
        } catch (e) {
            log("PASS " + "Sync XMLHttpRequest.send() did not follow the disallowed redirect.");
            log("TEST COMPLETE");
        }

    </script>
    <div id="log"></div>
</body>

</html>