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

Side by Side Diff: tests/lib/async/catch_errors24_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/lib/async/catch_errors23_test.dart ('k') | tests/lib/async/catch_errors26_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 Completer done = new Completer(); 12 Completer done = new Completer();
13 13
14 var events = []; 14 var events = [];
15 StreamController controller; 15 StreamController controller;
16 Stream stream; 16 Stream stream;
17 // Test that the first listen on a `asBroadcastStream` determines the 17 // Test that the first listen on a `asBroadcastStream` determines the
18 // zone the subscription lives in. In this case the outer listen happens first 18 // zone the subscription lives in. In this case the outer listen happens first
19 // and the error reaches `handleError`. 19 // and the error reaches `handleError`.
20 catchErrors(() { 20 catchErrors(() {
21 catchErrors(() { 21 catchErrors(() {
22 controller = new StreamController(); 22 controller = new StreamController();
23 stream = controller.stream 23 stream = controller.stream
24 .map((x) { 24 .map((x) {
25 events.add("map $x"); 25 events.add("map $x");
26 return x + 100; 26 return x + 100;
27 }) 27 })
28 .transform(new StreamTransformer( 28 .transform(new StreamTransformer.fromHandlers(
29 handleError: (e, sink) => sink.add("error $e"))) 29 handleError: (e, st, sink) { sink.add("error $e"); }))
30 .asBroadcastStream(); 30 .asBroadcastStream();
31 runAsync(() { 31 runAsync(() {
32 stream.listen((x) { 32 stream.listen((x) {
33 events.add("stream $x"); 33 events.add("stream $x");
34 if (x == "error 2") done.complete(true); 34 if (x == "error 2") done.complete(true);
35 }); 35 });
36 }); 36 });
37 }).listen((x) { events.add(x); }) 37 }).listen((x) { events.add(x); })
38 .asFuture().then((_) { Expect.fail("Unexpected callback"); }); 38 .asFuture().then((_) { Expect.fail("Unexpected callback"); });
39 stream.listen((x) { events.add("stream2 $x"); }); 39 stream.listen((x) { events.add("stream2 $x"); });
(...skipping 15 matching lines...) Expand all
55 "stream2 101", 55 "stream2 101",
56 "stream 101", 56 "stream 101",
57 "stream2 error 2", 57 "stream2 error 2",
58 "stream error 2", 58 "stream error 2",
59 ], 59 ],
60 events); 60 events);
61 asyncEnd(); 61 asyncEnd();
62 }); 62 });
63 }); 63 });
64 } 64 }
OLDNEW
« no previous file with comments | « tests/lib/async/catch_errors23_test.dart ('k') | tests/lib/async/catch_errors26_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698