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

Side by Side Diff: tests/lib/async/catch_errors16_test.dart

Issue 25354003: Redo StreamTransformers so they work with Stack traces. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Address comments. Created 7 years, 2 months 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/co19/co19-co19.status ('k') | tests/lib/async/catch_errors17_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) 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:async_helper/async_helper.dart'; 5 import 'package:async_helper/async_helper.dart';
6 import "package:expect/expect.dart"; 6 import "package:expect/expect.dart";
7 import 'dart:async'; 7 import 'dart:async';
8 import 'catch_errors.dart'; 8 import 'catch_errors.dart';
9 9
10 main() { 10 main() {
11 asyncStart(); 11 asyncStart();
12 var events = []; 12 var events = [];
13 StreamController controller = new StreamController(); 13 StreamController controller = new StreamController();
14 Stream stream = controller.stream; 14 Stream stream = controller.stream;
15 // Test that the subscription of a stream is what counts. The error (2) runs 15 // Test that the subscription of a stream is what counts. The error (2) runs
16 // through the map-stream which goes through the nested `catchError` but 16 // through the map-stream which goes through the nested `catchError` but
17 // the nested `catchError` won't see the error. 17 // the nested `catchError` won't see the error.
18 catchErrors(() { 18 catchErrors(() {
19 stream = stream.map((x) => x + 100); 19 stream = stream.map((x) => x + 100);
20 }).listen((x) { events.add(x); }); 20 }).listen((x) { events.add(x); });
21 stream 21 stream
22 .transform(new StreamTransformer( 22 .transform(new StreamTransformer.fromHandlers(
23 handleError: (e, sink) => sink.add("error $e"))) 23 handleError: (e, st, sink) { sink.add("error $e"); }))
24 .listen((x) { events.add("stream $x"); }, 24 .listen((x) { events.add("stream $x"); },
25 onDone: () { 25 onDone: () {
26 Expect.listEquals(["stream 101", 26 Expect.listEquals(["stream 101",
27 "stream error 2", 27 "stream error 2",
28 ], 28 ],
29 events); 29 events);
30 asyncEnd(); 30 asyncEnd();
31 }); 31 });
32 controller.add(1); 32 controller.add(1);
33 controller.addError(2); 33 controller.addError(2);
34 controller.close(); 34 controller.close();
35 } 35 }
OLDNEW
« no previous file with comments | « tests/co19/co19-co19.status ('k') | tests/lib/async/catch_errors17_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698