本文介绍如何对Flutter应用进行功能以及Widget测试
当创建一个Flutter应用的时候,已经默认配置好了测试环境,我们所要做的就是针对具体场景编写自己的测试用例。
功能测试
以测试缓存功能为例,编写如下的测试脚本:
/// 单元测试
void main() {
test('缓存功能测试', () async {
// fix 创建并初始化绑定
TestWidgetsFlutterBinding.ensureInitialized();
// fix 使用模拟值初始化共享首选项以进行测试。
SharedPreferences.setMockInitialValues({});
// 初始化缓存框架
await HiCache.preInit();
var key = "testHiCache", value = "hello.";
// 缓存数据
HiCache.getInstance().setString(key, value);
// 是否匹配
expect(HiCache.getInstance().get(key), value);
});
}
Widget测试
Widget 测试可以用于测试单独的 class,function,和 Widget
Widget 测试具有一定的局限性,所测试的Widget必须要能欧独立运行,或者依赖条件能欧被模拟出来。
/// Widget 测试
void main() {
testWidgets('测试UnKnowPage', (WidgetTester widgetTester) async {
var app = MaterialApp(home: UnKnowPage());
// 从给定的 [widget] 渲染 UI。
await widgetTester.pumpWidget(app);
// 是否存在404的Widget
expect(find.text('404'), findsOneWidget);
});
}