1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
"use strict";
// Test that the highlighter is correctly displayed and picker mode is not stopped after
// a shift-click (preview)
const TEST_URI = `data:text/html;charset=utf-8,
<p id="one">one</p><p id="two">two</p><p id="three">three</p>`;
add_task(function* () {
let {inspector, toolbox, testActor} = yield openInspectorForURL(TEST_URI);
let body = yield getNodeFront("body", inspector);
is(inspector.selection.nodeFront, body, "By default the body node is selected");
info("Start the element picker");
yield startPicker(toolbox);
info("Shift-clicking element #one should select it but keep the picker ON");
yield clickElement("#one", testActor, inspector, true);
yield checkElementSelected("#one", inspector);
checkPickerMode(toolbox, true);
info("Shift-clicking element #two should select it but keep the picker ON");
yield clickElement("#two", testActor, inspector, true);
yield checkElementSelected("#two", inspector);
checkPickerMode(toolbox, true);
info("Clicking element #three should select it and turn the picker OFF");
yield clickElement("#three", testActor, inspector, false);
yield checkElementSelected("#three", inspector);
checkPickerMode(toolbox, false);
});
function* clickElement(selector, testActor, inspector, isShift) {
let onSelectionChanged = inspector.once("inspector-updated");
yield testActor.synthesizeMouse({
selector: selector,
center: true,
options: { shiftKey: isShift }
});
yield onSelectionChanged;
}
function* checkElementSelected(selector, inspector) {
let el = yield getNodeFront(selector, inspector);
is(inspector.selection.nodeFront, el, `The element ${selector} is now selected`);
}
function checkPickerMode(toolbox, isOn) {
let pickerButton = toolbox.doc.querySelector("#command-button-pick");
is(pickerButton.hasAttribute("checked"), isOn, "The picker mode is correct");
}
|