/* Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/ */ /* import-globals-from helper_attributes_test_runner.js */ "use strict"; // One more test testing various add-attributes configurations // Some of the test data below asserts that long attributes get collapsed loadHelperScript("helper_attributes_test_runner.js"); /*eslint-disable */ const LONG_ATTRIBUTE = "ABCDEFGHIJKLMNOPQRSTUVWXYZ-ABCDEFGHIJKLMNOPQRSTUVWXYZ-ABCDEFGHIJKLMNOPQRSTUVWXYZABCDEFGHIJKLMNOPQRSTUVWXYZ-ABCDEFGHIJKLMNOPQRSTUVWXYZ-ABCDEFGHIJKLMNOPQRSTUVWXYZ"; const LONG_ATTRIBUTE_COLLAPSED = "ABCDEFGHIJKLMNOPQRSTUVWXYZ-ABCDEFGHIJKLMNOPQRSTUVWXYZ-ABCDEF\u2026UVWXYZ-ABCDEFGHIJKLMNOPQRSTUVWXYZ-ABCDEFGHIJKLMNOPQRSTUVWXYZ"; const DATA_URL_INLINE_STYLE='color: red; background: url("");'; const DATA_URL_INLINE_STYLE_COLLAPSED='color: red; background: url("\u2026NDDeNGe4Ug9C9zwz3gVLMDA/A6P9/AFGGFyjOXZtQAAAAAElFTkSuQmCC");'; const DATA_URL_ATTRIBUTE = ""; const DATA_URL_ATTRIBUTE_COLLAPSED = "\u20269/AFGGFyjOXZtQAAAAAElFTkSuQmCC"; /*eslint-enable */ var TEST_URL = "data:text/html,
markup-view attributes addition test
"; var TEST_DATA = [{ desc: "Add an attribute value containing < > ü \" & '", text: 'src="somefile.html?param1=¶m2=ü¶m3=\'"\'"', expectedAttributes: { src: "somefile.html?param1=¶m2=\xfc¶m3='\"'" } }, { desc: "Add an attribute by clicking the empty space after a node", text: 'class="newclass" style="color:green"', expectedAttributes: { class: "newclass", style: "color:green" } }, { desc: "Try add an attribute containing a quote (\") attribute by " + "clicking the empty space after a node - this should result " + "in it being set to an empty string", text: 'class="newclass" style="""', expectedAttributes: { class: "newclass", style: "" } }, { desc: "Try to add long data URL to make sure it is collapsed in attribute " + "editor.", text: `style='${DATA_URL_INLINE_STYLE}'`, expectedAttributes: { "style": DATA_URL_INLINE_STYLE }, validate: (container, inspector) => { let editor = container.editor; let visibleAttrText = editor.attrElements.get("style") .querySelector(".attr-value") .textContent; is(visibleAttrText, DATA_URL_INLINE_STYLE_COLLAPSED); } }, { desc: "Try to add long attribute to make sure it is collapsed in attribute " + "editor.", text: `data-long="${LONG_ATTRIBUTE}"`, expectedAttributes: { "data-long": LONG_ATTRIBUTE }, validate: (container, inspector) => { let editor = container.editor; let visibleAttrText = editor.attrElements.get("data-long") .querySelector(".attr-value") .textContent; is(visibleAttrText, LONG_ATTRIBUTE_COLLAPSED); } }, { desc: "Try to add long data URL to make sure it is collapsed in attribute " + "editor.", text: `src="${DATA_URL_ATTRIBUTE}"`, expectedAttributes: { "src": DATA_URL_ATTRIBUTE }, validate: (container, inspector) => { let editor = container.editor; let visibleAttrText = editor.attrElements.get("src") .querySelector(".attr-value").textContent; is(visibleAttrText, DATA_URL_ATTRIBUTE_COLLAPSED); } }, { desc: "Try to add long attribute with collapseAttributes == false" + "to make sure it isn't collapsed in attribute editor.", text: `data-long="${LONG_ATTRIBUTE}"`, expectedAttributes: { "data-long": LONG_ATTRIBUTE }, setUp: function (inspector) { Services.prefs.setBoolPref("devtools.markup.collapseAttributes", false); }, validate: (container, inspector) => { let editor = container.editor; let visibleAttrText = editor.attrElements .get("data-long") .querySelector(".attr-value") .textContent; is(visibleAttrText, LONG_ATTRIBUTE); }, tearDown: function (inspector) { Services.prefs.clearUserPref("devtools.markup.collapseAttributes"); } }, { desc: "Try to collapse attributes with collapseAttributeLength == 5", text: `data-long="${LONG_ATTRIBUTE}"`, expectedAttributes: { "data-long": LONG_ATTRIBUTE }, setUp: function (inspector) { Services.prefs.setIntPref("devtools.markup.collapseAttributeLength", 2); }, validate: (container, inspector) => { let firstChar = LONG_ATTRIBUTE[0]; let lastChar = LONG_ATTRIBUTE[LONG_ATTRIBUTE.length - 1]; let collapsed = firstChar + "\u2026" + lastChar; let editor = container.editor; let visibleAttrText = editor.attrElements .get("data-long") .querySelector(".attr-value") .textContent; is(visibleAttrText, collapsed); }, tearDown: function (inspector) { Services.prefs.clearUserPref("devtools.markup.collapseAttributeLength"); } }]; add_task(function* () { let {inspector, testActor} = yield openInspectorForURL(TEST_URL); yield runAddAttributesTests(TEST_DATA, "div", inspector, testActor); });