【问题标题】:Flutter widget test tap - would not hit test on the specified widgetFlutter 小部件测试点击 - 不会在指定的小部件上进行测试
【发布时间】:2021-09-22 17:28:32
【问题描述】:

输出以下警告后,我的小部件测试失败:

flutter:警告:使用 finder 调用 tap()“恰好是一个带有文本“Tab 2”的小部件(忽略后台小部件):Text(“Tab 2”,softWrap:除了换行符之外没有换行,溢出: fade, dependencies: [MediaQuery, DefaultTextStyle])" 派生了一个偏移量 (Offset(600.0, 23.0)),它不会在指定的小部件上进行测试。 flutter: 可能小部件实际上不在屏幕上,或者另一个小部件遮挡了它,或者小部件无法接收指针事件。

tap 永远不会执行,因此下一部分测试失败。我在测试中放了一些延迟,似乎测试正在尝试点击正确的小部件 - 它没有在屏幕外,没有被遮挡,并且过去能够接收指针事件 - 不确定它为什么目前失败。

这是一个最小的可重现示例:

import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart';

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: DefaultTabController(
        length: 2,
        child: Scaffold(
          appBar: TabBar(
            labelColor: Color(0xff8391e4),
            tabs: [
              Tab(text: 'Tab 1'),
              Tab(text: 'Tab 2'),
            ],
          ),
          body: TabBarView(
            children: <Widget>[
              Text('Tab 1 Text'),
              Text('Tab 2 Text'),
            ],
          ),
        ),
      ),
    );
  }
}

void main() {
  TestWidgetsFlutterBinding.ensureInitialized();

  testWidgets('My Test', (WidgetTester tester) async {
    await tester.pumpWidget(MyApp());
    await tester.pumpAndSettle();

    // Warning thrown on this tap - tap never executed
    await tester.tap(find.text('Tab 2'));
    await tester.pumpAndSettle();

    // Test fails here
    expect(find.text('Tab 2 Text'), findsOneWidget);
  });
}

【问题讨论】:

  • 我遇到了同样的问题,您找到解决方案了吗?我也试过ensureVisible。没有运气。
  • @LeeMordell 有这方面的消息吗?你找到解决办法了吗?
  • @Dirk - 有一段时间没有测试过,很遗憾没有解决方案。 :(

标签: flutter flutter-test


【解决方案1】:

尝试在tap()之前设置ensureVisible()

// Warning thrown on this tap - tap never executed
await tester.ensureVisible(find.text('Tab 2'));
await tester.tap(find.text('Tab 2'));
await tester.pumpAndSettle();

【讨论】:

  • 感谢您的建议。 ensureVisible 非常适合当小部件不在屏幕上并且您想滚动到它时;但是,在我的情况下,小部件在屏幕上清晰可见。
  • 我目前遇到了同样的问题@LeeMordell,但是当我在模拟器上运行测试时,正如您在评论中提到的那样,它是可见的。您是否设法找到解决此问题的方法?
  • ensureVisible 不是关于在真实模拟器中不可见,而是关于此特定组件在测试模拟器的屏幕上可见。因此,它会在模拟器屏幕上模拟滚动,直到相关组件可见
【解决方案2】:

我找到了解决问题的方法,但它可能不是通用的解决方案。此测试所针对的应用程序是专门的网络应用程序,因此它旨在在更大的屏幕尺寸上运行。当我在 chrome 上运行测试时它会通过,但如果不小心运行就会失败。

为了解决这个问题,我在更大的屏幕尺寸下运行测试,现在它不经意地通过了。 因此,如果您遇到A call to tap() ... that would not hit test on the specified widget 错误,调整屏幕大小可能会解决问题。

  testWidgets('My test', (WidgetTester tester) async {
      // Here we use physicalSizeTestValue to adjust the test screen size to
      // simulate running on a desktop computer which the app was designed for
      tester.binding.window.physicalSizeTestValue = Size(1080, 1920);
      tester.binding.window.devicePixelRatioTestValue = 1.0;

【讨论】:

    猜你喜欢
    • 2019-02-25
    • 2020-12-06
    • 2021-05-09
    • 2018-08-16
    • 2021-01-12
    • 2019-05-23
    • 2019-06-13
    • 2021-02-04
    • 1970-01-01
    相关资源
    最近更新 更多