diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /testing/web-platform/tests/fenced-frame/location-ancestorOrigins.https.html | |
parent | Initial commit. (diff) | |
download | thunderbird-upstream.tar.xz thunderbird-upstream.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/fenced-frame/location-ancestorOrigins.https.html')
-rw-r--r-- | testing/web-platform/tests/fenced-frame/location-ancestorOrigins.https.html | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/testing/web-platform/tests/fenced-frame/location-ancestorOrigins.https.html b/testing/web-platform/tests/fenced-frame/location-ancestorOrigins.https.html new file mode 100644 index 0000000000..f72a668bdc --- /dev/null +++ b/testing/web-platform/tests/fenced-frame/location-ancestorOrigins.https.html @@ -0,0 +1,51 @@ +<!DOCTYPE html> +<title>Test location.ancestorOrigins</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="/common/get-host-info.sub.js"></script> +<script src="/common/utils.js"></script> +<script src="resources/utils.js"></script> + +<body> + +<script> +promise_test(async () => { + const location_ao_key = token(); + const location_ao_ack_key = token(); + + // We load the top-level fenced frame in a cross-origin, so that we can + // more-completely verify the important cross-origin + // `location.ancestorOrigins` case. + const cross_origin = get_host_info().HTTPS_REMOTE_ORIGIN; + const cross_origin_fenced_frame = getRemoteOriginURL(generateURL( + 'resources/location-ancestorOrigins-inner.https.html', + [location_ao_key, location_ao_ack_key] + ), https=true); + attachFencedFrame(cross_origin_fenced_frame); + + // Get the result for the top-level fenced frame. + const fenced_frame_result = await nextValueFromServer(location_ao_key); + assert_equals(fenced_frame_result, "", "The top-level fenced frame has the " + + "right ancestor origins"); + + // Write an ACK, so that the fenced frame knows it can send message over the + // `window_parent_key` channel again. + writeValueToServer(location_ao_ack_key, "ACK"); + + // Get the result for the iframe inside the fenced frame. + const iframe_in_fenced_frame_result = await nextValueFromServer(location_ao_key); + assert_equals(iframe_in_fenced_frame_result, cross_origin, "The iframe " + + "inside the top-level fenced frame has the right " + + "ancestor origins"); + + writeValueToServer(location_ao_ack_key, "ACK"); + + // Get the result for the nested fenced frame. + const nested_fenced_frame_result = await nextValueFromServer(location_ao_key); + assert_equals(nested_fenced_frame_result, "", "The nested fenced frame " + + "inside the top-level fenced frame has the right ancestor " + + "origins"); +}, "location.ancestorOrigins"); +</script> + +</body> |