Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 import "package:expect/expect.dart"; | 5 import "package:expect/expect.dart"; |
| 6 | 6 |
| 7 void argument() { | 7 void argument() { |
| 8 throw new ArgumentError(499); | 8 throw new ArgumentError(499); |
| 9 } | 9 } |
| 10 | 10 |
|
Bob Nystrom
2017/07/25 22:05:43
Oof, this test is complicated. I believe the inten
jcollins
2017/08/02 21:03:26
Acknowledged.
| |
| 11 void noSuchMethod() { | 11 void noSuchMethod() { |
| 12 (499).doesNotExist(); | 12 (499).doesNotExist(); //# static: compile-time error |
|
Bob Nystrom
2017/07/25 22:05:43
This is still a valid runtime error, but we need t
jcollins
2017/08/02 21:03:26
So, in other words, in Dart 2.0 the only time a ru
Bob Nystrom
2017/08/02 21:12:36
Exactly right.
| |
| 13 } | 13 } |
| 14 | 14 |
| 15 void nullThrown() { | 15 void nullThrown() { |
| 16 throw null; | 16 throw null; |
| 17 } | 17 } |
| 18 | 18 |
| 19 void range() { | 19 void range() { |
| 20 throw new RangeError.range(0, 1, 2); | 20 throw new RangeError.range(0, 1, 2); |
| 21 } | 21 } |
| 22 | 22 |
| 23 void fallThrough() { | 23 void fallThrough() { |
|
Bob Nystrom
2017/07/25 22:05:43
FallThrough errors should not exist at runtime in
| |
| 24 nested() {} | 24 nested() {} |
| 25 | 25 |
| 26 switch (5) { | 26 switch (5) { |
| 27 case 5: | 27 case 5://# static: compile-time error |
| 28 nested(); | 28 nested();//# static: compile-time error |
|
jcollins
2017/08/02 21:03:26
This case has become more interesting once we've p
Bob Nystrom
2017/08/02 21:12:36
In strong mode, that static warning should get pro
| |
| 29 default: | 29 default: |
| 30 Expect.fail("Should not reach"); | 30 Expect.fail("Should not reach"); |
| 31 } | 31 } |
| 32 } | 32 } |
| 33 | 33 |
| 34 abstract class A { | 34 abstract class A { |
| 35 foo(); | 35 foo(); |
| 36 } | 36 } |
| 37 | 37 |
|
Bob Nystrom
2017/07/25 22:05:43
Likewise, there is no AbstractClassInstantiationEr
jcollins
2017/08/02 21:03:26
done
| |
| 38 void abstractClassInstantiation() { | 38 void abstractClassInstantiation() { |
| 39 new A(); | 39 new A();//# static: compile-time error |
| 40 } | 40 } |
| 41 | 41 |
| 42 void unsupported() { | 42 void unsupported() { |
| 43 throw new UnsupportedError("unsupported"); | 43 throw new UnsupportedError("unsupported"); |
| 44 } | 44 } |
| 45 | 45 |
| 46 void unimplemented() { | 46 void unimplemented() { |
| 47 throw new UnimplementedError("unimplemented"); | 47 throw new UnimplementedError("unimplemented"); |
| 48 } | 48 } |
| 49 | 49 |
| 50 void state() { | 50 void state() { |
| 51 return [1, 2].single; | 51 return [1, 2].single;//# static: compile-time error |
|
Bob Nystrom
2017/07/25 22:05:43
As far as I can tell, this shouldn't have a static
jcollins
2017/08/02 21:03:26
This has a static error because the code returns a
Bob Nystrom
2017/08/02 21:12:36
Ha, oh, right.
jcollins
2017/08/03 15:54:18
Making this more minimal makes sense, done.
| |
| 52 } | 52 } |
| 53 | 53 |
| 54 void type() { | 54 void type() { |
| 55 return 1 + "string"; | 55 return 1 + "string";//# static: compile-time error |
|
Bob Nystrom
2017/07/25 22:05:43
I don't believe Dart 2.0 has TypeError. But it *do
jcollins
2017/08/02 21:03:25
Done.
| |
| 56 } | 56 } |
| 57 | 57 |
| 58 main() { | 58 main() { |
| 59 List<Function> errorFunctions = [ | 59 List<Function> errorFunctions = [ |
| 60 argument, | 60 argument, |
| 61 noSuchMethod, | 61 noSuchMethod, //# static: ok |
| 62 nullThrown, | 62 nullThrown, |
| 63 range, | 63 range, |
| 64 fallThrough, | 64 fallThrough, //# static: ok |
| 65 abstractClassInstantiation, | 65 abstractClassInstantiation, //# static: ok |
| 66 unsupported, | 66 unsupported, |
| 67 unimplemented, | 67 unimplemented, |
| 68 state, | 68 state, //# static: ok |
| 69 type | 69 type //# static: ok |
| 70 ]; | 70 ]; |
| 71 | 71 |
| 72 for (var f in errorFunctions) { | 72 for (var f in errorFunctions) { |
| 73 bool hasThrown = false; | 73 bool hasThrown = false; |
| 74 try { | 74 try { |
| 75 f(); | 75 f(); |
| 76 } catch (e) { | 76 } catch (e, stackTrace) { |
| 77 hasThrown = true; | 77 hasThrown = true; |
| 78 Expect.isTrue( | 78 Expect.isTrue( |
| 79 e.stackTrace is StackTrace, "$e doesn't have a non-null stack trace"); | 79 stackTrace is StackTrace, "$e doesn't have a non-null stack trace"); |
|
Bob Nystrom
2017/07/25 22:05:43
I don't think this change is right. My reading is
jcollins
2017/08/02 21:03:26
I had asked around about this and the understandin
Bob Nystrom
2017/08/02 21:12:36
Oh, interesting. I didn't realize there were any A
jcollins
2017/08/03 15:54:18
Since I've already done the work of figuring out w
| |
| 80 } | 80 } |
| 81 Expect.isTrue(hasThrown); | 81 Expect.isTrue(hasThrown); |
| 82 } | 82 } |
| 83 } | 83 } |
| OLD | NEW |