/* vim: set ft=javascript ts=2 et sw=2 tw=80: */ /* 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(function* () { yield addTab("data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI)); let {inspector, view} = yield openRuleView(); yield selectNode("div", inspector); yield testCreateNewMultiUnfinished(inspector, view); }); function* testCreateNewMultiUnfinished(inspector, view) { let ruleEditor = getRuleViewRuleEditor(view, 0); let onMutation = inspector.once("markupmutation"); let onRuleViewChanged = view.once("ruleview-changed"); yield createNewRuleViewProperty(ruleEditor, "color:blue;background : orange ; text-align:center; border-color: "); yield onMutation; yield 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); yield 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(ruleEditor.rule.textProps[0].name, "color", "Should have correct property name"); is(ruleEditor.rule.textProps[0].value, "blue", "Should have correct property value"); is(ruleEditor.rule.textProps[1].name, "background", "Should have correct property name"); is(ruleEditor.rule.textProps[1].value, "orange", "Should have correct property value"); is(ruleEditor.rule.textProps[2].name, "text-align", "Should have correct property name"); is(ruleEditor.rule.textProps[2].value, "center", "Should have correct property value"); is(ruleEditor.rule.textProps[3].name, "border-color", "Should have correct property name"); is(ruleEditor.rule.textProps[3].value, "red", "Should have correct property value"); }