chromium/third_party/blink/web_tests/external/wpt/html/semantics/embedded-content/the-iframe-element/iframe-loading-lazy-referrerpolicy-change.sub.html

<!DOCTYPE html>
<head>
  <title>Deferred loading=lazy iframes are fetched with the parse-time
         `referrerpolicy` attribute</title>
  <link rel="author" title="Dom Farolino" href="mailto:[email protected]">
  <link rel="author" title="Raj T" href="mailto:[email protected]">
  <link rel="help" href="https://github.com/scott-little/lazyload">
  <script src="/resources/testharness.js"></script>
  <script src="/resources/testharnessreport.js"></script>
  <script src="../resources/common.js"></script>
</head>

<script>
  const below_viewport_iframe = new ElementLoadPromise("below_viewport_iframe");

  async_test(function(t) {
    // Change the referrer-policy and scroll down to load the deferred elements.
    window.addEventListener("load", t.step_func(() => {
      below_viewport_iframe.element().referrerPolicy = "no-referrer";
      below_viewport_iframe.element().scrollIntoView();
    }));

    below_viewport_iframe.promise.then(
      t.step_func_done(function() {
        // The `Referer` header should be the full URL, as specified by the
        // iframe's `referrerpolicy` attribute at parse-time, and not the origin
        // (as specified in meta referrer tag) or null (as overridden
        // referrerpolicy=no-referrer after load deferral).
        assert_true(below_viewport_iframe.element().contentDocument.body.innerHTML
                    .includes("Referer: http://{{location[host]}}{{location[path]}}"),
                    "The iframe's `Referer` should be the referrer's full URL");
      }));
  }, "Test that when a deferred iframe is fetched, it uses the " +
     "`referrerpolicy` specified at parse-time");
</script>

<body>
  <meta name="referrer" content="origin">
  <div style="height:1000vh;"></div>
  <iframe id="below_viewport_iframe" src="/xhr/resources/echo-headers.py"
          loading="lazy" width="200px" height="100px"
          referrerpolicy="unsafe-url"
          onload="below_viewport_iframe.resolve();">
  </iframe>
</body>