diff options
Diffstat (limited to '')
-rw-r--r-- | devtools/client/inspector/rules/test/browser_rules_multiple-properties-unfinished_01.js | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/devtools/client/inspector/rules/test/browser_rules_multiple-properties-unfinished_01.js b/devtools/client/inspector/rules/test/browser_rules_multiple-properties-unfinished_01.js new file mode 100644 index 0000000000..e451950aba --- /dev/null +++ b/devtools/client/inspector/rules/test/browser_rules_multiple-properties-unfinished_01.js @@ -0,0 +1,99 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +// Test that the rule-view behaves correctly when entering multiple and/or +// unfinished properties/values in inplace-editors + +const TEST_URI = "<div>Test Element</div>"; + +add_task(async function () { + await addTab("data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI)); + const { inspector, view } = await openRuleView(); + await selectNode("div", inspector); + await testCreateNewMultiUnfinished(inspector, view); +}); + +async function testCreateNewMultiUnfinished(inspector, view) { + const ruleEditor = getRuleViewRuleEditor(view, 0); + const onMutation = inspector.once("markupmutation"); + let onRuleViewChanged = view.once("ruleview-changed"); + await createNewRuleViewProperty( + ruleEditor, + "color:blue;background : orange ; text-align:center; border-color: " + ); + await onMutation; + await onRuleViewChanged; + + is( + ruleEditor.rule.textProps.length, + 4, + "Should have created new text properties." + ); + is( + ruleEditor.propertyList.children.length, + 4, + "Should have created property editors." + ); + + EventUtils.sendString("red", view.styleWindow); + onRuleViewChanged = view.once("ruleview-changed"); + EventUtils.synthesizeKey("VK_RETURN", {}, view.styleWindow); + await onRuleViewChanged; + + is( + ruleEditor.rule.textProps.length, + 4, + "Should have the same number of text properties." + ); + is( + ruleEditor.propertyList.children.length, + 5, + "Should have added the changed value editor." + ); + + is( + getTextProperty(view, 0, { color: "blue" }).name, + "color", + "Should have correct property name" + ); + is( + getTextProperty(view, 0, { color: "blue" }).value, + "blue", + "Should have correct property value" + ); + + is( + getTextProperty(view, 0, { background: "orange" }).name, + "background", + "Should have correct property name" + ); + is( + getTextProperty(view, 0, { background: "orange" }).value, + "orange", + "Should have correct property value" + ); + + is( + getTextProperty(view, 0, { "text-align": "center" }).name, + "text-align", + "Should have correct property name" + ); + is( + getTextProperty(view, 0, { "text-align": "center" }).value, + "center", + "Should have correct property value" + ); + + is( + getTextProperty(view, 0, { "border-color": "red" }).name, + "border-color", + "Should have correct property name" + ); + is( + getTextProperty(view, 0, { "border-color": "red" }).value, + "red", + "Should have correct property value" + ); +} |