summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/upgrade-insecure-requests/generic/test-case.sub.js
blob: 6652f85d4ae328a0afe3c9ac15885d47a4d55404 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
// TODO(hiroshige): Document the type of `scenario`.
function TestCase(scenarios) {
  function runTest(scenario) {
    const urls = getRequestURLs(scenario.subresource,
                                scenario.origin,
                                scenario.redirection);
    const checkResult = _ => {
      // Send request to check if the key has been torn down.
      return xhrRequest(urls.assertUrl)
        .then(assertResult => {
            // Now check if the value has been torn down. If it's still there,
            // we have blocked the request to mixed-content.
            assert_equals(assertResult.status, scenario.expectation,
              "The resource request should be '" + scenario.expectation + "'.");
          });
    };

    /** @type {Subresource} */
    const subresource = {
      subresourceType: scenario.subresource,
      url: urls.testUrl,
      policyDeliveries: scenario.subresource_policy_deliveries,
    };

    promise_test(() => {
      return xhrRequest(urls.announceUrl)
        // Send out the real resource request.
        // This should tear down the key if it's not blocked.
        .then(_ => invokeRequest(subresource, scenario.source_context_list))
        // We check the key state, regardless of whether the main request
        // succeeded or failed.
        .then(checkResult, checkResult);
      }, scenario.test_description);
  }  // runTest

  function runTests() {
    for (const scenario of scenarios) {
      runTest(scenario);
    }
  }

  return {start: runTests};
}