summaryrefslogtreecommitdiffstats
path: root/devtools/client/inspector/markup/test/browser_markup_image_tooltip_mutations.js
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--devtools/client/inspector/markup/test/browser_markup_image_tooltip_mutations.js95
1 files changed, 95 insertions, 0 deletions
diff --git a/devtools/client/inspector/markup/test/browser_markup_image_tooltip_mutations.js b/devtools/client/inspector/markup/test/browser_markup_image_tooltip_mutations.js
new file mode 100644
index 0000000000..3a2cc358a7
--- /dev/null
+++ b/devtools/client/inspector/markup/test/browser_markup_image_tooltip_mutations.js
@@ -0,0 +1,95 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"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();
+}