Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
/* Any copyright is dedicated to the Public Domain.
"use strict";
// Test that image preview tooltip shows updated content when the image src
// changes.
// prettier-ignore
const INITIAL_SRC = "";
const UPDATED_SRC = URL_ROOT + "doc_markup_tooltip.png";
const INITIAL_SRC_SIZE = "64" + " \u00D7 " + "64";
const UPDATED_SRC_SIZE = "22" + " \u00D7 " + "23";
add_task(async function () {
const { inspector } = await openInspectorForURL(
"data:text/html,<p>markup view tooltip test</p><img>"
);
info("Retrieving NodeFront for the <img> element.");
const img = await getNodeFront("img", inspector);
info("Selecting the <img> element");
await selectNode(img, inspector);
info("Adding src attribute to the image.");
await updateImageSrc(img, INITIAL_SRC, inspector);
const container = getContainerForNodeFront(img, inspector);
ok(container, "Found markup container for the image.");
let target = container.editor
.getAttributeElement("src")
.querySelector(".link");
ok(target, "Found the src attribute in the markup view.");
info("Showing tooltip on the src link.");
await assertTooltipShownOnHover(inspector.markup.imagePreviewTooltip, target);
checkImageTooltip(INITIAL_SRC_SIZE, inspector);
await assertTooltipHiddenOnMouseOut(
inspector.markup.imagePreviewTooltip,
target
);
info("Updating the image src.");
await updateImageSrc(img, UPDATED_SRC, inspector);
target = container.editor.getAttributeElement("src").querySelector(".link");
ok(target, "Found the src attribute in the markup view after mutation.");
info("Showing tooltip on the src link.");
await assertTooltipShownOnHover(inspector.markup.imagePreviewTooltip, target);
info("Checking that the new image was shown.");
checkImageTooltip(UPDATED_SRC_SIZE, inspector);
await assertTooltipHiddenOnMouseOut(
inspector.markup.imagePreviewTooltip,
target
);
});
/**
* Updates the src attribute of the image. Return a Promise.
*/
function updateImageSrc(img, newSrc, inspector) {
const onMutated = inspector.once("markupmutation");
const onModified = img.modifyAttributes([
{
attributeName: "src",
newValue: newSrc,
},
]);
return Promise.all([onMutated, onModified]);
}
/**
* Checks that the markup view tooltip contains an image element with the given
* size.
*/
function checkImageTooltip(size, { markup }) {
const panel = markup.imagePreviewTooltip.panel;
const images = panel.getElementsByTagName("img");
is(images.length, 1, "Tooltip contains an image");
const label = panel.querySelector(".devtools-tooltip-caption");
is(label.textContent, size, "Tooltip label displays the right image size");
markup.imagePreviewTooltip.hide();
}