chromium/third_party/blink/web_tests/http/tests/security/img-crossorigin-cookies.https.html

<!DOCTYPE html>
<title>Check request cookies for image resources with crossOrigin.</title>
<script src="../resources/testharness.js"></script>
<script src="../resources/testharnessreport.js"></script>
<script src="../resources/get-host-info.js?pipe=sub"></script>
<script>
if (window.testRunner)
  testRunner.setBlockThirdPartyCookies(false);


function load_image(url, cross_origin) {
  return new Promise(function(resolve, reject) {
      var img = document.createElement('img');
      document.body.appendChild(img);
      img.onload = resolve;
      img.onerror = reject;
      if (cross_origin != '') {
        img.crossOrigin = cross_origin;
      }
      img.src = url;
    });
}

function assert_resolves(promise, description) {
  return promise.catch(function(reason) {
      throw description + ' - ' + reason;
  });
}

promise_test(function(t) {
    document.cookie = "TestCookie=same";
    var host_info = get_host_info();
    // HTTPS must be used because SameSite=None cookies must be Secure.
    var RESOURCES_PATH = host_info['HTTPS_ORIGIN'] + '/security/resources/';
    var REMOTE_RESOURCES_PATH = host_info['HTTPS_REMOTE_ORIGIN'] +
                                '/security/resources/';

    return fetch(new Request(REMOTE_RESOURCES_PATH + 'set-cookie.php?' +
                             'name=TestCookie&value=cross&SameSiteNone',
                             {mode: 'no-cors', credentials: 'include'}))
      .then(function() {
          return Promise.all([
            assert_resolves(
                load_image(
                    RESOURCES_PATH + 'abe-cookie-check.php?Cookie=same', ''),
                'Same-origin request for a resource whose CORS setting is ' +
                'NoCORS must contain cookies.'),
            assert_resolves(
                load_image(
                    RESOURCES_PATH + 'abe-cookie-check.php?Cookie=same',
                    'anonymous'),
                'Same-origin request for a resource whose CORS setting is ' +
                'Anonymous must contain cookies.'),
            assert_resolves(
                load_image(
                    RESOURCES_PATH + 'abe-cookie-check.php?Cookie=same',
                    'use-credentials'),
                'Same-origin request for a resource whose CORS setting is ' +
                'UseCredentials must contain cookies.'),
            assert_resolves(
                load_image(
                    REMOTE_RESOURCES_PATH + 'abe-cookie-check.php?Cookie=cross',
                    ''),
                'Cross-origin request for a resource whose CORS setting is ' +
                'NoCORS must contain cookies.'),
            assert_resolves(
                load_image(
                    REMOTE_RESOURCES_PATH + 'abe-allow-star.php?Cookie=NotSet',
                    'anonymous'),
                'Cross-origin request for a resource whose CORS setting is ' +
                'Anonymous must not contain cookies.'),
            assert_resolves(
                load_image(
                    REMOTE_RESOURCES_PATH + 'abe-allow-credentials.php?' +
                    'Cookie=cross&Secure',
                    'use-credentials'),
                'Cross-origin request for a resource whose CORS setting is ' +
                'UseCredentials must contain cookies.'),
              ]);}
        );
  }, 'Check request cookies for image resources with crossOrigin.');
</script>