diff options
author | Matt A. Tobin <email@mattatobin.com> | 2016-10-16 19:34:53 -0400 |
---|---|---|
committer | Matt A. Tobin <email@mattatobin.com> | 2016-10-16 19:34:53 -0400 |
commit | 81805ce3f63e2e4a799bd54f174083c58a9b5640 (patch) | |
tree | 6e13374b213ac9b2ae74c25d8aac875faf71fdd0 /toolkit/devtools/styleinspector/test/browser_ruleview_multiple_properties_02.js | |
parent | 28c8da71bf521bb3ee76f27b8a241919e24b7cd5 (diff) | |
download | palemoon-gre-81805ce3f63e2e4a799bd54f174083c58a9b5640.tar.gz |
Move Mozilla DevTools to Platform - Part 3: Merge the browser/devtools and toolkit/devtools adjusting for directory collisions
Diffstat (limited to 'toolkit/devtools/styleinspector/test/browser_ruleview_multiple_properties_02.js')
-rw-r--r-- | toolkit/devtools/styleinspector/test/browser_ruleview_multiple_properties_02.js | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/toolkit/devtools/styleinspector/test/browser_ruleview_multiple_properties_02.js b/toolkit/devtools/styleinspector/test/browser_ruleview_multiple_properties_02.js new file mode 100644 index 000000000..3179a7b51 --- /dev/null +++ b/toolkit/devtools/styleinspector/test/browser_ruleview_multiple_properties_02.js @@ -0,0 +1,49 @@ +/* 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 mutliple and/or +// unfinished properties/values in inplace-editors + +add_task(function*() { + yield addTab("data:text/html;charset=utf-8,test rule view user changes"); + content.document.body.innerHTML = "<h1>Testing Multiple Properties</h1>"; + let {toolbox, inspector, view} = yield openRuleView(); + + info("Creating the test element"); + let newElement = content.document.createElement("div"); + newElement.textContent = "Test Element"; + content.document.body.appendChild(newElement); + yield selectNode("div", inspector); + let ruleEditor = getRuleViewRuleEditor(view, 0); + + yield testMultiValues(inspector, ruleEditor, view); +}); + +function* testMultiValues(inspector, ruleEditor, view) { + yield createNewRuleViewProperty(ruleEditor, "width:"); + + is(ruleEditor.rule.textProps.length, 1, "Should have created a new text property."); + is(ruleEditor.propertyList.children.length, 1, "Should have created a property editor."); + + // Value is focused, lets add multiple rules here and make sure they get added + let valueEditor = ruleEditor.propertyList.children[0].querySelector("input"); + valueEditor.value = "height: 10px;color:blue" + EventUtils.synthesizeKey("VK_RETURN", {}, view.doc.defaultView); + + is(ruleEditor.rule.textProps.length, 2, "Should have added the changed value."); + is(ruleEditor.propertyList.children.length, 3, "Should have added the changed value editor."); + + EventUtils.synthesizeKey("VK_ESCAPE", {}, view.doc.defaultView); + is(ruleEditor.propertyList.children.length, 2, "Should have removed the value editor."); + + is(ruleEditor.rule.textProps[0].name, "width", "Should have correct property name"); + is(ruleEditor.rule.textProps[0].value, "height: 10px", "Should have correct property value"); + + is(ruleEditor.rule.textProps[1].name, "color", "Should have correct property name"); + is(ruleEditor.rule.textProps[1].value, "blue", "Should have correct property value"); + + yield inspector.once("inspector-updated"); +} |