Index: packages/quiver/test/pattern/pattern_test.dart |
diff --git a/packages/quiver/test/pattern/pattern_test.dart b/packages/quiver/test/pattern/pattern_test.dart |
new file mode 100644 |
index 0000000000000000000000000000000000000000..54f8b86e55fd3294a62ab3bee1cef46a1e953938 |
--- /dev/null |
+++ b/packages/quiver/test/pattern/pattern_test.dart |
@@ -0,0 +1,79 @@ |
+// Copyright 2013 Google Inc. All Rights Reserved. |
+// |
+// Licensed under the Apache License, Version 2.0 (the "License"); |
+// you may not use this file except in compliance with the License. |
+// You may obtain a copy of the License at |
+// |
+// http://www.apache.org/licenses/LICENSE-2.0 |
+// |
+// Unless required by applicable law or agreed to in writing, software |
+// distributed under the License is distributed on an "AS IS" BASIS, |
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
+// See the License for the specific language governing permissions and |
+// limitations under the License. |
+ |
+library quiver.pattern_test; |
+ |
+import 'package:test/test.dart'; |
+import 'package:quiver/pattern.dart'; |
+ |
+final _specialChars = r'\^$.|+[](){}'; |
+ |
+main() { |
+ group('escapeRegex', () { |
+ test('should escape special characters', () { |
+ for (var c in _specialChars.split('')) { |
+ expect(escapeRegex(c), '\\$c'); |
+ } |
+ }); |
+ }); |
+ |
+ group('matchesAny', () { |
+ test('should match multiple include patterns', () { |
+ expectMatch(matchAny(['a', 'b']), 'a', 0, ['a']); |
+ expectMatch(matchAny(['a', 'b']), 'b', 0, ['b']); |
+ }); |
+ |
+ test('should match multiple include patterns (non-zero start)', () { |
+ expectMatch(matchAny(['a', 'b']), 'ba', 1, ['a']); |
+ expectMatch(matchAny(['a', 'b']), 'aab', 2, ['b']); |
+ }); |
+ |
+ test('should return multiple matches', () { |
+ expectMatch(matchAny(['a', 'b']), 'ab', 0, ['a', 'b']); |
+ }); |
+ |
+ test('should return multiple matches (non-zero start)', () { |
+ expectMatch(matchAny(['a', 'b', 'c']), 'cab', 1, ['a', 'b']); |
+ }); |
+ |
+ test('should exclude', () { |
+ expectMatch( |
+ matchAny(['foo', 'bar'], exclude: ['foobar']), 'foobar', 0, []); |
+ }); |
+ |
+ test('should exclude (non-zero start)', () { |
+ expectMatch( |
+ matchAny(['foo', 'bar'], exclude: ['foobar']), 'xyfoobar', 2, []); |
+ }); |
+ }); |
+ |
+ group('matchesFull', () { |
+ test('should match a string', () { |
+ expect(matchesFull('abcd', 'abcd'), true); |
+ expect(matchesFull(new RegExp('a.*d'), 'abcd'), true); |
+ }); |
+ |
+ test('should return false for a partial match', () { |
+ expect(matchesFull('abc', 'abcd'), false); |
+ expect(matchesFull('bcd', 'abcd'), false); |
+ expect(matchesFull(new RegExp('a.*c'), 'abcd'), false); |
+ expect(matchesFull(new RegExp('b.*d'), 'abcd'), false); |
+ }); |
+ }); |
+} |
+ |
+expectMatch(Pattern pattern, String str, int start, List<String> matches) { |
+ var actual = pattern.allMatches(str, start).map((m) => m.group(0)).toList(); |
+ expect(actual, matches); |
+} |