在我的 Dart 单元测试中,如何验证 print 是否被调用?
我正在为教程编写示例代码,我想对其进行测试。为简单起见,许多示例使用print
。我希望我的单元测试能够验证 print 是用正确的输入调用的。
谢谢!
在我的 Dart 单元测试中,如何验证 print 是否被调用?
我正在为教程编写示例代码,我想对其进行测试。为简单起见,许多示例使用print
。我希望我的单元测试能够验证 print 是用正确的输入调用的。
谢谢!
更新:ZoneSpecification允许覆盖该print
功能。通过在自定义区域内运行被测代码,您可以捕获对print
函数的调用。例如,以下测试将所有打印消息重定向到内存列表中log
:
import 'dart:async';
import 'package:test/test.dart';
var log = [];
main() {
test('override print', overridePrint(() {
print('hello world');
expect(log, ['hello world']);
}));
}
void Function() overridePrint(void testFn()) => () {
var spec = new ZoneSpecification(
print: (_, __, ___, String msg) {
// Add to log instead of printing to stdout
log.add(msg);
}
);
return Zone.current.fork(specification: spec).run<void>(testFn);
};
我认为 unittest 没有为此添加任何特定内容,但是您可以覆盖测试范围内的任何顶级函数并捕获对日志的调用,例如:
var printLog = [];
void print(String s) => printLog.add(s);
main() {
test('print', () {
myFuncUnderTest();
expect(printLog.length, 2);
expect(printLog[0], contains('hello'));
// etc...
});
}