| <!DOCTYPE html> |
| <title>Test that window.fence.reportEvent() succeeds in a fenced frame.</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', |
| register_beacon: true}); |
| |
| // This page will call reportEvent twice: Once for an enum event, and once |
| // for a custom URL event. Both beacons are expected to send successfully. |
| await fencedframe.execute(() => { |
| const destination_enum_event = { |
| eventType: 'click', |
| eventData: 'enum', |
| destination: ['buyer'] |
| } |
| 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 |
| } |
| window.fence.reportEvent(destination_url_event); |
| }); |
| |
| const [enum_origin, enum_referrer] = await nextBeacon("click", "enum") |
| .then(data => data.split(',')); |
| const [url_origin, url_referrer] = await nextBeacon("url", "<No data>") |
| .then(data => data.split(',')); |
| |
| assert_equals(enum_origin, location.origin, |
| 'The enum origin should be correctly set.'); |
| // GET requests do not set an 'Origin' header if same-origin to the request's |
| // destination. |
| assert_equals(url_origin, '<No data>', |
| 'The url origin should be correctly set.'); |
| |
| assert_equals(enum_referrer, location.origin + "/", |
| 'The enum referrer should be correctly set.'); |
| assert_equals(url_referrer, location.origin + "/", |
| 'The url referrer should be correctly set.'); |
| }, 'Test that window.fence.reportEvent() succeeds in a fenced frame.'); |
| </script> |
| </body> |