I'm trying to take advantage of the Chain object provided by stack_trace like so:
import 'dart:async';
import 'package:stack_trace/stack_trace.dart';
main() async {
print('Hello world: ${console_test.calculate()}!');
Chain.capture(() async {
try {
await testFunction();
} catch(e,st) {
print(Trace.format(new Chain.forTrace(st)));
}
});
}
Future testFunction() async {
throw new Exception("TEST");
}
The output I get is this:
Hello world: 42!
main.dart 4:1 main.<async>.<fn>.<async>
I understand that the outputted stack trace should include testFunction, but for some reason it isn't. If I do it with futures instead:
import 'dart:async';
import 'package:stack_trace/stack_trace.dart';
main() async {
print('Hello world: ${console_test.calculate()}!');
Chain.capture(() {
return testFunction();
}, onError: (e, stackTrace) => print(Trace.format(new Chain.forTrace(stackTrace))));
}
Future testFunction() async {
throw new Exception("TEST");
}
I get more expected output:
Hello world: 42!
main.dart 17:3 testFunction.<async>
dart:async _Completer.completeError
main.dart 4:1 testFunction.<async>
dart:async Future.Future
main.dart 4:1 testFunction
main.dart 11:26 main.<async>.<fn>
package:stack_trace Chain.capture
main.dart 10:16 main.<async>
Am I doing something wrong? Is Chain incompatible with the whole async/await thing?
@nex3 correctly pointed out that my original example in fact works in the 1.9.0 dev build of Dart, so this might just be an incompatibility at present. Regardless, taking the async off of the Chain.capture, changing the await on testFunction() to a return and using an await on Chain.Capture actually produce the correct output. This obviously isn't 100% optimal, but it gets the job done.
What versions of Dart and
stack_trace
are you using? On Dart1.9.0-edge.44028
withstack_trace
1.2.3
, after deleting theconsole_test
line, I get the following output:It's also worth noting that you don't really need to use
Trace.format
withChain
. You can just useChain.terse
, which will also preserve the asynchronous gaps.