/* Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/ */ "use strict"; const CSSCompleter = require("resource://devtools/client/shared/sourceeditor/css-autocompleter.js"); const source = [ ".devtools-toolbar {", " -moz-appearance: none;", " padding:4px 3px;border-bottom-width: 1px;", " border-bottom-style: solid;", "}", "", "#devtools-menu.devtools-menulist,", ".devtools-toolbarbutton#devtools-menu {", " -moz-appearance: none;", " align-items: center;", " min-width: 78px;", " min-height: 22px;", " text-shadow: 0 -1px 0 hsla(210,8%,5%,.45);", " border: 1px solid hsla(210,8%,5%,.45);", " border-radius: 3px;", " background: linear-gradient(hsla(212,7%,57%,.35),", " hsla(212,7%,57%,.1)) padding-box;", " margin: 0 3px;", " color: inherit;", "}", "", ".devtools-toolbarbutton > hbox.toolbarbutton-menubutton-button {", " flex-direction: row;", "}", "", ".devtools-menulist:active,", "#devtools-toolbarbutton:focus {", " outline: 1px dotted hsla(210,30%,85%,0.7);", " outline-offset : -4px;", "}", "", ".devtools-toolbarbutton:not([label]) {", " min-width: 32px;", "}", "", ".devtools-toolbarbutton:not([label]) > .toolbarbutton-text, .devtools-toolbar {", " display: none;", "}", ".multiline > ", ".complex + ", "#selector {}", ].join("\n"); // Format of test cases : // [ // {line, ch}, - The caret position at which the getInfo call should be made // expectedState, - The expected state at the caret // expectedSelector, - The expected selector for the state // expectedProperty, - The expected property name for states value and property // expectedValue, - If state is value, then the expected value // ] /* eslint-disable max-len */ const tests = [ [{ line: 0, ch: 13 }, CSSCompleter.CSS_STATE_SELECTOR, ".devtools-toolbar"], [ { line: 8, ch: 13 }, CSSCompleter.CSS_STATE_PROPERTY, [ "#devtools-menu.devtools-menulist", ".devtools-toolbarbutton#devtools-menu ", ], "-moz-appearance", ], [ { line: 28, ch: 25 }, CSSCompleter.CSS_STATE_VALUE, [".devtools-menulist:active", "#devtools-toolbarbutton:focus "], "outline-offset", "-4px", ], [{ line: 4, ch: 1 }, CSSCompleter.CSS_STATE_NULL], [{ line: 5, ch: 0 }, CSSCompleter.CSS_STATE_NULL], [ { line: 31, ch: 13 }, CSSCompleter.CSS_STATE_SELECTOR, ".devtools-toolbarbutton:not([label])", ], [ { line: 35, ch: 23 }, CSSCompleter.CSS_STATE_SELECTOR, ".devtools-toolbarbutton:not([label]) > .toolbarbutton-text", ], [{ line: 35, ch: 70 }, CSSCompleter.CSS_STATE_SELECTOR, ".devtools-toolbar"], [ { line: 27, ch: 14 }, CSSCompleter.CSS_STATE_VALUE, [".devtools-menulist:active", "#devtools-toolbarbutton:focus "], "outline", "1px dotted hsla(210,30%,85%,0.7)", ], [ { line: 16, ch: 16 }, CSSCompleter.CSS_STATE_VALUE, [ "#devtools-menu.devtools-menulist", ".devtools-toolbarbutton#devtools-menu ", ], "background", "linear-gradient(hsla(212,7%,57%,.35),\n hsla(212,7%,57%,.1)) padding-box", ], [ { line: 16, ch: 3 }, CSSCompleter.CSS_STATE_VALUE, [ "#devtools-menu.devtools-menulist", ".devtools-toolbarbutton#devtools-menu ", ], "background", "linear-gradient(hsla(212,7%,57%,.35),\n hsla(212,7%,57%,.1)) padding-box", ], [ { line: 15, ch: 25 }, CSSCompleter.CSS_STATE_VALUE, [ "#devtools-menu.devtools-menulist", ".devtools-toolbarbutton#devtools-menu ", ], "background", "linear-gradient(hsla(212,7%,57%,.35),\n hsla(212,7%,57%,.1)) padding-box", ], [ { line: 38, ch: 5 }, CSSCompleter.CSS_STATE_SELECTOR, ".multiline > \n.complex + \n#selector", ], [ { line: 39, ch: 5 }, CSSCompleter.CSS_STATE_SELECTOR, ".multiline > \n.complex + \n#selector", ], [ { line: 40, ch: 5 }, CSSCompleter.CSS_STATE_SELECTOR, ".multiline > \n.complex + \n#selector", ], ]; /* eslint-enable max-len */ const TEST_URI = "data:text/html;charset=UTF-8," + encodeURIComponent( [ "", "", "
", "