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

Unified Diff: tests/corelib/int_parse_radix_test.dart

Issue 11783009: Big merge from experimental to bleeding edge. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 11 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/corelib/indexed_list_access_test.dart ('k') | tests/corelib/iterable_element_at_test.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/corelib/int_parse_radix_test.dart
diff --git a/tests/corelib/int_parse_radix_test.dart b/tests/corelib/int_parse_radix_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..a59ee600875b07b677bbfed7491ca34804145189
--- /dev/null
+++ b/tests/corelib/int_parse_radix_test.dart
@@ -0,0 +1,88 @@
+// Copyright (c) 2012, 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.
+
+void main() {
+ bool checkedMode = false;
+ assert(checkedMode = true);
+
+ for (int i = 0; i < 36 * 36 + 1; i++) {
+ for (int r = 2; r <= 36; r++) {
+ String radixString = i.toRadixString(r);
+ Expect.equals(i, int.parse(radixString, radix: r), "");
+ Expect.equals(i, int.parse(" $radixString", radix: r), "");
+ Expect.equals(i, int.parse("$radixString ", radix: r), "");
+ Expect.equals(i, int.parse(" $radixString ", radix: r), "");
+ Expect.equals(i, int.parse("+$radixString", radix: r), "");
+ Expect.equals(i, int.parse(" +$radixString", radix: r), "");
+ Expect.equals(i, int.parse("+$radixString ", radix: r), "");
+ Expect.equals(i, int.parse(" +$radixString ", radix: r), "");
+ Expect.equals(-i, int.parse("-$radixString", radix: r), "");
+ Expect.equals(-i, int.parse(" -$radixString", radix: r), "");
+ Expect.equals(-i, int.parse("-$radixString ", radix: r), "");
+ Expect.equals(-i, int.parse(" -$radixString ", radix: r), "");
+ }
+ }
+ // Allow both upper- and lower-case letters.
+ Expect.equals(0xABCD, int.parse("ABCD", radix: 16));
+ Expect.equals(0xABCD, int.parse("abcd", radix: 16));
+ Expect.equals(15628859, int.parse("09azAZ", radix: 36));
+
+ // Allow whitespace before and after the number.
+ Expect.equals(1, int.parse(" 1", radix: 2));
+ Expect.equals(1, int.parse("1 ", radix: 2));
+ Expect.equals(1, int.parse(" 1 ", radix: 2));
+ Expect.equals(1, int.parse("\n1", radix: 2));
+ Expect.equals(1, int.parse("1\n", radix: 2));
+ Expect.equals(1, int.parse("\n1\n", radix: 2));
+ Expect.equals(1, int.parse("+1", radix: 2));
+
+ void testFails(String source, int radix) {
+ Expect.throws(() { throw int.parse(source, radix: radix,
+ onError: (s) { throw "FAIL"; }); },
+ (e) => e == "FAIL",
+ "$source/$radix");
+ Expect.equals(-999, int.parse(source, radix: radix, onError: (s) => -999));
+ }
+ for (int i = 2; i < 36; i++) {
+ testFails(i.toRadixString(36), i);
+ }
+ testFails("", 2);
+ testFails("0x10", 16); // No 0x specially allowed.
+ testFails("+ 1", 2); // No space between sign and digits.
+ testFails("- 1", 2); // No space between sign and digits.
+
+ testBadTypes(var source, var radix) {
+ if (!checkedMode) {
+ // No promises on what error is thrown if the type doesn't match.
+ // Likely either ArgumentError or NoSuchMethodError.
+ Expect.throws(() => int.parse(source, radix: radix, onError: (s) => 0));
+ return;
+ }
+ // In checked mode, it's always a TypeError.
+ Expect.throws(() => int.parse(source, radix: radix, onError: (s) => 0),
+ (e) => e is TypeError);
+ }
+
+ testBadTypes(9, 10);
+ testBadTypes(true, 10);
+ testBadTypes("0", true);
+ testBadTypes("0", "10");
+
+ testBadArguments(String source, int radix) {
+ // If the types match, it should be an ArgumentError of some sort.
+ Expect.throws(() => int.parse(source, radix: radix, onError: (s) => 0),
+ (e) => e is ArgumentError);
+ }
+
+ testBadArguments("0", -1);
+ testBadArguments("0", 0);
+ testBadArguments("0", 1);
+ testBadArguments("0", 37);
+
+ // If handleError isn't an unary function, and it's called, it also throws
+ // (either TypeError in checked mode, or some failure in unchecked mode).
+ Expect.throws(() => int.parse("9", radix: 8, onError: "not a function"));
+ Expect.throws(() => int.parse("9", radix: 8, onError: () => 42));
+ Expect.throws(() => int.parse("9", radix: 8, onError: (v1, v2) => 42));
+}
« no previous file with comments | « tests/corelib/indexed_list_access_test.dart ('k') | tests/corelib/iterable_element_at_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698