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

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

Issue 11417058: Revert "Remove NullPointerException." (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: 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
« no previous file with comments | « tests/corelib/reg_exp5_test.dart ('k') | tests/language/call_through_null_getter_test.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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;
29 } on TypeError catch (e) { 31 } on TypeError catch (e) {
30 // In type checked mode. 32 // In type checked mode.
31 return true; 33 return true;
32 } 34 }
33 return false; 35 return false;
34 } 36 }
35 37
36 numberOpBadSecondArgument(f) { 38 numberOpBadSecondArgument(f) {
37 Expect.isTrue(throwsBecauseOfBadArgument(() => f(true))); 39 Expect.isTrue(throwsBecauseOfBadArgument(() => f(true)));
38 Expect.isTrue(throwsBecauseOfBadArgument(() => f(new A()))); 40 Expect.isTrue(throwsBecauseOfBadArgument(() => f(new A())));
(...skipping 24 matching lines...) Expand all
63 numberOpBadSecondArgument((x) => 3 - x); 65 numberOpBadSecondArgument((x) => 3 - x);
64 numberOpBadSecondArgument((x) => 3 * x); 66 numberOpBadSecondArgument((x) => 3 * x);
65 numberOpBadSecondArgument((x) => 3 / x); 67 numberOpBadSecondArgument((x) => 3 / x);
66 numberOpBadSecondArgument((x) => 3 ~/ x); 68 numberOpBadSecondArgument((x) => 3 ~/ x);
67 numberOpBadSecondArgument((x) => 3 % x); 69 numberOpBadSecondArgument((x) => 3 % x);
68 badOperations(true); 70 badOperations(true);
69 badOperations(false); 71 badOperations(false);
70 badOperations(() => 499); 72 badOperations(() => 499);
71 badOperations(A.foo); 73 badOperations(A.foo);
72 } 74 }
OLDNEW
« no previous file with comments | « tests/corelib/reg_exp5_test.dart ('k') | tests/language/call_through_null_getter_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698