browser/devtools/markupview/test/browser_markupview_image_tooltip.js

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

michael@0 1 /* vim: set ts=2 et sw=2 tw=80: */
michael@0 2 /* Any copyright is dedicated to the Public Domain.
michael@0 3 http://creativecommons.org/publicdomain/zero/1.0/ */
michael@0 4
michael@0 5 "use strict";
michael@0 6
michael@0 7 // Test that image preview tooltips are shown on img and canvas tags in the
michael@0 8 // markup-view and that the tooltip actually contains an image and shows the
michael@0 9 // right dimension label
michael@0 10
michael@0 11 const PAGE_CONTENT = [
michael@0 12 '<img class="local" src="chrome://branding/content/about-logo.png" />',
michael@0 13 '<img class="data" src="" />',
michael@0 14 '<img class="remote" src="' + TEST_URL_ROOT + 'doc_markup_tooltip.png" />',
michael@0 15 '<canvas class="canvas" width="600" height="600"></canvas>'
michael@0 16 ].join("\n");
michael@0 17
michael@0 18 const TEST_NODES = [
michael@0 19 {selector: "img.local", size: "192 x 192"},
michael@0 20 {selector: "img.data", size: "64 x 64"},
michael@0 21 {selector: "img.remote", size: "22 x 23"},
michael@0 22 {selector: ".canvas", size: "600 x 600"}
michael@0 23 ];
michael@0 24
michael@0 25 let test = asyncTest(function*() {
michael@0 26 yield addTab("data:text/html,markup view tooltip test");
michael@0 27 createPage();
michael@0 28
michael@0 29 let {inspector} = yield openInspector();
michael@0 30
michael@0 31 info("Selecting the first <img> tag");
michael@0 32 yield selectNode("img", inspector);
michael@0 33
michael@0 34 for (let testNode of TEST_NODES) {
michael@0 35 let target = getImageTooltipTarget(testNode, inspector);
michael@0 36 yield assertTooltipShownOn(target, inspector);
michael@0 37 checkImageTooltip(testNode, inspector);
michael@0 38 }
michael@0 39 });
michael@0 40
michael@0 41 function createPage() {
michael@0 42 info("Fill the page with the test content");
michael@0 43 content.document.body.innerHTML = PAGE_CONTENT;
michael@0 44
michael@0 45 info("Fill the canvas");
michael@0 46 let doc = content.document;
michael@0 47 let context = doc.querySelector(".canvas").getContext("2d");
michael@0 48
michael@0 49 context.beginPath();
michael@0 50 context.moveTo(300, 0);
michael@0 51 context.lineTo(600, 600);
michael@0 52 context.lineTo(0, 600);
michael@0 53 context.closePath();
michael@0 54 context.fillStyle = "#ffc821";
michael@0 55 context.fill();
michael@0 56 }
michael@0 57
michael@0 58 function getImageTooltipTarget({selector}, inspector) {
michael@0 59 let node = getNode(selector);
michael@0 60 let isImg = node.tagName.toLowerCase() === "img";
michael@0 61
michael@0 62 let container = getContainerForRawNode(node, inspector);
michael@0 63
michael@0 64 let target = container.editor.tag;
michael@0 65 if (isImg) {
michael@0 66 target = container.editor.getAttributeElement("src");
michael@0 67 }
michael@0 68 return target;
michael@0 69 }
michael@0 70
michael@0 71 function assertTooltipShownOn(element, {markup}) {
michael@0 72 return Task.spawn(function*() {
michael@0 73 info("Is the element a valid hover target");
michael@0 74 let isValid = yield markup.tooltip.isValidHoverTarget(element);
michael@0 75 ok(isValid, "The element is a valid hover target for the image tooltip");
michael@0 76 });
michael@0 77 }
michael@0 78
michael@0 79 function checkImageTooltip({selector, size}, {markup}) {
michael@0 80 let images = markup.tooltip.panel.getElementsByTagName("image");
michael@0 81 is(images.length, 1, "Tooltip for [" + selector + "] contains an image");
michael@0 82
michael@0 83 let label = markup.tooltip.panel.querySelector(".devtools-tooltip-caption");
michael@0 84 is(label.textContent, size, "Tooltip label for [" + selector + "] displays the right image size");
michael@0 85
michael@0 86 markup.tooltip.hide();
michael@0 87 }

mercurial