/* 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 = "
Test Element
"; 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" ); }