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

Side by Side Diff: tests/language/arithmetic2_test.dart

Issue 11415028: Remove NullPointerException. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Fixed VM bugs. Created 8 years, 1 month 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, 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 // Dart test program to test arithmetic operations. 4 // Dart test program to test arithmetic operations.
5 // @static-clean 5 // @static-clean
6 6
7 class A { 7 class A {
8 static foo() => 499; 8 static foo() => 499;
9 } 9 }
10 10
11 bool throwsNoSuchMethod(f) { 11 bool throwsNoSuchMethod(f) {
12 try { 12 try {
13 f(); 13 f();
14 return false; 14 return false;
15 } on NoSuchMethodError catch (e) { 15 } on NoSuchMethodError catch (e) {
16 return true; 16 return true;
17 } 17 }
18 return false; 18 return false;
19 } 19 }
20 20
21 bool throwsBecauseOfBadArgument(f) { 21 bool throwsBecauseOfBadArgument(f) {
22 try { 22 try {
23 f(); 23 f();
24 return false; 24 return false;
25 } on NoSuchMethodError catch (e) { 25 } on NoSuchMethodError catch (e) {
26 return true; 26 return true;
27 } on ArgumentError catch (e) { 27 } on ArgumentError catch (e) {
28 return true; 28 return true;
29 } on NullPointerException catch (e) {
30 return true;
31 } on TypeError catch (e) { 29 } on TypeError catch (e) {
32 // In type checked mode. 30 // In type checked mode.
33 return true; 31 return true;
34 } 32 }
35 return false; 33 return false;
36 } 34 }
37 35
38 numberOpBadSecondArgument(f) { 36 numberOpBadSecondArgument(f) {
39 Expect.isTrue(throwsBecauseOfBadArgument(() => f(true))); 37 Expect.isTrue(throwsBecauseOfBadArgument(() => f(true)));
40 Expect.isTrue(throwsBecauseOfBadArgument(() => f(new A()))); 38 Expect.isTrue(throwsBecauseOfBadArgument(() => f(new A())));
(...skipping 24 matching lines...) Expand all
65 numberOpBadSecondArgument((x) => 3 - x); 63 numberOpBadSecondArgument((x) => 3 - x);
66 numberOpBadSecondArgument((x) => 3 * x); 64 numberOpBadSecondArgument((x) => 3 * x);
67 numberOpBadSecondArgument((x) => 3 / x); 65 numberOpBadSecondArgument((x) => 3 / x);
68 numberOpBadSecondArgument((x) => 3 ~/ x); 66 numberOpBadSecondArgument((x) => 3 ~/ x);
69 numberOpBadSecondArgument((x) => 3 % x); 67 numberOpBadSecondArgument((x) => 3 % x);
70 badOperations(true); 68 badOperations(true);
71 badOperations(false); 69 badOperations(false);
72 badOperations(() => 499); 70 badOperations(() => 499);
73 badOperations(A.foo); 71 badOperations(A.foo);
74 } 72 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698