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

Unified Diff: tests/compiler/dart2js/setlet_test.dart

Issue 27510002: Add a much simplified set implementation designed to waste little memory for small sets. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 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/compiler/dart2js/setlet_test.dart
diff --git a/tests/compiler/dart2js/setlet_test.dart b/tests/compiler/dart2js/setlet_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..7e58a6255a4bc51d76cfb8524ce0faaf04f92fc0
--- /dev/null
+++ b/tests/compiler/dart2js/setlet_test.dart
@@ -0,0 +1,60 @@
+// Copyright (c) 2013, 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 "package:expect/expect.dart";
+import '../../../sdk/lib/_internal/compiler/implementation/util/setlet.dart';
+
+main() {
+ for (int i = 1; i <= 32; i++) {
+ test(i);
+ }
+}
+
+test(int size) {
+ var setlet = new Setlet();
+ for (int i = 0; i < size; i++) {
+ Expect.isTrue(setlet.isEmpty == (i == 0));
+ setlet.add(i);
+ Expect.equals(i + 1, setlet.length);
+ Expect.isFalse(setlet.isEmpty);
+ for (int j = 0; j < size + size; j++) {
+ Expect.isTrue(setlet.contains(j) == (j <= i));
+ }
+ Expect.isTrue(setlet.remove(i));
+ Expect.isFalse(setlet.remove(i + 1));
+ setlet.add(i);
+
+ List expectedElements = [];
+ for (int j = 0; j <= i; j++) expectedElements.add(j);
+
+ List actualElements = [];
+ setlet.forEach((each) => actualElements.add(each));
+ Expect.listEquals(expectedElements, actualElements);
+
+ actualElements = [];
+ for (var each in setlet) actualElements.add(each);
+ Expect.listEquals(expectedElements, actualElements);
+ }
+
+ for (int i = 0; i < size; i++) {
+ Expect.equals(size, setlet.length);
+
+ // Try removing all possible ranges one by one and re-add them.
+ for (int k = size; k > i; --k) {
+ for (int j = i; j < k; j++) {
+ Expect.isTrue(setlet.remove(j));
+ Expect.equals(size - (j - i + 1), setlet.length);
+ Expect.isFalse(setlet.remove(j));
+ Expect.isFalse(setlet.contains(j));
+ }
+
+ for (int j = i; j < k; j++) {
+ setlet.add(j);
+ }
+ }
+
+ Expect.equals(size, setlet.length);
+ Expect.isTrue(setlet.contains(i));
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698