Commit dbed575c authored by Tong Mu's avatar Tong Mu Committed by Flutter GitHub Bot

Add test of scrolling competition (#47492)

parent 07161e82
...@@ -16,6 +16,7 @@ Future<void> pumpTest( ...@@ -16,6 +16,7 @@ Future<void> pumpTest(
bool scrollable = true, bool scrollable = true,
bool reverse = false, bool reverse = false,
ScrollController controller, ScrollController controller,
Widget Function(Widget) wrapper,
}) async { }) async {
await tester.pumpWidget(MaterialApp( await tester.pumpWidget(MaterialApp(
theme: ThemeData( theme: ThemeData(
...@@ -33,14 +34,46 @@ Future<void> pumpTest( ...@@ -33,14 +34,46 @@ Future<void> pumpTest(
await tester.pump(const Duration(seconds: 5)); // to let the theme animate await tester.pump(const Duration(seconds: 5)); // to let the theme animate
} }
// Pump a nested scrollable. The outer scrollable contains a sliver of a
// 300-pixel-long scrollable followed by a 2000-pixel-long content.
Future<void> pumpDoubleScrollableTest(
WidgetTester tester,
TargetPlatform platform,
) async {
await tester.pumpWidget(MaterialApp(
theme: ThemeData(
platform: platform,
),
home: CustomScrollView(
slivers: <Widget>[
SliverToBoxAdapter(
child: Container(
height: 300,
child: const CustomScrollView(
slivers: <Widget>[
SliverToBoxAdapter(child: SizedBox(height: 2000.0)),
],
),
),
),
const SliverToBoxAdapter(child: SizedBox(height: 2000.0)),
],
),
));
await tester.pump(const Duration(seconds: 5)); // to let the theme animate
}
const double dragOffset = 200.0; const double dragOffset = 200.0;
final LogicalKeyboardKey modifierKey = defaultTargetPlatform == TargetPlatform.macOS final LogicalKeyboardKey modifierKey = defaultTargetPlatform == TargetPlatform.macOS
? LogicalKeyboardKey.metaLeft ? LogicalKeyboardKey.metaLeft
: LogicalKeyboardKey.controlLeft; : LogicalKeyboardKey.controlLeft;
double getScrollOffset(WidgetTester tester) { double getScrollOffset(WidgetTester tester, {bool last = true}) {
final RenderViewport viewport = tester.renderObject(find.byType(Viewport)); Finder viewportFinder = find.byType(Viewport);
if (last)
viewportFinder = viewportFinder.last;
final RenderViewport viewport = tester.renderObject(viewportFinder);
return viewport.offset.pixels; return viewport.offset.pixels;
} }
...@@ -252,6 +285,24 @@ void main() { ...@@ -252,6 +285,24 @@ void main() {
expect(getScrollOffset(tester), 0.0); expect(getScrollOffset(tester), 0.0);
}); });
testWidgets('Scroll pointer signals are handled when there is competion', (WidgetTester tester) async {
// This is a regression test. When there are multiple scrollables listening
// to the same event, for example when scrollables are nested, there used
// to be exceptions at scrolling events.
await pumpDoubleScrollableTest(tester, TargetPlatform.fuchsia);
final Offset scrollEventLocation = tester.getCenter(find.byType(Viewport).last);
final TestPointer testPointer = TestPointer(1, ui.PointerDeviceKind.mouse);
// Create a hover event so that |testPointer| has a location when generating the scroll.
testPointer.hover(scrollEventLocation);
final HitTestResult result = tester.hitTestOnBinding(scrollEventLocation);
await tester.sendEventToBinding(testPointer.scroll(const Offset(0.0, 20.0)), result);
expect(getScrollOffset(tester, last: true), 20.0);
// Pointer signals should not cause overscroll.
await tester.sendEventToBinding(testPointer.scroll(const Offset(0.0, -30.0)), result);
expect(getScrollOffset(tester, last: true), 0.0);
});
testWidgets('Scroll pointer signals are ignored when scrolling is disabled', (WidgetTester tester) async { testWidgets('Scroll pointer signals are ignored when scrolling is disabled', (WidgetTester tester) async {
await pumpTest(tester, TargetPlatform.fuchsia, scrollable: false); await pumpTest(tester, TargetPlatform.fuchsia, scrollable: false);
final Offset scrollEventLocation = tester.getCenter(find.byType(Viewport)); final Offset scrollEventLocation = tester.getCenter(find.byType(Viewport));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment