Index: tests/language_2/class_literal_test.dart |
diff --git a/tests/language_2/class_literal_test.dart b/tests/language_2/class_literal_test.dart |
index 8ce3560b0ef215b2b8fcf339b5d846004222975d..b532c297ff6d904d82c5ce63ccab07606aa760f2 100644 |
--- a/tests/language_2/class_literal_test.dart |
+++ b/tests/language_2/class_literal_test.dart |
@@ -18,39 +18,50 @@ main() { |
// Verify references to a class literal are allowed. |
Class; |
+ var x = Class; |
foo(Class); |
Expect.isFalse(Class == null); |
- dynamic x = Class; |
- |
- // Verify that dereferencing a class literal is a runtime error. |
- Expect.throws(() { x(); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { x[0]; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { var y = x[0]; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { var y = x[0].field; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { var y = x[0].method(); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { foo(x()); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { foo(x[0]); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { foo(x[0].field); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { foo(x[0].method()); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { x[0] = 91; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { x++; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { ++x; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { x[0] += 3; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { ++x[0]; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { x[0]++; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { x.method(); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { x.field; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { var y = x.method(); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { var y = x.field; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { foo(x.method()); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { foo(x.field); }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { x / 3; }, (e) => e is NoSuchMethodError); |
- Expect.throws(() { x += 3; }, (e) => e is NoSuchMethodError); |
+ |
+ // Verify that dereferencing a class literal is a compile-time error. |
+ // TODO(jcollins-g): several tests here seem to depend on being in their |
+ // own namespace, but others do not. More tests seem to also depend on |
+ // the complexities of Expect.throws() for other, unknown reasons to trigger |
+ // bugs in the VM as of this writing. |
+ // |
+ // Remove the legacy Expect.throws and namespaces around statements that don't |
+ // need it after a careful examination of each case. |
+ Expect.throws(() { Class(); }, (e) => e is NoSuchMethodError); //# 01: compile-time error |
+ Expect.throws(() { Class[0]; }, (e) => e is NoSuchMethodError); //# 02: compile-time error |
+ Expect.throws(() { var x = Class();}, (e) => e is NoSuchMethodError); //# 03: compile-time error |
+ Expect.throws(() { var x = Class[0]; }, (e) => e is NoSuchMethodError); //# 04: compile-time error |
+ Expect.throws(() { var x = Class[0].field; }, (e) => e is NoSuchMethodError); //# 05: compile-time error |
+ Expect.throws(() { var x = Class[0].method(); }, (e) => e is NoSuchMethodError); //# 06: compile-time error |
+ Expect.throws(() { foo(Class()); }, (e) => e is NoSuchMethodError); //# 07: compile-time error |
+ Expect.throws(() { foo(Class[0]); }, (e) => e is NoSuchMethodError); //# 08: compile-time error |
+ Expect.throws(() { foo(Class[0].field); }, (e) => e is NoSuchMethodError); //# 09: compile-time error |
+ Expect.throws(() { foo(Class[0].method()); }, (e) => e is NoSuchMethodError); //# 10: compile-time error |
+ Expect.throws(() { Class[0] = 91; }, (e) => e is NoSuchMethodError); //# 11: compile-time error |
+ Expect.throws(() { Class++; }, (e) => e is NoSuchMethodError); //# 12: compile-time error |
+ Expect.throws(() { ++Class; }, (e) => e is NoSuchMethodError); //# 13: compile-time error |
+ Expect.throws(() { Class[0] += 3; }, (e) => e is NoSuchMethodError); //# 14: compile-time error |
+ Expect.throws(() { ++Class[0]; }, (e) => e is NoSuchMethodError); //# 15: compile-time error |
+ Expect.throws(() { Class[0]++; }, (e) => e is NoSuchMethodError); //# 16: compile-time error |
+ Expect.throws(() { Class.method(); }, (e) => e is NoSuchMethodError); //# 17: compile-time error |
+ Expect.throws(() { Class.field; }, (e) => e is NoSuchMethodError); //# 18: compile-time error |
+ Expect.throws(() { var x = Class.method(); }, (e) => e is NoSuchMethodError); //# 19: compile-time error |
+ Expect.throws(() { var x = Class.field; }, (e) => e is NoSuchMethodError); //# 20: compile-time error |
+ Expect.throws(() { foo(Class.method()); }, (e) => e is NoSuchMethodError); //# 21: compile-time error |
+ Expect.throws(() { foo(Class.field); }, (e) => e is NoSuchMethodError); //# 22: compile-time error |
+ Expect.throws(() { Class / 3; }, (e) => e is NoSuchMethodError); //# 23: compile-time error |
+ Expect.throws(() { Class += 3; }, (e) => e is NoSuchMethodError); //# 24: compile-time error |
// Verify that a class literal isn't a string literal. |
Expect.notEquals(Class, "Class"); |
// Verify toString() works for class literals. |
Expect.isTrue((Class).toString() is String); |
- Expect.isTrue(x.toString() is String); |
+ var y = Class; |
+ Expect.isTrue(y.toString() is String); |
+ |
+ Expect.throws(() { Class.toString(); }, (e) => e is NoSuchMethodError); //# 25: compile-time error |
} |