async-custom-formats-write-read-without-web-prefix.tentative.https.html (1611B)
1 <!doctype html> 2 <meta charset="utf-8"> 3 <title>Async Clipboard web custom format write using Blob without web prefix test.</title> 4 <link rel="help" href="https://w3c.github.io/clipboard-apis/#async-clipboard-api"> 5 <body>Body needed for test_driver.click()</body> 6 <script src="/resources/testharness.js"></script> 7 <script src="/resources/testharnessreport.js"></script> 8 <script src="/resources/testdriver.js"></script> 9 <script src="/resources/testdriver-vendor.js"></script> 10 <script src="resources/user-activation.js"></script> 11 <script> 12 'use strict'; 13 14 promise_test(async t => { 15 await tryGrantReadPermission(); 16 await tryGrantWritePermission(); 17 18 const format1 = 'web text/plain'; 19 const format2 = 'text/plain'; 20 const blobInput1 = new Blob(['input data 1'], {type: format2}); 21 const clipboardItemInput = new ClipboardItem( 22 {[format1]: blobInput1}); 23 await waitForUserActivation(); 24 await navigator.clipboard.write([clipboardItemInput]); 25 await waitForUserActivation(); 26 const clipboardItems = await navigator.clipboard.read(); 27 assert_equals(clipboardItems.length, 1); 28 const clipboardItem = clipboardItems[0]; 29 assert_true(clipboardItem instanceof ClipboardItem); 30 // This test can't verify clipboardItem.types, because its size and values 31 // are both platform-dependent. 32 33 const blobOutput1 = await clipboardItem.getType(format1); 34 assert_equals(blobOutput1.type, format1); 35 const data1 = await (new Response(blobOutput1)).text(); 36 assert_equals(data1, 'input data 1'); 37 }, 'navigator.clipboard.write() for custom format with web prefix, but Blob type without web prefix'); 38 39 </script>