2014-04-08 03:19:16 -07:00
|
|
|
/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
|
2013-10-25 12:21:01 -07:00
|
|
|
/* Any copyright is dedicated to the Public Domain.
|
|
|
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
"use strict";
|
|
|
|
|
|
|
|
// Test that background-image URLs have image preview tooltips in the rule-view
|
|
|
|
// and computed-view
|
2013-10-25 12:21:01 -07:00
|
|
|
|
|
|
|
const PAGE_CONTENT = [
|
|
|
|
'<style type="text/css">',
|
|
|
|
' body {',
|
|
|
|
' padding: 1em;',
|
|
|
|
' background-image: url(
|
|
|
|
' background-repeat: repeat-y;',
|
|
|
|
' background-position: right top;',
|
|
|
|
' }',
|
|
|
|
' .test-element {',
|
|
|
|
' font-family: verdana;',
|
|
|
|
' color: #333;',
|
|
|
|
' background: url(chrome://global/skin/icons/warning-64.png) no-repeat left center;',
|
|
|
|
' padding-left: 70px;',
|
|
|
|
' }',
|
|
|
|
'</style>',
|
2013-11-18 10:03:20 -08:00
|
|
|
'<div class="test-element">test element</div>'
|
2013-10-25 12:21:01 -07:00
|
|
|
].join("\n");
|
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
let test = asyncTest(function*() {
|
2014-07-17 00:59:11 -07:00
|
|
|
yield addTab("data:text/html;charset=utf-8,rule view tooltip test");
|
2014-04-08 03:19:16 -07:00
|
|
|
content.document.body.innerHTML = PAGE_CONTENT;
|
|
|
|
let {toolbox, inspector, view} = yield openRuleView();
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
info("Testing the background-image property on the body rule");
|
|
|
|
yield testBodyRuleView(view);
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
info("Selecting the test div node");
|
|
|
|
yield selectNode(".test-element", inspector);
|
|
|
|
info("Testing the the background property on the .test-element rule");
|
|
|
|
yield testDivRuleView(view);
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
info("Testing that image preview tooltips show even when there are fields being edited");
|
|
|
|
yield testTooltipAppearsEvenInEditMode(view);
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
info("Switching over to the computed-view");
|
|
|
|
let {view} = yield openComputedView();
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
info("Testing that the background-image computed style has a tooltip too");
|
|
|
|
yield testComputedView(view);
|
|
|
|
});
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
function* testBodyRuleView(view) {
|
|
|
|
info("Testing tooltips in the rule view");
|
2014-06-18 01:25:40 -07:00
|
|
|
let panel = view.tooltips.previewTooltip.panel;
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
// Check that the rule view has a tooltip and that a XUL panel has been created
|
2014-06-18 01:25:40 -07:00
|
|
|
ok(view.tooltips.previewTooltip, "Tooltip instance exists");
|
2014-04-08 03:19:16 -07:00
|
|
|
ok(panel, "XUL panel exists");
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
// Get the background-image property inside the rule view
|
|
|
|
let {valueSpan} = getRuleViewProperty(view, "body", "background-image");
|
|
|
|
let uriSpan = valueSpan.querySelector(".theme-link");
|
2014-03-19 02:11:34 -07:00
|
|
|
|
2014-06-18 01:25:40 -07:00
|
|
|
yield assertHoverTooltipOn(view.tooltips.previewTooltip, uriSpan);
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
let images = panel.getElementsByTagName("image");
|
|
|
|
is(images.length, 1, "Tooltip contains an image");
|
|
|
|
ok(images[0].getAttribute("src").indexOf("iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHe") !== -1,
|
|
|
|
"The image URL seems fine");
|
2013-10-25 12:21:01 -07:00
|
|
|
}
|
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
function* testDivRuleView(view) {
|
2014-06-18 01:25:40 -07:00
|
|
|
let panel = view.tooltips.previewTooltip.panel;
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
// Get the background property inside the rule view
|
|
|
|
let {valueSpan} = getRuleViewProperty(view, ".test-element", "background");
|
|
|
|
let uriSpan = valueSpan.querySelector(".theme-link");
|
2014-03-19 02:11:34 -07:00
|
|
|
|
2014-06-18 01:25:40 -07:00
|
|
|
yield assertHoverTooltipOn(view.tooltips.previewTooltip, uriSpan);
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
let images = panel.getElementsByTagName("image");
|
|
|
|
is(images.length, 1, "Tooltip contains an image");
|
|
|
|
ok(images[0].getAttribute("src").startsWith("data:"), "Tooltip contains a data-uri image as expected");
|
2013-11-18 10:03:20 -08:00
|
|
|
}
|
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
function* testTooltipAppearsEvenInEditMode(view) {
|
2014-06-18 01:25:40 -07:00
|
|
|
let panel = view.tooltips.previewTooltip.panel;
|
2013-11-18 10:03:20 -08:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
info("Switching to edit mode in the rule view");
|
|
|
|
let editor = yield turnToEditMode(view);
|
2014-03-19 02:11:34 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
info("Now trying to show the preview tooltip");
|
|
|
|
let {valueSpan} = getRuleViewProperty(view, ".test-element", "background");
|
|
|
|
let uriSpan = valueSpan.querySelector(".theme-link");
|
2014-06-18 01:25:40 -07:00
|
|
|
yield assertHoverTooltipOn(view.tooltips.previewTooltip, uriSpan);
|
2013-11-18 10:03:20 -08:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
is(view.doc.activeElement, editor.input,
|
|
|
|
"Tooltip was shown in edit mode, and inplace-editor still focused");
|
2014-03-19 02:11:34 -07:00
|
|
|
}
|
2013-11-18 10:03:20 -08:00
|
|
|
|
2014-03-19 02:11:34 -07:00
|
|
|
function turnToEditMode(ruleView) {
|
|
|
|
let brace = ruleView.doc.querySelector(".ruleview-ruleclose");
|
2014-04-08 03:19:16 -07:00
|
|
|
return focusEditableField(brace);
|
2013-10-25 12:21:01 -07:00
|
|
|
}
|
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
function* testComputedView(view) {
|
2014-06-18 01:25:40 -07:00
|
|
|
let tooltip = view.tooltips.previewTooltip;
|
2014-04-08 03:19:16 -07:00
|
|
|
ok(tooltip, "The computed-view has a tooltip defined");
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
let panel = tooltip.panel;
|
|
|
|
ok(panel, "The computed-view tooltip has a XUL panel");
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
let {valueSpan} = getComputedViewProperty(view, "background-image");
|
|
|
|
let uriSpan = valueSpan.querySelector(".theme-link");
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-06-18 01:25:40 -07:00
|
|
|
yield assertHoverTooltipOn(view.tooltips.previewTooltip, uriSpan);
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
let images = panel.getElementsByTagName("image");
|
|
|
|
is(images.length, 1, "Tooltip contains an image");
|
2013-10-25 12:21:01 -07:00
|
|
|
|
2014-04-08 03:19:16 -07:00
|
|
|
ok(images[0].getAttribute("src").startsWith("data:"), "Tooltip contains a data-uri in the computed-view too");
|
2013-10-25 12:21:01 -07:00
|
|
|
}
|