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

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

Issue 2791573002: Revert of Refactor WebUSB LayoutTests to separate out the Mojo service mocks (Closed)
Patch Set: Created 3 years, 9 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
« no previous file with comments | « third_party/WebKit/LayoutTests/usb/usbDevice.html ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 b63743da10699cf677932f9f6b718a476223db38..37e109af210148c9c27ed555cf0fdb9a62a5f1b7 100644
--- a/third_party/WebKit/LayoutTests/usb/usbDevice-iframe.html
+++ b/third_party/WebKit/LayoutTests/usb/usbDevice-iframe.html
@@ -1,88 +1,95 @@
<!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="resources/webusb-test.js"></script>
<script>
'use strict';
-function runIframeDisconnectTest(onDeviceConnected) {
- return navigator.usb.test.initialize().then(() => {
- return new Promise((resolve, reject) => {
- let opened = false;
- let fakeDeviceGuid = null;
+function runIframeDisconnectTest(usb, onDeviceConnected) {
+ return new Promise((resolve, reject) => {
+ let mockDeviceManager = new usb.MockDeviceManager;
+ let opened = false;
+ let iframe = document.createElement('iframe');
- let iframe = document.createElement('iframe');
- iframe.src = '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') {
+ mockDeviceManager.addMockDevice(usb.fakeDevices[0]);
+ } else if (messageEvent.data === 'Success') {
+ opened = true;
+ onDeviceConnected(iframe);
+ } else {
+ reject(messageEvent.data);
+ }
+ };
- window.onmessage = messageEvent => {
- if (messageEvent.data == 'Ready') {
- fakeDeviceGuid = navigator.usb.test.addFakeDevice(fakeDeviceInit);
- } 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();
+ });
- navigator.usb.test.ondeviceclose = guid => {
- assert_equals(guid, fakeDeviceGuid);
- assert_true(opened);
- resolve();
- };
-
- document.body.appendChild(iframe);
- });
+ 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);
});
}
-promise_test(() => {
- return runIframeDisconnectTest(iframe => {
+usb_test(usb => {
+ return runIframeDisconnectTest(usb, iframe => {
document.body.removeChild(iframe);
});
}, 'detaching iframe disconnects device.');
-promise_test(() => {
- return runIframeDisconnectTest(iframe => {
+usb_test(usb => {
+ return runIframeDisconnectTest(usb, iframe => {
iframe.src = 'about:blank';
});
}, 'navigating iframe disconnects device.');
-promise_test(() => {
- return navigator.usb.test.initialize().then(() => {
- return new Promise((resolve, reject) => {
- let opened = false;
- let fakeDeviceGuid = null;
+usb_test(usb => {
+ return new Promise((resolve, reject) => {
+ let mockDeviceManager = new usb.MockDeviceManager;
+ let iframe = document.createElement('iframe');
- let iframe = document.createElement('iframe');
- iframe.src = '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]);
+ resolve();
});
- };
+ } else {
+ reject(messageEvent.data);
+ }
+ };
- window.onmessage = messageEvent => {
- if (messageEvent.data == 'Ready') {
- document.body.removeChild(iframe);
- runGarbageCollection().then(() => {
- navigator.usb.test.addFakeDevice(fakeDeviceInit);
- resolve();
- });
- } else {
- reject(messageEvent.data);
- }
- };
-
- document.body.appendChild(iframe);
- });
+ 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);
});
}, 'events are not delivered to detached frames');
</script>
« no previous file with comments | « third_party/WebKit/LayoutTests/usb/usbDevice.html ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698