Skip to content

Commit

Permalink
Bug 1845211 [wpt PR 41167] - Fenced frames: Add reporting to custom d…
Browse files Browse the repository at this point in the history
…estination urls [1/N], a=testonly

Automatic update from web-platform-tests
Fenced frames: Add reporting to custom destination urls [1/N]

This CL adds the API surface for custom destination urls in reportEvent.

Later CLs will send this information to the browser and send reporting
beacons based on it.

WICG/turtledove#477

Change-Id: If901ceb39f759a2911e1781d91caf133874ac389
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4711374
Reviewed-by: Dominic Farolino <[email protected]>
Reviewed-by: Shivani Sharma <[email protected]>
Commit-Queue: Garrett Tanzer <[email protected]>
Cr-Commit-Position: refs/heads/main@{#1175044}

--

wpt-commits: 18f69d13d720ecd631631b4e9aee95bd27fc84e4
wpt-pr: 41167
  • Loading branch information
Garrett Tanzer authored and moz-wptsync-bot committed Aug 2, 2023
1 parent 3a20184 commit 0a4dd7c
Showing 1 changed file with 42 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
<!DOCTYPE html>
<title>Test window.fence.reportEvent destination URL.</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="resources/utils.js"></script>

<body>
<script>
promise_test(async(t) => {
const fencedframe = await attachFencedFrameContext({generator_api: 'fledge'});
await fencedframe.execute(() => {
// The destinationURL must be a valid URL.
let event = {destinationURL: "foobarbaz"};
assert_throws_js(TypeError, () => {window.fence.reportEvent(event);});

// The destinationURL must be an https URL.
event.destinationURL = "http://3pat.com";
assert_throws_js(TypeError, () => {window.fence.reportEvent(event);});

event.destinationURL = "https://3pat.com";
window.fence.reportEvent(event);

// `eventType` isn't allowed.
event.eventType = 'click';
assert_throws_js(TypeError, () => {window.fence.reportEvent(event);});
event.eventType = undefined;

// `eventData` isn't allowed.
event.eventData = 'payload';
assert_throws_js(TypeError, () => {window.fence.reportEvent(event);});
event.eventData = undefined;

// `destination` isn't allowed.
event.destination = ['buyer'];
assert_throws_js(TypeError, () => {window.fence.reportEvent(event);});
event.destination = undefined;
});
}, 'window.fence.reportEvent destinationURL');
</script>
</body>

0 comments on commit 0a4dd7c

Please sign in to comment.