| OLD | NEW |
| 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2015, 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 "dart:async"; | 5 import "dart:async"; |
| 6 | 6 |
| 7 import "package:expect/expect.dart"; | 7 import "package:expect/expect.dart"; |
| 8 import "package:async_helper/async_helper.dart"; | 8 import "package:async_helper/async_helper.dart"; |
| 9 | 9 |
| 10 class Tracer { | 10 class Tracer { |
| 11 final String expected; | 11 final String expected; |
| 12 final String name; | 12 final String name; |
| 13 String _trace = ""; | 13 String _trace = ""; |
| 14 | 14 |
| 15 Tracer(this.expected, [this.name]); | 15 Tracer(this.expected, [this.name]); |
| 16 | 16 |
| 17 void trace(msg) { | 17 void trace(msg) { |
| 18 if (name != null) { | 18 if (name != null) { |
| 19 print("Tracing $name: $msg"); | 19 print("Tracing $name: $msg"); |
| 20 } | 20 } |
| 21 _trace += msg; | 21 _trace += msg; |
| 22 } | 22 } |
| 23 | 23 |
| 24 void done() { | 24 void done() { |
| 25 Expect.equals(expected, _trace); | 25 Expect.equals(expected, _trace); |
| 26 } | 26 } |
| 27 } | 27 } |
| 28 | 28 |
| 29 test1(Tracer tracer) { | 29 test1(Tracer tracer) { |
| 30 foo() async | 30 foo() async* |
| 31 * /// asyncStar: ok | 31 |
| 32 { | 32 /// asyncStar: ok |
| 33 { |
| 33 var savedStackTrace; | 34 var savedStackTrace; |
| 34 try { | 35 try { |
| 35 try { | 36 try { |
| 36 tracer.trace("a"); | 37 tracer.trace("a"); |
| 37 throw "Error"; | 38 throw "Error"; |
| 38 } catch (e, st) { | 39 } catch (e, st) { |
| 39 tracer.trace("b"); | 40 tracer.trace("b"); |
| 40 savedStackTrace = st; | 41 savedStackTrace = st; |
| 41 } | 42 } |
| 42 tracer.trace("c"); | 43 tracer.trace("c"); |
| 43 await new Future.error("Error 2", savedStackTrace); | 44 await new Future.error("Error 2", savedStackTrace); |
| 44 tracer.trace("d"); | 45 tracer.trace("d"); |
| 45 } catch (e, st) { | 46 } catch (e, st) { |
| 46 tracer.trace("e"); | 47 tracer.trace("e"); |
| 47 Expect.equals(savedStackTrace.toString(), st.toString()); | 48 Expect.equals(savedStackTrace.toString(), st.toString()); |
| 48 } | 49 } |
| 49 tracer.trace("f"); | 50 tracer.trace("f"); |
| 50 } | 51 } |
| 51 return foo() | 52 return foo().toList() |
| 52 .toList() /// asyncStar: continued | 53 |
| 53 ; | 54 /// asyncStar: continued |
| 55 ; |
| 54 } | 56 } |
| 55 | 57 |
| 56 test2(Tracer tracer) { | 58 test2(Tracer tracer) { |
| 57 var savedStackTrace; | 59 var savedStackTrace; |
| 58 foo() async | 60 foo() async* |
| 59 * /// asyncStar: continued | 61 |
| 60 { | 62 /// asyncStar: continued |
| 63 { |
| 61 try { | 64 try { |
| 62 tracer.trace("a"); | 65 tracer.trace("a"); |
| 63 throw "Error"; | 66 throw "Error"; |
| 64 } catch (e, st) { | 67 } catch (e, st) { |
| 65 tracer.trace("b"); | 68 tracer.trace("b"); |
| 66 savedStackTrace = st; | 69 savedStackTrace = st; |
| 67 } | 70 } |
| 68 tracer.trace("c"); | 71 tracer.trace("c"); |
| 69 await new Future.error("Error 2", savedStackTrace); | 72 await new Future.error("Error 2", savedStackTrace); |
| 70 tracer.trace("d"); | 73 tracer.trace("d"); |
| 71 } | 74 } |
| 72 return foo() | 75 return foo().toList() |
| 73 .toList() /// asyncStar: continued | 76 |
| 77 /// asyncStar: continued |
| 74 .catchError((e, st) { | 78 .catchError((e, st) { |
| 75 tracer.trace("e"); | 79 tracer.trace("e"); |
| 76 Expect.equals(savedStackTrace.toString(), st.toString()); | 80 Expect.equals(savedStackTrace.toString(), st.toString()); |
| 77 }); | 81 }); |
| 78 } | 82 } |
| 79 | 83 |
| 80 test3(Tracer tracer) { | 84 test3(Tracer tracer) { |
| 81 var savedStackTrace; | 85 var savedStackTrace; |
| 82 foo() async | 86 foo() async* |
| 83 * /// asyncStar: continued | 87 |
| 84 { | 88 /// asyncStar: continued |
| 89 { |
| 85 try { | 90 try { |
| 86 tracer.trace("a"); | 91 tracer.trace("a"); |
| 87 throw "Error"; | 92 throw "Error"; |
| 88 } catch (e, st) { | 93 } catch (e, st) { |
| 89 tracer.trace("b"); | 94 tracer.trace("b"); |
| 90 savedStackTrace = st; | 95 savedStackTrace = st; |
| 91 rethrow; | 96 rethrow; |
| 92 } | 97 } |
| 93 } | 98 } |
| 94 return foo() | 99 return foo().toList() |
| 95 .toList() /// asyncStar: continued | 100 |
| 101 /// asyncStar: continued |
| 96 .catchError((e, st) { | 102 .catchError((e, st) { |
| 97 tracer.trace("c"); | 103 tracer.trace("c"); |
| 98 Expect.equals(savedStackTrace.toString(), st.toString()); | 104 Expect.equals(savedStackTrace.toString(), st.toString()); |
| 99 }); | 105 }); |
| 100 } | 106 } |
| 101 | 107 |
| 102 runTest(String expectedTrace, Future test(Tracer tracer)) async { | 108 runTest(String expectedTrace, Future test(Tracer tracer)) async { |
| 103 Tracer tracer = new Tracer(expectedTrace); | 109 Tracer tracer = new Tracer(expectedTrace); |
| 104 await test(tracer); | 110 await test(tracer); |
| 105 tracer.done(); | 111 tracer.done(); |
| 106 } | 112 } |
| 107 | 113 |
| 108 runTests() async { | 114 runTests() async { |
| 109 await runTest("abcef", test1); | 115 await runTest("abcef", test1); |
| 110 await runTest("abce", test2); | 116 await runTest("abce", test2); |
| 111 await runTest("abc", test3); | 117 await runTest("abc", test3); |
| 112 } | 118 } |
| 113 | 119 |
| 114 main() { | 120 main() { |
| 115 asyncTest(runTests); | 121 asyncTest(runTests); |
| 116 } | 122 } |
| OLD | NEW |