Flutter单元测试和Widget测试

本文介绍如何对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);
  });
}

版权声明:本文为weixin_43800535原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。