blob: 503d3ba91e65433f7aa0bba39f2019a1d801f794 [file] [log] [blame]
// Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
import "dart:async";
import "package:expect/expect.dart";
import "package:async_helper/async_helper.dart";
class Tracer {
final String expected;
final String name;
String _trace = "";
int counter = 0;
Tracer(this.expected, [this.name]);
void trace(msg) {
if (name != null) {
print("Tracing $name: $msg");
}
_trace += msg;
counter++;
}
void done() {
Expect.equals(expected, _trace);
}
}
foo1(Tracer tracer) async* {
try {
tracer.trace("a");
await new Future.value(3);
tracer.trace("b");
throw "Error";
} catch (e) {
Expect.equals("Error", e);
tracer.trace("c");
yield 1;
tracer.trace("d");
yield 2;
tracer.trace("e");
yield 3;
tracer.trace("f");
} finally {
tracer.trace("f");
}
tracer.trace("g");
}
foo2(Tracer tracer) async* {
try {
tracer.trace("a");
throw "Error";
} catch (error) {
Expect.equals("Error", error);
tracer.trace("b");
rethrow;
} finally {
tracer.trace("c");
}
}
foo3(Tracer tracer) async* {
try {
tracer.trace("a");
throw "Error";
} catch (error) {
Expect.equals("Error", error);
tracer.trace("b");
rethrow;
} finally {
tracer.trace("c");
yield 1;
}
}
foo4(Tracer tracer) async* {
try {
tracer.trace("a");
await new Future.value(3);
tracer.trace("b");
throw "Error";
} catch (e) {
Expect.equals("Error", e);
tracer.trace("c");
yield 1;
tracer.trace("d");
yield 2;
tracer.trace("e");
await new Future.error("Error2");
} finally {
tracer.trace("f");
}
tracer.trace("g");
}
runTest(test, expectedTrace, expectedError, shouldCancel) {
Tracer tracer = new Tracer(expectedTrace, expectedTrace);
Completer done = new Completer();
var subscription;
subscription = test(tracer).listen((event) async {
tracer.trace("Y");
if (shouldCancel) {
await subscription.cancel();
tracer.trace("C");
done.complete(null);
}
}, onError: (error) {
Expect.equals(expectedError, error);
tracer.trace("X");
}, onDone: () {
tracer.done();
done.complete(null);
});
return done.future.then((_) => tracer.done());
}
test() async {
// TODO(sigurdm): These tests are too dependent on scheduling, and buffering
// behavior.
await runTest(foo1, "abcdYefC", null, true);
await runTest(foo2, "abcX", "Error", false);
await runTest(foo3, "abcYX", "Error", false);
await runTest(foo4, "abcdYeYfX", "Error2", false);
}
void main() {
asyncTest(test);
}