| Index: third_party/WebKit/LayoutTests/usb/usbDevice-iframe.html
|
| diff --git a/third_party/WebKit/LayoutTests/usb/usbDevice-iframe.html b/third_party/WebKit/LayoutTests/usb/usbDevice-iframe.html
|
| index 37e109af210148c9c27ed555cf0fdb9a62a5f1b7..fccd71f3169ace9a67310313d362e72f4dcca4e6 100644
|
| --- a/third_party/WebKit/LayoutTests/usb/usbDevice-iframe.html
|
| +++ b/third_party/WebKit/LayoutTests/usb/usbDevice-iframe.html
|
| @@ -1,95 +1,38 @@
|
| <!DOCTYPE html>
|
| <script src="../resources/testharness.js"></script>
|
| <script src="../resources/testharnessreport.js"></script>
|
| -<script src="../resources/mojo-helpers.js"></script>
|
| -<script src="resources/fake-devices.js"></script>
|
| -<script src="resources/usb-helpers.js"></script>
|
| +<script src="../external/wpt/webusb/resources/fake-devices.js"></script>
|
| +<script src="../external/wpt_polyfill/webusb/webusb-test.js"></script>
|
| <script>
|
| 'use strict';
|
|
|
| -function runIframeDisconnectTest(usb, onDeviceConnected) {
|
| - return new Promise((resolve, reject) => {
|
| - let mockDeviceManager = new usb.MockDeviceManager;
|
| - let opened = false;
|
| - let iframe = document.createElement('iframe');
|
| -
|
| - window.onmessage = messageEvent => {
|
| - if (messageEvent.data === 'Ready') {
|
| - mockDeviceManager.addMockDevice(usb.fakeDevices[0]);
|
| - } else if (messageEvent.data === 'Success') {
|
| - opened = true;
|
| - onDeviceConnected(iframe);
|
| - } else {
|
| - reject(messageEvent.data);
|
| - }
|
| - };
|
| -
|
| - mockDeviceManager.setDeviceCloseHandler(info => {
|
| - assert_equals(info, usb.fakeDevices[0]);
|
| - assert_true(opened);
|
| - resolve();
|
| - });
|
| -
|
| - iframe.src = 'resources/open-in-iframe.html';
|
| - iframe.onload = () => {
|
| - iframe.contentWindow.gin.define(
|
| - "Mojo Service Registry",
|
| - [ 'content/public/renderer/frame_interfaces' ],
|
| - (frameInterfaces) => {
|
| - frameInterfaces.addInterfaceOverrideForTesting(
|
| - usb.DeviceManager.name,
|
| - handle => { mockDeviceManager.bindingSet.addBinding(
|
| - mockDeviceManager, handle); });
|
| - iframe.contentWindow.postMessage('Ready', '*');
|
| - });
|
| - }
|
| - document.body.appendChild(iframe);
|
| - });
|
| -}
|
| -
|
| -usb_test(usb => {
|
| - return runIframeDisconnectTest(usb, iframe => {
|
| - document.body.removeChild(iframe);
|
| - });
|
| -}, 'detaching iframe disconnects device.');
|
| -
|
| -usb_test(usb => {
|
| - return runIframeDisconnectTest(usb, iframe => {
|
| - iframe.src = 'about:blank';
|
| - });
|
| -}, 'navigating iframe disconnects device.');
|
| -
|
| -usb_test(usb => {
|
| - return new Promise((resolve, reject) => {
|
| - let mockDeviceManager = new usb.MockDeviceManager;
|
| - let iframe = document.createElement('iframe');
|
| +promise_test(() => {
|
| + return navigator.usb.test.initialize().then(() => {
|
| + return new Promise((resolve, reject) => {
|
| + let opened = false;
|
| + let fakeDeviceGuid = null;
|
| +
|
| + let iframe = document.createElement('iframe');
|
| + iframe.src = '../external/wpt/webusb/resources/open-in-iframe.html';
|
| + iframe.onload = () => {
|
| + navigator.usb.test.attachToWindow(iframe.contentWindow).then(() => {
|
| + iframe.contentWindow.postMessage('Ready', '*');
|
| + });
|
| + };
|
|
|
| - window.onmessage = messageEvent => {
|
| - if (messageEvent.data === 'Ready') {
|
| - document.body.removeChild(iframe);
|
| - runGarbageCollection().then(() => {
|
| - mockDeviceManager.addMockDevice(usb.fakeDevices[0]);
|
| + window.onmessage = messageEvent => {
|
| + if (messageEvent.data == 'Ready') {
|
| + document.body.removeChild(iframe);
|
| + GCController.collect();
|
| + navigator.usb.test.addFakeDevice(fakeDeviceInit);
|
| resolve();
|
| - });
|
| - } else {
|
| - reject(messageEvent.data);
|
| - }
|
| - };
|
| + } else {
|
| + reject(messageEvent.data);
|
| + }
|
| + };
|
|
|
| - iframe.src = 'resources/open-in-iframe.html';
|
| - iframe.onload = () => {
|
| - iframe.contentWindow.gin.define(
|
| - "Mojo Service Registry",
|
| - [ 'content/public/renderer/frame_interfaces' ],
|
| - (frameInterfaces) => {
|
| - frameInterfaces.addInterfaceOverrideForTesting(
|
| - usb.DeviceManager.name,
|
| - handle => { mockDeviceManager.bindingSet.addBinding(
|
| - mockDeviceManager, handle); });
|
| - iframe.contentWindow.postMessage('Ready', '*');
|
| - });
|
| - }
|
| - document.body.appendChild(iframe);
|
| + document.body.appendChild(iframe);
|
| + });
|
| });
|
| }, 'events are not delivered to detached frames');
|
| </script>
|
|
|