blob: 7a69230aef5f770616d01830938af8067239e4b5 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
// Test that HTML can be pasted in SVG elements.
const TEST_URL = URL_ROOT + "doc_inspector_svg.svg";
const PASTE_AS_FIRST_CHILD =
'<circle xmlns="http://www.w3.org/2000/svg" cx="42" cy="42" r="5"/>';
const PASTE_AS_LAST_CHILD =
'<circle xmlns="http://www.w3.org/2000/svg" cx="42" cy="42" r="15"/>';
add_task(async function () {
const clipboard = require("resource://devtools/shared/platform/clipboard.js");
const { inspector } = await openInspectorForURL(TEST_URL);
const refSelector = "svg";
const oldHTML = await getContentPageElementProperty(refSelector, "innerHTML");
await selectNode(refSelector, inspector);
const markupTagLine = getContainerForSelector(refSelector, inspector).tagLine;
await pasteContent("node-menu-pastefirstchild", PASTE_AS_FIRST_CHILD);
await pasteContent("node-menu-pastelastchild", PASTE_AS_LAST_CHILD);
const html = await getContentPageElementProperty(refSelector, "innerHTML");
const expectedHtml = PASTE_AS_FIRST_CHILD + oldHTML + PASTE_AS_LAST_CHILD;
is(html, expectedHtml, "The innerHTML of the SVG node is correct");
// Helpers
async function pasteContent(menuId, clipboardData) {
const allMenuItems = openContextMenuAndGetAllItems(inspector, {
target: markupTagLine,
});
info(`Testing ${menuId} for ${clipboardData}`);
await SimpleTest.promiseClipboardChange(clipboardData, () => {
clipboard.copyString(clipboardData);
});
const onMutation = inspector.once("markupmutation");
allMenuItems.find(item => item.id === menuId).click();
info("Waiting for mutation to occur");
await onMutation;
}
});
|