summaryrefslogtreecommitdiffstats
path: root/devtools/client/inspector/components/test/browser_boxmodel_editablemodel.js
blob: 5c32c2029597991362ff490f5cac2909171067ff (plain)
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
/* vim: set ts=2 et sw=2 tw=80: */
/* Any copyright is dedicated to the Public Domain.
 http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

// Test that editing the box-model values works as expected and test various
// key bindings

const TEST_URI = "<style>" +
  "div { margin: 10px; padding: 3px }" +
  "#div1 { margin-top: 5px }" +
  "#div2 { border-bottom: 1em solid black; }" +
  "#div3 { padding: 2em; }" +
  "#div4 { margin: 1px; }" +
  "</style>" +
  "<div id='div1'></div><div id='div2'></div>" +
  "<div id='div3'></div><div id='div4'></div>";

add_task(function* () {
  yield addTab("data:text/html," + encodeURIComponent(TEST_URI));
  let {inspector, view, testActor} = yield openBoxModelView();

  yield testEditingMargins(inspector, view, testActor);
  yield testKeyBindings(inspector, view, testActor);
  yield testEscapeToUndo(inspector, view, testActor);
  yield testDeletingValue(inspector, view, testActor);
  yield testRefocusingOnClick(inspector, view, testActor);
});

function* testEditingMargins(inspector, view, testActor) {
  info("Test that editing margin dynamically updates the document, pressing " +
       "escape cancels the changes");

  is((yield getStyle(testActor, "#div1", "margin-top")), "",
     "Should be no margin-top on the element.");
  yield selectNode("#div1", inspector);

  let span = view.doc.querySelector(".boxmodel-margin.boxmodel-top > span");
  is(span.textContent, 5, "Should have the right value in the box model.");

  EventUtils.synthesizeMouseAtCenter(span, {}, view.doc.defaultView);
  let editor = view.doc.querySelector(".styleinspector-propertyeditor");
  ok(editor, "Should have opened the editor.");
  is(editor.value, "5px", "Should have the right value in the editor.");

  EventUtils.synthesizeKey("3", {}, view.doc.defaultView);
  yield waitForUpdate(inspector);

  is((yield getStyle(testActor, "#div1", "margin-top")), "3px",
     "Should have updated the margin.");

  EventUtils.synthesizeKey("VK_ESCAPE", {}, view.doc.defaultView);
  yield waitForUpdate(inspector);

  is((yield getStyle(testActor, "#div1", "margin-top")), "",
     "Should be no margin-top on the element.");
  is(span.textContent, 5, "Should have the right value in the box model.");
}

function* testKeyBindings(inspector, view, testActor) {
  info("Test that arrow keys work correctly and pressing enter commits the " +
       "changes");

  is((yield getStyle(testActor, "#div1", "margin-left")), "",
     "Should be no margin-top on the element.");
  yield selectNode("#div1", inspector);

  let span = view.doc.querySelector(".boxmodel-margin.boxmodel-left > span");
  is(span.textContent, 10, "Should have the right value in the box model.");

  EventUtils.synthesizeMouseAtCenter(span, {}, view.doc.defaultView);
  let editor = view.doc.querySelector(".styleinspector-propertyeditor");
  ok(editor, "Should have opened the editor.");
  is(editor.value, "10px", "Should have the right value in the editor.");

  EventUtils.synthesizeKey("VK_UP", {}, view.doc.defaultView);
  yield waitForUpdate(inspector);

  is(editor.value, "11px", "Should have the right value in the editor.");
  is((yield getStyle(testActor, "#div1", "margin-left")), "11px",
     "Should have updated the margin.");

  EventUtils.synthesizeKey("VK_DOWN", {}, view.doc.defaultView);
  yield waitForUpdate(inspector);

  is(editor.value, "10px", "Should have the right value in the editor.");
  is((yield getStyle(testActor, "#div1", "margin-left")), "10px",
     "Should have updated the margin.");

  EventUtils.synthesizeKey("VK_UP", { shiftKey: true }, view.doc.defaultView);
  yield waitForUpdate(inspector);

  is(editor.value, "20px", "Should have the right value in the editor.");
  is((yield getStyle(testActor, "#div1", "margin-left")), "20px",
     "Should have updated the margin.");
  EventUtils.synthesizeKey("VK_RETURN", {}, view.doc.defaultView);

  is((yield getStyle(testActor, "#div1", "margin-left")), "20px",
     "Should be the right margin-top on the element.");
  is(span.textContent, 20, "Should have the right value in the box model.");
}

function* testEscapeToUndo(inspector, view, testActor) {
  info("Test that deleting the value removes the property but escape undoes " +
       "that");

  is((yield getStyle(testActor, "#div1", "margin-left")), "20px",
     "Should be the right margin-top on the element.");
  yield selectNode("#div1", inspector);

  let span = view.doc.querySelector(".boxmodel-margin.boxmodel-left > span");
  is(span.textContent, 20, "Should have the right value in the box model.");

  EventUtils.synthesizeMouseAtCenter(span, {}, view.doc.defaultView);
  let editor = view.doc.querySelector(".styleinspector-propertyeditor");
  ok(editor, "Should have opened the editor.");
  is(editor.value, "20px", "Should have the right value in the editor.");

  EventUtils.synthesizeKey("VK_DELETE", {}, view.doc.defaultView);
  yield waitForUpdate(inspector);

  is(editor.value, "", "Should have the right value in the editor.");
  is((yield getStyle(testActor, "#div1", "margin-left")), "",
     "Should have updated the margin.");

  EventUtils.synthesizeKey("VK_ESCAPE", {}, view.doc.defaultView);
  yield waitForUpdate(inspector);

  is((yield getStyle(testActor, "#div1", "margin-left")), "20px",
     "Should be the right margin-top on the element.");
  is(span.textContent, 20, "Should have the right value in the box model.");
}

function* testDeletingValue(inspector, view, testActor) {
  info("Test that deleting the value removes the property");

  yield setStyle(testActor, "#div1", "marginRight", "15px");
  yield waitForUpdate(inspector);

  yield selectNode("#div1", inspector);

  let span = view.doc.querySelector(".boxmodel-margin.boxmodel-right > span");
  is(span.textContent, 15, "Should have the right value in the box model.");

  EventUtils.synthesizeMouseAtCenter(span, {}, view.doc.defaultView);
  let editor = view.doc.querySelector(".styleinspector-propertyeditor");
  ok(editor, "Should have opened the editor.");
  is(editor.value, "15px", "Should have the right value in the editor.");

  EventUtils.synthesizeKey("VK_DELETE", {}, view.doc.defaultView);
  yield waitForUpdate(inspector);

  is(editor.value, "", "Should have the right value in the editor.");
  is((yield getStyle(testActor, "#div1", "margin-right")), "",
     "Should have updated the margin.");

  EventUtils.synthesizeKey("VK_RETURN", {}, view.doc.defaultView);

  is((yield getStyle(testActor, "#div1", "margin-right")), "",
     "Should be the right margin-top on the element.");
  is(span.textContent, 10, "Should have the right value in the box model.");
}

function* testRefocusingOnClick(inspector, view, testActor) {
  info("Test that clicking in the editor input does not remove focus");

  yield selectNode("#div4", inspector);

  let span = view.doc.querySelector(".boxmodel-margin.boxmodel-top > span");
  is(span.textContent, 1, "Should have the right value in the box model.");

  EventUtils.synthesizeMouseAtCenter(span, {}, view.doc.defaultView);
  let editor = view.doc.querySelector(".styleinspector-propertyeditor");
  ok(editor, "Should have opened the editor.");

  info("Click in the already opened editor input");
  EventUtils.synthesizeMouseAtCenter(editor, {}, view.doc.defaultView);
  is(editor, view.doc.activeElement,
    "Inplace editor input should still have focus.");

  info("Check the input can still be used as expected");
  EventUtils.synthesizeKey("VK_UP", {}, view.doc.defaultView);
  yield waitForUpdate(inspector);

  is(editor.value, "2px", "Should have the right value in the editor.");
  is((yield getStyle(testActor, "#div4", "margin-top")), "2px",
     "Should have updated the margin.");
  EventUtils.synthesizeKey("VK_RETURN", {}, view.doc.defaultView);

  is((yield getStyle(testActor, "#div4", "margin-top")), "2px",
     "Should be the right margin-top on the element.");
  is(span.textContent, 2, "Should have the right value in the box model.");
}