diff options
Diffstat (limited to 'testing/web-platform/tests/fenced-frame/fence-report-event-cross-origin-no-embedder-opt-in.https.html')
-rw-r--r-- | testing/web-platform/tests/fenced-frame/fence-report-event-cross-origin-no-embedder-opt-in.https.html | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/testing/web-platform/tests/fenced-frame/fence-report-event-cross-origin-no-embedder-opt-in.https.html b/testing/web-platform/tests/fenced-frame/fence-report-event-cross-origin-no-embedder-opt-in.https.html new file mode 100644 index 0000000000..d8fa5133cd --- /dev/null +++ b/testing/web-platform/tests/fenced-frame/fence-report-event-cross-origin-no-embedder-opt-in.https.html @@ -0,0 +1,50 @@ +<!DOCTYPE html> +<title>Test window.fence.reportEvent from cross-origin subframes.</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="/common/utils.js"></script> +<script src="/common/dispatcher/dispatcher.js"></script> +<script src="/common/get-host-info.sub.js"></script> +<script src="resources/automatic-beacon-helper.js"></script> +<script src="resources/utils.js"></script> + +<body> +<script> +promise_test(async(t) => { + const fencedframe = await attachFencedFrameContext({ + generator_api: 'fledge', + headers: [[ + 'Allow-Cross-Origin-Event-Reporting', 'false' + ]], + register_beacon: true + }); + // Perform a cross-origin navigation. Since the navigation is + // content-initiated, the fenced frame reporting metadata will persist. + await navigateFrameContext(fencedframe, { + origin: get_host_info().HTTPS_REMOTE_ORIGIN, + }); + await fencedframe.execute(() => { + // This page will call reportEvent() twice. Once for a destination enum + // event (i.e. an event with an eventType/eventData specified), and once for + // a destination URL event (i.e. an event with a destinationURL specified). + const destination_enum_event = { + eventType: "click", + eventData: "enum", + destination: ["buyer"], + crossOriginExposed: true + } + window.fence.reportEvent(destination_enum_event); + + const destination_url = new URL(BEACON_URL + "?type=url", + get_host_info().HTTPS_ORIGIN); + const destination_url_event = { + destinationURL: destination_url, + crossOriginExposed: true + } + window.fence.reportEvent(destination_url_event); + }); + await verifyBeaconData("click", "enum", false, t); + await verifyBeaconData("url", "<No data>", false, t); +}, 'Cross-origin window.fence.reportEvent without embedder opt-in'); +</script> +</body> |