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

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

Issue 8273004: Implement removeRange, and update some documentation on the list interface. (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
Index: tests/corelib/src/ListRemoveRangeTest.dart
===================================================================
--- tests/corelib/src/ListRemoveRangeTest.dart (revision 0)
+++ tests/corelib/src/ListRemoveRangeTest.dart (revision 0)
@@ -0,0 +1,66 @@
+// 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() {
+ var list = [];
+ list.removeRange(0, 0);
+ Expect.equals(0, list.length);
+ expectIOORE(() { list.removeRange(0, 1); });
+
+ list.add(1);
+ list.removeRange(0, 0);
+ Expect.equals(1, list.length);
+ Expect.equals(1, list[0]);
+
+ expectIOORE(() { list.removeRange(0, 2); });
+ Expect.equals(1, list.length);
+ Expect.equals(1, list[0]);
+
+ list.removeRange(0, 1);
+ Expect.equals(0, list.length);
+
+ list.addAll([3, 4, 5, 6]);
+ Expect.equals(4, list.length);
+ list.removeRange(0, 4);
+ Expect.listEquals([], list);
+
+ list.addAll([3, 4, 5, 6]);
+ list.removeRange(2, 2);
+ Expect.listEquals([3, 4], list);
+ list.addAll([5, 6]);
+
+ expectIOORE(() { list.removeRange(4, 1); });
+ Expect.listEquals([3, 4, 5, 6], list);
+
+ list.removeRange(1, 2);
+ Expect.listEquals([3, 6], list);
+
+ testNegativeIndices();
+}
+
+void expectIOORE(Function f) {
+ Expect.throws(f, (e) => e is IndexOutOfRangeException);
+}
+
+void testNegativeIndices() {
+ var list = [1, 2];
+ expectIOORE(() { list.removeRange(-1, 1); });
+ Expect.listEquals([1, 2], list);
+
+ // A negative length throws an IllegalArgumentException.
+ Expect.throws(() { list.removeRange(0, -1); },
+ (e) => e is IllegalArgumentException);
+ Expect.listEquals([1, 2], list);
+
+ Expect.throws(() { list.removeRange(-1, -1); },
+ (e) => e is IllegalArgumentException);
+ Expect.listEquals([1, 2], list);
+
+ // A zero length prevails, and does not throw an exception.
+ list.removeRange(-1, 0);
+ Expect.listEquals([1, 2], list);
+
+ list.removeRange(4, 0);
+ Expect.listEquals([1, 2], list);
+}

Powered by Google App Engine
This is Rietveld 408576698