我正在编写一些集成测试,这些测试利用了HttpServer
,一堆Directory().watch()
'ers以及可能的其他将来/流监听代码。
我正在使用以下测试配置:
class LaserServerTestConfiguration extends SimpleConfiguration {
LaserServer _server;
LaserServerTestConfiguration(this._server);
void onDone(bool success) {
super.onDone(success);
_server.stop();
}
}
我的测试如下所示:
main() {
var conf = new LaserConfiguration.fromPath('test/test_config.yaml');
var server = new LaserServer(conf);
unittestConfiguration = new LaserServerTestConfiguration(server);
server.start().then((_) {
test('test file changed event', () {
var response = new Completer<Map>();
response.future.then(expectAsync((e) =>
expect(e, containsValue('test/sample/sample_test.html'))
));
WebSocket.connect("ws://localhost:2014").then((ws) {
ws.listen((msg) {
response.complete(JSON.decode(msg));
ws.close();
});
new File('test/sample/sample.dart').writeAsString("");
});
});
});
}
我的问题是,在测试运行(并通过)之后,Dart VM无法退出。大概是因为我在事件队列中还有待处理的事情。
如何调试事件队列?我想看看是什么原因阻止了Dart VM在测试运行结束时退出。
您可以在自定义TestConfiguration中看到我重载了onDone(),这将被调用,然后我停止()我的服务器(HttpServer上的
.close(force: true)
并循环所有Directory().watch()
'ers并取消订阅)。但是仍然有东西徘徊... 最佳答案
现在的观测站(Dart VM版本:1.11.0-edge.131775)允许在调试器 View 中调查消息队列。
关于Dart事件队列: How to debug event queue?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27024868/