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

Unified Diff: tests/corelib/expando_test.dart

Issue 10534089: Add experimental expando support. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Fix comment and merge. Created 8 years, 6 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/expando_test.dart
diff --git a/tests/corelib/expando_test.dart b/tests/corelib/expando_test.dart
new file mode 100644
index 0000000000000000000000000000000000000000..73a65a411ecf4f5135748a8cbaa825fc0cbf164d
--- /dev/null
+++ b/tests/corelib/expando_test.dart
@@ -0,0 +1,110 @@
+// 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.
+
+final Expando<int> visits = const Expando<int>('visits');
+
+main() {
+ var legal = [ new Object(),
+ new List(), [1,2,3], const [1,2,3],
+ new Map(), {'x':1,'y':2}, const {'x':1,'y':2},
+ new Expando(), new Expando('horse') ];
+ for (var object in legal) {
+ testNamedExpando(object);
+ testUnnamedExpando(object);
+ testConstExpando(object);
+ }
+ for (var object in legal) {
+ Expect.equals(3, visits[object]);
+ }
+ testIllegal();
+}
+
+visit(object) {
+ int count = visits[object];
+ count = (count === null) ? 1 : count + 1;
+ visits[object] = count;
+}
+
+testNamedExpando(object) {
+ Expando<int> expando = new Expando<int>('myexpando');
+ Expect.equals('myexpando', expando.name);
+ Expect.isTrue(expando.toString().startsWith('Expando:myexpando'));
+ testExpando(expando, object);
+}
+
+testUnnamedExpando(object) {
+ Expando<int> expando = new Expando<int>();
+ Expect.isNull(expando.name);
+ Expect.isTrue(expando.toString().startsWith('Expando:'));
+ testExpando(expando, object);
+}
+
+testExpando(Expando<int> expando, object) {
+ visit(object);
+
+ Expect.isNull(expando[object]);
+ expando[object] = 42;
+ Expect.equals(42, expando[object]);
+ expando[object] = null;
+ Expect.isNull(expando[object]);
+
+ Expando<int> alternative = new Expando('myexpando');
+ Expect.isNull(alternative[object]);
+ alternative[object] = 87;
+ Expect.isNull(expando[object]);
+ expando[object] = 99;
+ Expect.equals(99, expando[object]);
+ Expect.equals(87, alternative[object]);
+}
+
+testConstExpando(object) {
+ visit(object);
+
+ var e0 = const Expando<int>('horse');
sra1 2012/06/12 07:10:26 Add 'difficult' names: 'prototype' 'toString' '__p
+ var e1 = const Expando<int>('horse');
+ var e2 = new Expando<int>('horse');
+ var e3 = new Expando<int>('horse');
+
+ e0[object] = 0;
+ Expect.equals(0, e0[object]);
+
+ e1[object] = 1;
+ Expect.equals(1, e0[object]);
+ Expect.equals(1, e1[object]);
+
+ e2[object] = 2;
+ Expect.equals(1, e0[object]);
+ Expect.equals(1, e1[object]);
+ Expect.equals(2, e2[object]);
+
+ e3[object] = 3;
+ Expect.equals(1, e0[object]);
+ Expect.equals(1, e1[object]);
+ Expect.equals(2, e2[object]);
+ Expect.equals(3, e3[object]);
+
+ e0[object] = null;
+ Expect.isNull(e0[object]);
+ Expect.isNull(e1[object]);
+ Expect.equals(2, e2[object]);
+ Expect.equals(3, e3[object]);
+}
+
+testIllegal() {
sra1 2012/06/12 07:10:26 Illegal cases make the Expando API difficult to us
+ Expando<int> expando = new Expando<int>();
+ Expect.throws(() => expando[null], (exception)
+ => exception is NullPointerException);
+ Expect.throws(() => expando['string'], (exception)
+ => exception is IllegalArgumentException);
+ Expect.throws(() => expando['string'], (exception)
+ => exception is IllegalArgumentException);
+ Expect.throws(() => expando[42], (exception)
+ => exception is IllegalArgumentException);
+ Expect.throws(() => expando[42.87], (exception)
+ => exception is IllegalArgumentException);
+ Expect.throws(() => expando[true], (exception)
+ => exception is IllegalArgumentException);
+ Expect.throws(() => expando[false], (exception)
+ => exception is IllegalArgumentException);
+}
« lib/compiler/implementation/lib/js_helper.dart ('K') | « tests/corelib/corelib.status ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698