加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

dart – Flutter中的jest快照测试相当于什么?

发布时间:2020-12-14 14:50:40 所属栏目:百科 来源:网络整理
导读:使用Jest,一个JS的测试库,可以有一个“快照”如下: test('foo',() = { expect(42).toMatchSnapshot("my_snapshot");}) 基本上,在第一次运行时,这会将测试值保存到文件中.在以后的运行中,它将传递的值与文件中的值进行比较.因此,如果传递的值与该文件中的值
使用Jest,一个JS的测试库,可以有一个“快照”如下:

test('foo',() => {
    expect(42).toMatchSnapshot("my_snapshot");
})

基本上,在第一次运行时,这会将测试值保存到文件中.在以后的运行中,它将传递的值与文件中的值进行比较.因此,如果传递的值与该文件中的值不同,则测试失败.

这非常有用,因为它允许轻松创建测试.

有没有办法使用Flutter提供的测试框架来做到这一点?

解决方法

使用testWidgets只能使用小部件:

testWidgets('golden',(tester) async {
  await tester.pumpWidget(Container(
    color: Colors.red,));

  await expectLater(
      find.byType(Container),matchesGoldenFile("red_container.png"));
});

首先,您必须抽取要测试的小部件(这里是一个红色容器).

然后你可以使用matchesGoldenFile和expectLater.这将捕获窗口小部件的屏幕截图,并将其与先前保存的捕获进行比较.

在第一次运行或当您想要更新您的goldens时,您必须通过标志进行颤振测试:

flutter test --update-goldens

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读