chromium/third_party/blink/web_tests/http/tests/xmlhttprequest/redirect-cross-origin-tripmine.html

<!DOCTYPE HTML>
<html>
<body>
<script src="/js-test-resources/js-test.js"></script>
<script>
description("Test that a cross-origin redirect does not result in a non-simple request being sent to the target.");

window.jsTestIsAsync = true;

function setImmediate(f)
{
    var channel = new MessageChannel();
    channel.port1.onmessage = function() { channel.port1.close(); f(); };
    channel.port2.postMessage("abusingmessagechannelsforfunandprofit");
    channel.port2.close();
}

function resetTripmine()
{
    var req = new XMLHttpRequest;
    req.open("GET", "/resources/reset-temp-file.php?filename=tripmine-status", false);
    req.send();
}

function fetchTripmineStatus()
{
    var req = new XMLHttpRequest;
    req.open("GET", "/resources/tripmine.php?command=status", false);
    req.send();
    return req.responseText;
}

function checkResult()
{
    window.tripmineStatus = fetchTripmineStatus();
    shouldBeEmptyString("tripmineStatus");
}

function testAsync(method, code)
{
    debug("Asynchronous XMLHttpRequest " + code + " " + method + " redirect:");

    var req = new XMLHttpRequest;

    setImmediate(function() {
        resetTripmine();
        req.open(method, "/resources/redirect.php?code=" + code + "&url=http://localhost:8000/resources/tripmine.php", true);
        req.setRequestHeader("X-WebKit-Test", "*");
        req.setRequestHeader("Content-Type", "application/xml");
        req.send("data");
    });

    return new Promise(function(resolve, reject)
    {
        req.onloadend = function() {
            setImmediate(function() {
                checkResult();
                resolve();
            });
        };
    });
}

function testSync(method, code)
{
    debug("Synchronous XMLHttpRequest " + code + " " + method + " redirect:");
    resetTripmine();

    var req = new XMLHttpRequest;
    req.open(method, "/resources/redirect.php?code=" + code + "&url=http://localhost:8000/resources/tripmine.php", false);
    req.setRequestHeader("X-WebKit-Test", "*");
    req.setRequestHeader("Content-Type", "application/xml");
    window.testSyncReq = req;
    shouldThrow("testSyncReq.send('data')");
    checkResult();
}

var ASYNC_TEST_CASES = [
    ["POST", 307],
    ["GET", 307],
    ["POST", 303],
    ["GET", 303],
    ["POST", 302],
    ["GET", 302],
    ["DELETE", 307],
    ["POST", 301],
    ["GET", 301],
    ["DELETE", 301],
];

var SYNC_TEST_CASES = [
    ["POST", 307],
    ["GET", 307],
    ["POST", 303],
    ["GET", 303],
    ["POST", 302],
    ["GET", 302],
    ["DELETE", 307],
    ["POST", 301],
    ["GET", 301],
    ["DELETE", 301],
];

function finish()
{
    resetTripmine();

    finishJSTest();
}

var prevPromise = Promise.resolve();
for (var i = 0; i < ASYNC_TEST_CASES.length; ++i) {
    var method = ASYNC_TEST_CASES[i][0];
    var code = ASYNC_TEST_CASES[i][1];
    prevPromise = prevPromise.then(testAsync.bind(null, method, code));
}
prevPromise.then(function()
{
    setImmediate(function() {
        try {
            for (var i = 0; i < SYNC_TEST_CASES.length; ++i) {
                var method = SYNC_TEST_CASES[i][0];
                var code = SYNC_TEST_CASES[i][1];
                testSync(method, code);
            }
        } catch (e) {
            testFailed(e.toString());
        }
        finish();
    });
});
</script>