--- /dev/null
+(function() {
+ var mode = CodeMirror.getMode({tabSize: 4}, "css");
+ function MT(name) { test.mode(name, mode, Array.prototype.slice.call(arguments, 1)); }
+
+ // Requires at least one media query
+ MT("atMediaEmpty",
+ "[def @media] [error {] }");
+
+ MT("atMediaMultiple",
+ "[def @media] [keyword not] [attribute screen] [operator and] ([property color]), [keyword not] [attribute print] [operator and] ([property color]) { }");
+
+ MT("atMediaCheckStack",
+ "[def @media] [attribute screen] { } [tag foo] { }");
+
+ MT("atMediaCheckStack",
+ "[def @media] [attribute screen] ([property color]) { } [tag foo] { }");
+
+ MT("atMediaPropertyOnly",
+ "[def @media] ([property color]) { } [tag foo] { }");
+
+ MT("atMediaCheckStackInvalidAttribute",
+ "[def @media] [attribute&error foobarhello] { [tag foo] { } }");
+
+ MT("atMediaCheckStackInvalidAttribute",
+ "[def @media] [attribute&error foobarhello] { } [tag foo] { }");
+
+ // Error, because "and" is only allowed immediately preceding a media expression
+ MT("atMediaInvalidAttribute",
+ "[def @media] [attribute&error foobarhello] { }");
+
+ // Error, because "and" is only allowed immediately preceding a media expression
+ MT("atMediaInvalidAnd",
+ "[def @media] [error and] [attribute screen] { }");
+
+ // Error, because "not" is only allowed as the first item in each media query
+ MT("atMediaInvalidNot",
+ "[def @media] [attribute screen] [error not] ([error not]) { }");
+
+ // Error, because "only" is only allowed as the first item in each media query
+ MT("atMediaInvalidOnly",
+ "[def @media] [attribute screen] [error only] ([error only]) { }");
+
+ // Error, because "foobarhello" is neither a known type or property, but
+ // property was expected (after "and"), and it should be in parenthese.
+ MT("atMediaUnknownType",
+ "[def @media] [attribute screen] [operator and] [error foobarhello] { }");
+
+ // Error, because "color" is not a known type, but is a known property, and
+ // should be in parentheses.
+ MT("atMediaInvalidType",
+ "[def @media] [attribute screen] [operator and] [error color] { }");
+
+ // Error, because "print" is not a known property, but is a known type,
+ // and should not be in parenthese.
+ MT("atMediaInvalidProperty",
+ "[def @media] [attribute screen] [operator and] ([error print]) { }");
+
+ // Soft error, because "foobarhello" is not a known property or type.
+ MT("atMediaUnknownProperty",
+ "[def @media] [attribute screen] [operator and] ([property&error foobarhello]) { }");
+
+ // Make sure nesting works with media queries
+ MT("atMediaMaxWidthNested",
+ "[def @media] [attribute screen] [operator and] ([property max-width][operator :] [number 25px]) { [tag foo] { } }");
+
+ MT("tagSelector",
+ "[tag foo] { }");
+
+ MT("classSelector",
+ "[qualifier .foo-bar_hello] { }");
+
+ MT("idSelector",
+ "[builtin #foo] { [error #foo] }");
+
+ MT("tagSelectorUnclosed",
+ "[tag foo] { [property margin][operator :] [number 0] } [tag bar] { }");
+
+ MT("tagStringNoQuotes",
+ "[tag foo] { [property font-family][operator :] [variable-2 hello] [variable-2 world]; }");
+
+ MT("tagStringDouble",
+ "[tag foo] { [property font-family][operator :] [string \"hello world\"]; }");
+
+ MT("tagStringSingle",
+ "[tag foo] { [property font-family][operator :] [string 'hello world']; }");
+
+ MT("tagColorKeyword",
+ "[tag foo] {" +
+ "[property color][operator :] [keyword black];" +
+ "[property color][operator :] [keyword navy];" +
+ "[property color][operator :] [keyword yellow];" +
+ "}");
+
+ MT("tagColorHex3",
+ "[tag foo] { [property background][operator :] [atom #fff]; }");
+
+ MT("tagColorHex6",
+ "[tag foo] { [property background][operator :] [atom #ffffff]; }");
+
+ MT("tagColorHex4",
+ "[tag foo] { [property background][operator :] [atom&error #ffff]; }");
+
+ MT("tagColorHexInvalid",
+ "[tag foo] { [property background][operator :] [atom&error #ffg]; }");
+
+ MT("tagNegativeNumber",
+ "[tag foo] { [property margin][operator :] [number -5px]; }");
+
+ MT("tagPositiveNumber",
+ "[tag foo] { [property padding][operator :] [number 5px]; }");
+
+ MT("tagVendor",
+ "[tag foo] { [meta -foo-][property box-sizing][operator :] [meta -foo-][string-2 border-box]; }");
+
+ MT("tagBogusProperty",
+ "[tag foo] { [property&error barhelloworld][operator :] [number 0]; }");
+
+ MT("tagTwoProperties",
+ "[tag foo] { [property margin][operator :] [number 0]; [property padding][operator :] [number 0]; }");
+
+ MT("tagTwoPropertiesURL",
+ "[tag foo] { [property background][operator :] [string-2 url]([string //example.com/foo.png]); [property padding][operator :] [number 0]; }");
+
+ MT("commentSGML",
+ "[comment <!--comment-->]");
+})();