Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(103)

Unified Diff: tests/language/regex/negative-special-characters_test.dart

Issue 539153002: Port and integrate the irregexp engine from V8 (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Addressed Ivan's comments. Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tests/language/regex/multiline_test.dart ('k') | tests/language/regex/no-extensions_test.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/language/regex/negative-special-characters_test.dart
diff --git a/tests/language/regex/negative-special-characters_test.dart b/tests/language/regex/negative-special-characters_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..98e19ed53e00267ff4e3cf557f2dd8c4dc75be88
--- /dev/null
+++ b/tests/language/regex/negative-special-characters_test.dart
@@ -0,0 +1,75 @@
+// Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
+// for details. All rights reserved. Use of this source code is governed by a
+// BSD-style license that can be found in the LICENSE file.
+
+import 'util.dart';
+import 'package:expect/expect.dart';
+
+void main() {
+ description(
+ "This test checks Unicode in negative RegExp character classes."
+ );
+
+ dynamic testPassed(str) { }
+ dynamic testFailed(str) => Expect.fail(str);
+
+ dynamic test(pattern, str, expected_length) {
+ var result = str.replaceAll(new RegExp(pattern, caseSensitive: false, multiLine: true), '');
+
+ if (result.length == expected_length)
+ testPassed('"' + pattern + '", ' + '"' + str + '".');
+ else
+ testFailed('"' + pattern + '", ' + '"' + str + '". Was "' + result + '".');
+ }
+
+
+ test("\\s", " \t\f\v\r\n", 0); // ASCII whitespace.
+ test("\\S", "Проверка", 0); // Cyrillic letters are non-whitespace...
+ test("\\s", "Проверка", 8); // ...and they aren't whitespace.
+ test("[\\s]", "Проверка", 8);
+ test("[\\S]", "Проверка", 0);
+ test("[^\\s]", "Проверка", 0);
+ test("[^\\S]", "Проверка", 8);
+ test("[\\s\\S]*", "\\u2002Проверка\\r\\n\\u00a0", 0);
+ test("\\S\\S", "уф", 0);
+ test("\\S{2}", "уф", 0);
+
+ test("\\w", "Проверка", 8); // Alas, only ASCII characters count as word ones in JS.
+ test("\\W", "Проверка", 0);
+ test("[\\w]", "Проверка", 8);
+ test("[\\W]", "Проверка", 0);
+ test("[^\\w]", "Проверка", 0);
+ test("[^\\W]", "Проверка", 8);
+ test("\\W\\W", "уф", 0);
+ test("\\W{2}", "уф", 0);
+
+ test("\\d", "Проверка", 8); // Digit and non-digit.
+ test("\\D", "Проверка", 0);
+ test("[\\d]", "Проверка", 8);
+ test("[\\D]", "Проверка", 0);
+ test("[^\\d]", "Проверка", 0);
+ test("[^\\D]", "Проверка", 8);
+ test("\\D\\D", "уф", 0);
+ test("\\D{2}", "уф", 0);
+
+ test("[\\S\\d]", "Проверка123", 0);
+ test("[\\d\\S]", "Проверка123", 0);
+ test("[^\\S\\d]", "Проверка123", 11);
+ test("[^\\d\\S]", "Проверка123", 11);
+
+ test("[ \\S]", " Проверка ", 0);
+ test("[\\S ]", " Проверка ", 0);
+ test("[ф \\S]", " Проверка ", 0);
+ test("[\\Sф ]", " Проверка ", 0);
+
+ test("[^р\\S]", " Проверка ", 8);
+ test("[^\\Sр]", " Проверка ", 8);
+ test("[^р\\s]", " Проверка ", 4);
+ test("[^\\sр]", " Проверка ", 4);
+
+ test("[ф \\s\\S]", "Проверка \\r\\n", 0);
+ test("[\\S\\sф ]", "Проверка \\r\\n", 0);
+
+ test("[^z]", "Проверка \\r\\n", 0);
+ test("[^ф]", "Проверка \\r\\n", 0);
+}
« no previous file with comments | « tests/language/regex/multiline_test.dart ('k') | tests/language/regex/no-extensions_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698