gecko-dev/testing/web-platform/tests/idle-detection/mock.js
Sam Goto b63307f448 Bug 1514466 [wpt PR 14539] - [idle] Verify that the Idle Detection API works under a variety of corner cases., a=testonly
Automatic update from web-platform-tests
[idle] Verify that the Idle Detection API works under a variety of corner cases.

Uses a MojoInterfaceInterceptor to simulate a variety of corner cases that
can happen.

Change-Id: Iccbd6a394ec8bb2ac3e56411d7ecb5f25c50b5d5
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/1371186
Commit-Queue: Sam Goto <goto@chromium.org>
Reviewed-by: Reilly Grant <reillyg@chromium.org>
Reviewed-by: Daniel Cheng <dcheng@chromium.org>
Auto-Submit: Sam Goto <goto@chromium.org>
Cr-Commit-Position: refs/heads/master@{#639310}

--

wpt-commits: 7474091614bd2f383f8daea8dcb0c557a0e8154a
wpt-pr: 14539
2019-04-01 14:43:13 +01:00

83 lines
No EOL
2.2 KiB
JavaScript

/**
* This is a testing framework that enables us to test the user idle detection
* by intercepting the connection between the renderer and the browser and
* exposing a mocking API for tests.
*
* Usage:
*
* 1) Include <script src="mock.js"></script> in your file.
* 2) Set expectations
* expect(addMonitor).andReturn((threshold, monitorPtr, callback) => {
* // mock behavior
* })
* 3) Call navigator.idle.query()
*
* The mocking API is blink agnostic and is designed such that other engines
* could implement it too. Here are the symbols that are exposed to tests:
*
* - function addMonitor(): the main/only function that can be mocked.
* - function expect(): the main/only function that enables us to mock it.
* - function close(): disconnects the interceptor.
* - enum UserIdleState {IDLE, ACTIVE}: blink agnostic constants.
* - enum ScreenIdleState {LOCKED, UNLOCKED}: blink agnostic constants.
*/
class FakeIdleMonitor {
addMonitor(threshold, monitorPtr, callback) {
return this.handler.addMonitor(threshold, monitorPtr);
}
setHandler(handler) {
this.handler = handler;
return this;
}
setBinding(binding) {
this.binding = binding;
return this;
}
close() {
this.binding.close();
}
}
const UserIdleState = {};
const ScreenIdleState = {};
function addMonitor(threshold, monitorPtr, callback) {
throw new Error("expected to be overriden by tests");
}
async function close() {
interceptor.close();
}
function expect(call) {
return {
andReturn(callback) {
let handler = {};
handler[call.name] = callback;
interceptor.setHandler(handler);
}
}
}
function intercept() {
let result = new FakeIdleMonitor();
let binding = new mojo.Binding(blink.mojom.IdleManager, result);
let interceptor = new MojoInterfaceInterceptor(blink.mojom.IdleManager.name);
interceptor.oninterfacerequest = (e) => {
binding.bind(e.handle);
}
interceptor.start();
UserIdleState.ACTIVE = blink.mojom.UserIdleState.kActive;
UserIdleState.IDLE = blink.mojom.UserIdleState.kIdle;
ScreenIdleState.LOCKED = blink.mojom.ScreenIdleState.kLocked;
ScreenIdleState.UNLOCKED = blink.mojom.ScreenIdleState.kUnlocked;
result.setBinding(binding);
return result;
}
const interceptor = intercept();