| <!doctype html> |
| <title>synthetic clipboard events should not be composed</title> |
| <link rel="help" href="https://w3c.github.io/clipboard-apis/#clipboard-event-copy"> |
| <link rel="help" href="https://w3c.github.io/clipboard-apis/#clipboard-event-cut"> |
| <link rel="help" href="https://w3c.github.io/clipboard-apis/#clipboard-event-paste"> |
| <script src="/resources/testharness.js"></script> |
| <script src="/resources/testharnessreport.js"></script> |
| <div id=log></div> |
| <script> |
| const EVENTS = [ 'copy', 'cut', 'paste' ]; |
| |
| function testEvent(eventName, init, composed_flag_expectation, testName) { |
| async_test(test => { |
| document.addEventListener(eventName, test.step_func_done(e => { |
| assert_false(e.isTrusted, `synthetic ${eventName} event is untrusted`); |
| assert_equals(e.composed, composed_flag_expectation, |
| `composed flag should be ${composed_flag_expectation}`); |
| })); |
| const event = new ClipboardEvent(eventName, init); |
| document.dispatchEvent(event); |
| }, testName); |
| } |
| |
| EVENTS.forEach(name => { |
| testEvent(name, { bubbles: true, cancellable: true }, false, |
| `Unspecified synthetic ${name} event should not be composed.`); |
| testEvent(name, { bubbles: true, cancelable: true, composed: true }, true, |
| `Synthetic ${name} event can be explicitly composed.`); |
| testEvent(name, { bubbles: true, cancelable: true, composed: false }, false, |
| `Synthetic ${name} event can be explicitly uncomposed.`); |
| }); |
| </script> |