Wed, 31 Dec 2014 06:09:35 +0100
Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.
1 /* vim: set ft=javascript ts=2 et sw=2 tw=80: */
2 /* Any copyright is dedicated to the Public Domain.
3 http://creativecommons.org/publicdomain/zero/1.0/ */
5 "use strict";
7 // Test that background-image URLs have image preview tooltips in the rule-view
8 // and computed-view
10 const PAGE_CONTENT = [
11 '<style type="text/css">',
12 ' body {',
13 ' padding: 1em;',
14 ' background-image: url();',
15 ' background-repeat: repeat-y;',
16 ' background-position: right top;',
17 ' }',
18 ' .test-element {',
19 ' font-family: verdana;',
20 ' color: #333;',
21 ' background: url(chrome://global/skin/icons/warning-64.png) no-repeat left center;',
22 ' padding-left: 70px;',
23 ' }',
24 '</style>',
25 '<div class="test-element">test element</div>'
26 ].join("\n");
28 let test = asyncTest(function*() {
29 yield addTab("data:text/html,rule view tooltip test");
30 content.document.body.innerHTML = PAGE_CONTENT;
31 let {toolbox, inspector, view} = yield openRuleView();
33 info("Testing the background-image property on the body rule");
34 yield testBodyRuleView(view);
36 info("Selecting the test div node");
37 yield selectNode(".test-element", inspector);
38 info("Testing the the background property on the .test-element rule");
39 yield testDivRuleView(view);
41 info("Testing that image preview tooltips show even when there are fields being edited");
42 yield testTooltipAppearsEvenInEditMode(view);
44 info("Switching over to the computed-view");
45 let {view} = yield openComputedView();
47 info("Testing that the background-image computed style has a tooltip too");
48 yield testComputedView(view);
49 });
51 function* testBodyRuleView(view) {
52 info("Testing tooltips in the rule view");
53 let panel = view.previewTooltip.panel;
55 // Check that the rule view has a tooltip and that a XUL panel has been created
56 ok(view.previewTooltip, "Tooltip instance exists");
57 ok(panel, "XUL panel exists");
59 // Get the background-image property inside the rule view
60 let {valueSpan} = getRuleViewProperty(view, "body", "background-image");
61 let uriSpan = valueSpan.querySelector(".theme-link");
63 yield assertHoverTooltipOn(view.previewTooltip, uriSpan);
65 let images = panel.getElementsByTagName("image");
66 is(images.length, 1, "Tooltip contains an image");
67 ok(images[0].getAttribute("src").indexOf("iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHe") !== -1,
68 "The image URL seems fine");
69 }
71 function* testDivRuleView(view) {
72 let panel = view.previewTooltip.panel;
74 // Get the background property inside the rule view
75 let {valueSpan} = getRuleViewProperty(view, ".test-element", "background");
76 let uriSpan = valueSpan.querySelector(".theme-link");
78 yield assertHoverTooltipOn(view.previewTooltip, uriSpan);
80 let images = panel.getElementsByTagName("image");
81 is(images.length, 1, "Tooltip contains an image");
82 ok(images[0].getAttribute("src").startsWith("data:"), "Tooltip contains a data-uri image as expected");
83 }
85 function* testTooltipAppearsEvenInEditMode(view) {
86 let panel = view.previewTooltip.panel;
88 info("Switching to edit mode in the rule view");
89 let editor = yield turnToEditMode(view);
91 info("Now trying to show the preview tooltip");
92 let {valueSpan} = getRuleViewProperty(view, ".test-element", "background");
93 let uriSpan = valueSpan.querySelector(".theme-link");
94 yield assertHoverTooltipOn(view.previewTooltip, uriSpan);
96 is(view.doc.activeElement, editor.input,
97 "Tooltip was shown in edit mode, and inplace-editor still focused");
98 }
100 function turnToEditMode(ruleView) {
101 let brace = ruleView.doc.querySelector(".ruleview-ruleclose");
102 return focusEditableField(brace);
103 }
105 function* testComputedView(view) {
106 let tooltip = view.tooltip;
107 ok(tooltip, "The computed-view has a tooltip defined");
109 let panel = tooltip.panel;
110 ok(panel, "The computed-view tooltip has a XUL panel");
112 let {valueSpan} = getComputedViewProperty(view, "background-image");
113 let uriSpan = valueSpan.querySelector(".theme-link");
115 yield assertHoverTooltipOn(view.tooltip, uriSpan);
117 let images = panel.getElementsByTagName("image");
118 is(images.length, 1, "Tooltip contains an image");
120 ok(images[0].getAttribute("src").startsWith("data:"), "Tooltip contains a data-uri in the computed-view too");
121 }