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

Unified Diff: tests/corelib/src/ListGetRangeTest.dart

Issue 8276005: Implement List.getRange. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: '' Created 9 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 | « runtime/lib/growable_array.dart ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/corelib/src/ListGetRangeTest.dart
===================================================================
--- tests/corelib/src/ListGetRangeTest.dart (revision 0)
+++ tests/corelib/src/ListGetRangeTest.dart (revision 0)
@@ -0,0 +1,45 @@
+// Copyright (c) 2011, 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.
+
+main() {
+ Expect.listEquals([], [].getRange(0, 0));
+ Expect.listEquals([], const [].getRange(0, 0));
+
+ Expect.listEquals([], [].getRange(-1, 0));
+ Expect.listEquals([], const [].getRange(-1, 0));
+
+ Expect.listEquals([1, 2], [1, 2].getRange(0, 2));
+ Expect.listEquals([1, 2], const [1, 2].getRange(0, 2));
+
+ Expect.listEquals([1], [1, 2].getRange(0, 1));
+ Expect.listEquals([1], const [1, 2].getRange(0, 1));
+
+ Expect.listEquals([2], [1, 2].getRange(1, 1));
+ Expect.listEquals([2], const [1, 2].getRange(1, 1));
+
+ Expect.listEquals([], [1, 2].getRange(0, 0));
+ Expect.listEquals([], const [1, 2].getRange(0, 0));
+
+ Expect.listEquals([2, 3], [1, 2, 3, 4].getRange(1, 2));
+ Expect.listEquals([2, 3], const [1, 2, 3, 4].getRange(1, 2));
+
+ Expect.listEquals([2, 3], [1, 2, 3, 4].getRange(1, 2));
+ Expect.listEquals([2, 3], const [1, 2, 3, 4].getRange(1, 2));
+
+ expectIAE(() => [].getRange(0, -1));
+ expectIAE(() => const [].getRange(-1, -1));
+
+ expectIOORE(() => [].getRange(-1, 1));
+ expectIOORE(() => [].getRange(1, 1));
+ expectIOORE(() => [1].getRange(0, 2));
+ expectIOORE(() => [1].getRange(1, 1));
+}
+
+void expectIOORE(Function f) {
+ Expect.throws(f, (e) => e is IndexOutOfRangeException);
+}
+
+void expectIAE(Function f) {
+ Expect.throws(f, (e) => e is IllegalArgumentException);
+}
« no previous file with comments | « runtime/lib/growable_array.dart ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698