Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(93)

Unified Diff: third_party/WebKit/LayoutTests/usb/usbDevice-iframe.html

Issue 2789723003: Migrate WebUSB LayoutTests into external/wpt (Closed)
Patch Set: Addressed comments from ortuno@ and foolip@ Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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>

Powered by Google App Engine
This is Rietveld 408576698