| OLD | NEW |
| 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 /** Common definitions used for setting up the test environment. */ | 5 /** Common definitions used for setting up the test environment. */ |
| 6 library testing; | 6 library testing; |
| 7 | 7 |
| 8 import 'package:csslib/parser.dart'; | 8 import 'package:csslib/parser.dart'; |
| 9 import 'package:csslib/visitor.dart'; | 9 import 'package:csslib/visitor.dart'; |
| 10 import 'package:csslib/src/messages.dart'; | 10 import 'package:csslib/src/messages.dart'; |
| 11 | 11 |
| 12 useMockMessages() { | 12 void useMockMessages() { |
| 13 messages = new Messages(printHandler: (message) {}); | 13 messages = new Messages(printHandler: (message) {}); |
| 14 } | 14 } |
| 15 | 15 |
| 16 /** | 16 /** |
| 17 * Spin-up CSS parser in checked mode to detect any problematic CSS. Normally, | 17 * Spin-up CSS parser in checked mode to detect any problematic CSS. Normally, |
| 18 * CSS will allow any property/value pairs regardless of validity; all of our | 18 * CSS will allow any property/value pairs regardless of validity; all of our |
| 19 * tests (by default) will ensure that the CSS is really valid. | 19 * tests (by default) will ensure that the CSS is really valid. |
| 20 */ | 20 */ |
| 21 StyleSheet parseCss(String cssInput, {List errors, List opts}) => | 21 StyleSheet parseCss(String cssInput, {List errors, List opts}) => |
| 22 parse(cssInput, errors: errors, options: opts == null ? | 22 parse(cssInput, errors: errors, options: opts == null ? |
| 23 ['--no-colors', '--checked', '--warnings_as_errors', 'memory'] : opts); | 23 ['--no-colors', '--checked', '--warnings_as_errors', 'memory'] : opts); |
| 24 | 24 |
| 25 /** | 25 /** |
| 26 * Spin-up CSS parser in checked mode to detect any problematic CSS. Normally, | 26 * Spin-up CSS parser in checked mode to detect any problematic CSS. Normally, |
| 27 * CSS will allow any property/value pairs regardless of validity; all of our | 27 * CSS will allow any property/value pairs regardless of validity; all of our |
| 28 * tests (by default) will ensure that the CSS is really valid. | 28 * tests (by default) will ensure that the CSS is really valid. |
| 29 */ | 29 */ |
| 30 StyleSheet compileCss(String cssInput, {List errors, List opts, | 30 StyleSheet compileCss(String cssInput, {List errors, List opts, |
| 31 bool polyfill: false, List<StyleSheet> includes: null}) => | 31 bool polyfill: false, List<StyleSheet> includes: null}) => |
| 32 compile(cssInput, errors: errors, options: opts == null ? | 32 compile(cssInput, errors: errors, options: opts == null ? |
| 33 ['--no-colors', '--checked', '--warnings_as_errors', 'memory'] : opts, | 33 ['--no-colors', '--checked', '--warnings_as_errors', 'memory'] : opts, |
| 34 polyfill: polyfill, includes: includes); | 34 polyfill: polyfill, includes: includes); |
| 35 | 35 |
| 36 StyleSheet polyFillCompileCss(input, {List errors, List opts}) => | 36 StyleSheet polyFillCompileCss(input, {List errors, List opts}) => |
| 37 compileCss(input, errors: errors, polyfill: true, opts: opts); | 37 compileCss(input, errors: errors, polyfill: true, opts: opts); |
| 38 | 38 |
| 39 /** CSS emitter walks the style sheet tree and emits readable CSS. */ | 39 /** CSS emitter walks the style sheet tree and emits readable CSS. */ |
| 40 var _emitCss = new CssPrinter(); | 40 final _emitCss = new CssPrinter(); |
| 41 | 41 |
| 42 /** Simple Visitor does nothing but walk tree. */ | 42 /** Simple Visitor does nothing but walk tree. */ |
| 43 var _cssVisitor = new Visitor(); | 43 final _cssVisitor = new Visitor(); |
| 44 | 44 |
| 45 /** Pretty printer for CSS. */ | 45 /** Pretty printer for CSS. */ |
| 46 String prettyPrint(StyleSheet ss) { | 46 String prettyPrint(StyleSheet ss) { |
| 47 // Walk the tree testing basic Vistor class. | 47 // Walk the tree testing basic Vistor class. |
| 48 walkTree(ss); | 48 walkTree(ss); |
| 49 return (_emitCss..visitTree(ss, pretty: true)).toString(); | 49 return (_emitCss..visitTree(ss, pretty: true)).toString(); |
| 50 } | 50 } |
| 51 | 51 |
| 52 /** | 52 /** |
| 53 * Helper function to emit compact (non-pretty printed) CSS for suite test | 53 * Helper function to emit compact (non-pretty printed) CSS for suite test |
| 54 * comparsions. Spaces, new lines, etc. are reduced for easier comparsions of | 54 * comparsions. Spaces, new lines, etc. are reduced for easier comparsions of |
| 55 * expected suite test results. | 55 * expected suite test results. |
| 56 */ | 56 */ |
| 57 String compactOuptut(StyleSheet ss) { | 57 String compactOuptut(StyleSheet ss) { |
| 58 walkTree(ss); | 58 walkTree(ss); |
| 59 return (_emitCss..visitTree(ss, pretty: false)).toString(); | 59 return (_emitCss..visitTree(ss, pretty: false)).toString(); |
| 60 } | 60 } |
| 61 | 61 |
| 62 /** Walks the style sheet tree does nothing; insures the basic walker works. */ | 62 /** Walks the style sheet tree does nothing; insures the basic walker works. */ |
| 63 void walkTree(StyleSheet ss) { | 63 void walkTree(StyleSheet ss) { |
| 64 _cssVisitor..visitTree(ss); | 64 _cssVisitor..visitTree(ss); |
| 65 } | 65 } |
| 66 | 66 |
| 67 String dumpTree(StyleSheet ss) => treeToDebugString(ss); | 67 String dumpTree(StyleSheet ss) => treeToDebugString(ss); |
| 68 | |
| 69 | |
| OLD | NEW |