Commit 3a43fc88 authored by Adam Barth's avatar Adam Barth Committed by GitHub

Remove extraneous uses of scrollableKey from tests (#7775)

This patch removes unnecessary uses of scrollableKey from tests.
Scrollable2 will likely use a different mechanism for identifying
itself, so we want to focus on the uses of scrollableKey that will need
to be addressed in the new implementation.
parent 906541c0
...@@ -156,11 +156,12 @@ void main() { ...@@ -156,11 +156,12 @@ void main() {
) )
); );
expect(scrollableKey.currentState.scrollOffset, equals(500.0)); final ScrollableState scrollable = tester.state(find.byType(Scrollable));
expect(scrollable.scrollOffset, equals(500.0));
await tester.tapAt(const Point(100.0, 10.0)); await tester.tapAt(const Point(100.0, 10.0));
await tester.pump(); await tester.pump();
await tester.pump(const Duration(seconds: 1)); await tester.pump(const Duration(seconds: 1));
expect(scrollableKey.currentState.scrollOffset, equals(0.0)); expect(scrollable.scrollOffset, equals(0.0));
}); });
testWidgets('Tapping the status bar does not scroll to top on Android', (WidgetTester tester) async { testWidgets('Tapping the status bar does not scroll to top on Android', (WidgetTester tester) async {
...@@ -190,11 +191,12 @@ void main() { ...@@ -190,11 +191,12 @@ void main() {
) )
); );
expect(scrollableKey.currentState.scrollOffset, equals(500.0)); final ScrollableState scrollable = tester.state(find.byType(Scrollable));
expect(scrollable.scrollOffset, equals(500.0));
await tester.tapAt(const Point(100.0, 10.0)); await tester.tapAt(const Point(100.0, 10.0));
await tester.pump(); await tester.pump();
await tester.pump(const Duration(seconds: 1)); await tester.pump(const Duration(seconds: 1));
expect(scrollableKey.currentState.scrollOffset, equals(500.0)); expect(scrollable.scrollOffset, equals(500.0));
}); });
testWidgets('Bottom sheet cannot overlap app bar', (WidgetTester tester) async { testWidgets('Bottom sheet cannot overlap app bar', (WidgetTester tester) async {
......
...@@ -15,7 +15,7 @@ Widget buildFrame(ScrollableEdge clampedEdge) { ...@@ -15,7 +15,7 @@ Widget buildFrame(ScrollableEdge clampedEdge) {
return new ClampOverscrolls( return new ClampOverscrolls(
edge: clampedEdge, edge: clampedEdge,
child: new ScrollableViewport( child: new ScrollableViewport(
scrollableKey: new UniqueKey(), key: new UniqueKey(),
child: new SizedBox( child: new SizedBox(
height: 650.0, height: 650.0,
child: new Column( child: new Column(
......
...@@ -58,7 +58,7 @@ void main() { ...@@ -58,7 +58,7 @@ void main() {
}); });
testWidgets('Inherited ScrollConfiguration changed', (WidgetTester tester) async { testWidgets('Inherited ScrollConfiguration changed', (WidgetTester tester) async {
final GlobalKey scrollableKey = new GlobalKey(debugLabel: 'scrollable'); final GlobalKey key = new GlobalKey(debugLabel: 'scrollable');
TestScrollConfigurationDelegate delegate; TestScrollConfigurationDelegate delegate;
ExtentScrollBehavior behavior; ExtentScrollBehavior behavior;
...@@ -66,7 +66,7 @@ void main() { ...@@ -66,7 +66,7 @@ void main() {
new ScrollConfiguration( new ScrollConfiguration(
delegate: new TestScrollConfigurationDelegate(true), delegate: new TestScrollConfigurationDelegate(true),
child: new ScrollableViewport( child: new ScrollableViewport(
scrollableKey: scrollableKey, key: key,
child: new Builder( child: new Builder(
builder: (BuildContext context) { builder: (BuildContext context) {
delegate = ScrollConfiguration.of(context); delegate = ScrollConfiguration.of(context);
...@@ -89,7 +89,7 @@ void main() { ...@@ -89,7 +89,7 @@ void main() {
new ScrollConfiguration( new ScrollConfiguration(
delegate: new TestScrollConfigurationDelegate(false), delegate: new TestScrollConfigurationDelegate(false),
child: new ScrollableViewport( child: new ScrollableViewport(
scrollableKey: scrollableKey, key: key,
child: new Builder( child: new Builder(
builder: (BuildContext context) { builder: (BuildContext context) {
delegate = ScrollConfiguration.of(context); delegate = ScrollConfiguration.of(context);
......
...@@ -7,9 +7,8 @@ import 'dart:async'; ...@@ -7,9 +7,8 @@ import 'dart:async';
import 'package:flutter_test/flutter_test.dart'; import 'package:flutter_test/flutter_test.dart';
import 'package:flutter/widgets.dart'; import 'package:flutter/widgets.dart';
Widget _buildScroller({Key key, List<String> log}) { Widget _buildScroller({ List<String> log }) {
return new ScrollableViewport( return new ScrollableViewport(
scrollableKey: key,
onScrollStart: (double scrollOffset) { onScrollStart: (double scrollOffset) {
log.add('scrollstart'); log.add('scrollstart');
}, },
...@@ -24,11 +23,10 @@ Widget _buildScroller({Key key, List<String> log}) { ...@@ -24,11 +23,10 @@ Widget _buildScroller({Key key, List<String> log}) {
} }
void main() { void main() {
GlobalKey<ScrollableState<Scrollable>> scrollKey; Completer<Null> scrollTo(WidgetTester tester, double newScrollOffset, { Duration duration }) {
Completer<Null> scrollTo(double newScrollOffset, { Duration duration }) {
Completer<Null> completer = new Completer<Null>(); Completer<Null> completer = new Completer<Null>();
scrollKey.currentState.scrollTo(newScrollOffset, duration: duration).whenComplete(completer.complete); final ScrollableState scrollable = tester.state(find.byType(Scrollable));
scrollable.scrollTo(newScrollOffset, duration: duration).whenComplete(completer.complete);
return completer; return completer;
} }
...@@ -52,12 +50,11 @@ void main() { ...@@ -52,12 +50,11 @@ void main() {
}); });
testWidgets('Scroll scrollTo animation', (WidgetTester tester) async { testWidgets('Scroll scrollTo animation', (WidgetTester tester) async {
scrollKey = new GlobalKey<ScrollableState<Scrollable>>();
List<String> log = <String>[]; List<String> log = <String>[];
await tester.pumpWidget(_buildScroller(key: scrollKey, log: log)); await tester.pumpWidget(_buildScroller(log: log));
expect(log, equals(<String>[])); expect(log, equals(<String>[]));
Completer<Null> completer = scrollTo(100.0, duration: const Duration(seconds: 1)); Completer<Null> completer = scrollTo(tester, 100.0, duration: const Duration(seconds: 1));
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
expect(log, equals(<String>['scrollstart'])); expect(log, equals(<String>['scrollstart']));
await tester.pump(const Duration(milliseconds: 100)); await tester.pump(const Duration(milliseconds: 100));
...@@ -70,12 +67,11 @@ void main() { ...@@ -70,12 +67,11 @@ void main() {
}); });
testWidgets('Scroll scrollTo no animation', (WidgetTester tester) async { testWidgets('Scroll scrollTo no animation', (WidgetTester tester) async {
scrollKey = new GlobalKey<ScrollableState<Scrollable>>();
List<String> log = <String>[]; List<String> log = <String>[];
await tester.pumpWidget(_buildScroller(key: scrollKey, log: log)); await tester.pumpWidget(_buildScroller(log: log));
expect(log, equals(<String>[])); expect(log, equals(<String>[]));
Completer<Null> completer = scrollTo(100.0); Completer<Null> completer = scrollTo(tester, 100.0);
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
expect(log, equals(<String>['scrollstart', 'scroll', 'scrollend'])); expect(log, equals(<String>['scrollstart', 'scroll', 'scrollend']));
await tester.pump(); await tester.pump();
...@@ -83,12 +79,11 @@ void main() { ...@@ -83,12 +79,11 @@ void main() {
}); });
testWidgets('Scroll during animation', (WidgetTester tester) async { testWidgets('Scroll during animation', (WidgetTester tester) async {
scrollKey = new GlobalKey<ScrollableState<Scrollable>>();
List<String> log = <String>[]; List<String> log = <String>[];
await tester.pumpWidget(_buildScroller(key: scrollKey, log: log)); await tester.pumpWidget(_buildScroller(log: log));
expect(log, equals(<String>[])); expect(log, equals(<String>[]));
Completer<Null> completer = scrollTo(100.0, duration: const Duration(seconds: 1)); Completer<Null> completer = scrollTo(tester, 100.0, duration: const Duration(seconds: 1));
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
expect(log, equals(<String>['scrollstart'])); expect(log, equals(<String>['scrollstart']));
await tester.pump(const Duration(milliseconds: 100)); await tester.pump(const Duration(milliseconds: 100));
...@@ -97,7 +92,7 @@ void main() { ...@@ -97,7 +92,7 @@ void main() {
expect(log, equals(<String>['scrollstart', 'scroll'])); expect(log, equals(<String>['scrollstart', 'scroll']));
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
completer = scrollTo(100.0); completer = scrollTo(tester, 100.0);
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
expect(log, equals(<String>['scrollstart', 'scroll', 'scroll'])); expect(log, equals(<String>['scrollstart', 'scroll', 'scroll']));
await tester.pump(const Duration(milliseconds: 100)); await tester.pump(const Duration(milliseconds: 100));
...@@ -108,12 +103,11 @@ void main() { ...@@ -108,12 +103,11 @@ void main() {
}); });
testWidgets('Scroll during animation', (WidgetTester tester) async { testWidgets('Scroll during animation', (WidgetTester tester) async {
scrollKey = new GlobalKey<ScrollableState<Scrollable>>();
List<String> log = <String>[]; List<String> log = <String>[];
await tester.pumpWidget(_buildScroller(key: scrollKey, log: log)); await tester.pumpWidget(_buildScroller(log: log));
expect(log, equals(<String>[])); expect(log, equals(<String>[]));
Completer<Null> completer = scrollTo(100.0, duration: const Duration(seconds: 1)); Completer<Null> completer = scrollTo(tester, 100.0, duration: const Duration(seconds: 1));
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
expect(log, equals(<String>['scrollstart'])); expect(log, equals(<String>['scrollstart']));
await tester.pump(const Duration(milliseconds: 100)); await tester.pump(const Duration(milliseconds: 100));
...@@ -122,7 +116,7 @@ void main() { ...@@ -122,7 +116,7 @@ void main() {
expect(log, equals(<String>['scrollstart', 'scroll'])); expect(log, equals(<String>['scrollstart', 'scroll']));
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
completer = scrollTo(100.0, duration: const Duration(seconds: 1)); completer = scrollTo(tester, 100.0, duration: const Duration(seconds: 1));
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
expect(log, equals(<String>['scrollstart', 'scroll'])); expect(log, equals(<String>['scrollstart', 'scroll']));
await tester.pump(const Duration(milliseconds: 100)); await tester.pump(const Duration(milliseconds: 100));
...@@ -133,9 +127,8 @@ void main() { ...@@ -133,9 +127,8 @@ void main() {
}); });
testWidgets('fling, fling generates two start/end pairs', (WidgetTester tester) async { testWidgets('fling, fling generates two start/end pairs', (WidgetTester tester) async {
scrollKey = new GlobalKey<ScrollableState<Scrollable>>();
List<String> log = <String>[]; List<String> log = <String>[];
await tester.pumpWidget(_buildScroller(key: scrollKey, log: log)); await tester.pumpWidget(_buildScroller(log: log));
expect(log, equals(<String>[])); expect(log, equals(<String>[]));
await tester.flingFrom(const Point(100.0, 100.0), const Offset(-50.0, -50.0), 500.0); await tester.flingFrom(const Point(100.0, 100.0), const Offset(-50.0, -50.0), 500.0);
...@@ -152,9 +145,8 @@ void main() { ...@@ -152,9 +145,8 @@ void main() {
}); });
testWidgets('fling up ends', (WidgetTester tester) async { testWidgets('fling up ends', (WidgetTester tester) async {
scrollKey = new GlobalKey<ScrollableState<Scrollable>>();
List<String> log = <String>[]; List<String> log = <String>[];
await tester.pumpWidget(_buildScroller(key: scrollKey, log: log)); await tester.pumpWidget(_buildScroller(log: log));
expect(log, equals(<String>[])); expect(log, equals(<String>[]));
await tester.flingFrom(const Point(100.0, 100.0), const Offset(50.0, 50.0), 500.0); await tester.flingFrom(const Point(100.0, 100.0), const Offset(50.0, 50.0), 500.0);
...@@ -165,6 +157,6 @@ void main() { ...@@ -165,6 +157,6 @@ void main() {
expect(log.last, equals('scrollend')); expect(log.last, equals('scrollend'));
log.removeWhere((String value) => value == 'scroll'); log.removeWhere((String value) => value == 'scroll');
expect(log.length, equals(2)); expect(log.length, equals(2));
expect(scrollKey.currentState.scrollOffset, equals(0.0)); expect(tester.state<ScrollableState>(find.byType(Scrollable)).scrollOffset, equals(0.0));
}); });
} }
...@@ -15,7 +15,6 @@ void main() { ...@@ -15,7 +15,6 @@ void main() {
// Tests https://github.com/flutter/flutter/issues/5522 // Tests https://github.com/flutter/flutter/issues/5522
testWidgets('ScrollableGrid displays correct children with nonzero padding', (WidgetTester tester) async { testWidgets('ScrollableGrid displays correct children with nonzero padding', (WidgetTester tester) async {
GlobalKey<ScrollableState> scrollableKey = new GlobalKey<ScrollableState>();
final EdgeInsets padding = const EdgeInsets.fromLTRB(0.0, 100.0, 0.0, 0.0); final EdgeInsets padding = const EdgeInsets.fromLTRB(0.0, 100.0, 0.0, 0.0);
Widget testWidget = new Align( Widget testWidget = new Align(
...@@ -23,7 +22,6 @@ void main() { ...@@ -23,7 +22,6 @@ void main() {
height: 800.0, height: 800.0,
width: 300.0, // forces the grid children to be 300..300 width: 300.0, // forces the grid children to be 300..300
child: new ScrollableGrid( child: new ScrollableGrid(
scrollableKey: scrollableKey,
delegate: new FixedColumnCountGridDelegate( delegate: new FixedColumnCountGridDelegate(
columnCount: 1, columnCount: 1,
padding: padding padding: padding
......
...@@ -77,10 +77,8 @@ void main() { ...@@ -77,10 +77,8 @@ void main() {
return result; return result;
}; };
GlobalKey<ScrollableState> scrollableKey = new GlobalKey<ScrollableState>();
FlipWidget testWidget = new FlipWidget( FlipWidget testWidget = new FlipWidget(
left: new ScrollableLazyList( left: new ScrollableLazyList(
scrollableKey: scrollableKey,
itemBuilder: itemBuilder, itemBuilder: itemBuilder,
itemExtent: 200.0, itemExtent: 200.0,
initialScrollOffset: 300.0 initialScrollOffset: 300.0
...@@ -89,7 +87,8 @@ void main() { ...@@ -89,7 +87,8 @@ void main() {
); );
Completer<Null> scrollTo(double newScrollOffset) { Completer<Null> scrollTo(double newScrollOffset) {
Completer<Null> completer = new Completer<Null>(); Completer<Null> completer = new Completer<Null>();
scrollableKey.currentState.scrollTo(newScrollOffset).whenComplete(completer.complete); final ScrollableState scrollable = tester.state(find.byType(Scrollable));
scrollable.scrollTo(newScrollOffset).whenComplete(completer.complete);
return completer; return completer;
} }
...@@ -132,10 +131,8 @@ void main() { ...@@ -132,10 +131,8 @@ void main() {
return result; return result;
}; };
GlobalKey<ScrollableState> scrollableKey = new GlobalKey<ScrollableState>();
FlipWidget testWidget = new FlipWidget( FlipWidget testWidget = new FlipWidget(
left: new ScrollableLazyList( left: new ScrollableLazyList(
scrollableKey: scrollableKey,
itemBuilder: itemBuilder, itemBuilder: itemBuilder,
itemExtent: 200.0, itemExtent: 200.0,
initialScrollOffset: 300.0, initialScrollOffset: 300.0,
...@@ -145,7 +142,8 @@ void main() { ...@@ -145,7 +142,8 @@ void main() {
); );
Completer<Null> scrollTo(double newScrollOffset) { Completer<Null> scrollTo(double newScrollOffset) {
Completer<Null> completer = new Completer<Null>(); Completer<Null> completer = new Completer<Null>();
scrollableKey.currentState.scrollTo(newScrollOffset).whenComplete(completer.complete); final ScrollableState scrollable = tester.state(find.byType(Scrollable));
scrollable.scrollTo(newScrollOffset).whenComplete(completer.complete);
return completer; return completer;
} }
...@@ -183,16 +181,15 @@ void main() { ...@@ -183,16 +181,15 @@ void main() {
return result; return result;
}; };
GlobalKey<ScrollableState> scrollableKey = new GlobalKey<ScrollableState>();
Widget testWidget = new ScrollableLazyList( Widget testWidget = new ScrollableLazyList(
scrollableKey: scrollableKey,
itemBuilder: itemBuilder, itemBuilder: itemBuilder,
itemExtent: 300.0, itemExtent: 300.0,
itemCount: 10 itemCount: 10
); );
Completer<Null> scrollTo(double newScrollOffset) { Completer<Null> scrollTo(double newScrollOffset) {
Completer<Null> completer = new Completer<Null>(); Completer<Null> completer = new Completer<Null>();
scrollableKey.currentState.scrollTo(newScrollOffset).whenComplete(completer.complete); ScrollableState scrollable = tester.state(find.byType(Scrollable));
scrollable.scrollTo(newScrollOffset).whenComplete(completer.complete);
return completer; return completer;
} }
......
...@@ -154,14 +154,12 @@ void main() { ...@@ -154,14 +154,12 @@ void main() {
testWidgets('Tap immediately following clamped overscroll', (WidgetTester tester) async { testWidgets('Tap immediately following clamped overscroll', (WidgetTester tester) async {
// Regression test for https://github.com/flutter/flutter/issues/5709 // Regression test for https://github.com/flutter/flutter/issues/5709
GlobalKey<ScrollableState> scrollableKey = new GlobalKey<ScrollableState>();
List<int> tapped = <int>[]; List<int> tapped = <int>[];
await tester.pumpWidget( await tester.pumpWidget(
new ClampOverscrolls( new ClampOverscrolls(
edge: ScrollableEdge.both, edge: ScrollableEdge.both,
child: new ScrollableList( child: new ScrollableList(
scrollableKey: scrollableKey,
itemExtent: 200.0, itemExtent: 200.0,
children: items.map((int item) { children: items.map((int item) {
return new Container( return new Container(
...@@ -176,8 +174,9 @@ void main() { ...@@ -176,8 +174,9 @@ void main() {
); );
await tester.fling(find.text('0'), const Offset(0.0, 400.0), 1000.0); await tester.fling(find.text('0'), const Offset(0.0, 400.0), 1000.0);
expect(scrollableKey.currentState.scrollOffset, equals(0.0)); final ScrollableState scrollable = tester.state(find.byType(Scrollable));
expect(scrollableKey.currentState.virtualScrollOffset, lessThan(0.0)); expect(scrollable.scrollOffset, equals(0.0));
expect(scrollable.virtualScrollOffset, lessThan(0.0));
await tester.tapAt(const Point(200.0, 100.0)); await tester.tapAt(const Point(200.0, 100.0));
expect(tapped, equals(<int>[0])); expect(tapped, equals(<int>[0]));
......
...@@ -70,12 +70,10 @@ class TestViewportScrollPosition extends AbsoluteScrollPosition ...@@ -70,12 +70,10 @@ class TestViewportScrollPosition extends AbsoluteScrollPosition
void main() { void main() {
testWidgets('Evil test of sliver features - 1', (WidgetTester tester) async { testWidgets('Evil test of sliver features - 1', (WidgetTester tester) async {
final GlobalKey<Scrollable2State> scrollableKey = new GlobalKey<Scrollable2State>();
final GlobalKey centerKey = new GlobalKey(); final GlobalKey centerKey = new GlobalKey();
await tester.pumpWidget( await tester.pumpWidget(
new Scrollbar2( new Scrollbar2(
child: new ScrollableViewport2( child: new ScrollableViewport2(
key: scrollableKey,
axisDirection: AxisDirection.down, axisDirection: AxisDirection.down,
center: centerKey, center: centerKey,
anchor: 0.25, anchor: 0.25,
......
...@@ -9,7 +9,6 @@ import 'package:flutter/widgets.dart'; ...@@ -9,7 +9,6 @@ import 'package:flutter/widgets.dart';
const double itemExtent = 200.0; const double itemExtent = 200.0;
Axis scrollDirection = Axis.vertical; Axis scrollDirection = Axis.vertical;
GlobalKey scrollableListKey;
Widget buildItem(int item) { Widget buildItem(int item) {
return new Container( return new Container(
...@@ -39,14 +38,12 @@ class TestScrollConfigurationDelegate extends ScrollConfigurationDelegate { ...@@ -39,14 +38,12 @@ class TestScrollConfigurationDelegate extends ScrollConfigurationDelegate {
} }
Widget buildFrame() { Widget buildFrame() {
scrollableListKey = new GlobalKey();
return new ScrollConfiguration( return new ScrollConfiguration(
delegate: const TestScrollConfigurationDelegate(), delegate: const TestScrollConfigurationDelegate(),
child: new Center( child: new Center(
child: new Container( child: new Container(
height: itemExtent * 2.0, height: itemExtent * 2.0,
child: new ScrollableList( child: new ScrollableList(
scrollableKey: scrollableListKey,
snapOffsetCallback: snapOffsetCallback, snapOffsetCallback: snapOffsetCallback,
scrollDirection: scrollDirection, scrollDirection: scrollDirection,
itemExtent: itemExtent, itemExtent: itemExtent,
...@@ -57,26 +54,26 @@ Widget buildFrame() { ...@@ -57,26 +54,26 @@ Widget buildFrame() {
); );
} }
ScrollableState get scrollableState => scrollableListKey.currentState; void main() {
testWidgets('ScrollableList snap scrolling', (WidgetTester tester) async {
ScrollableState getScrollableState() => tester.state(find.byType(Scrollable));
double get scrollOffset => scrollableState.scrollOffset; double getScrollOffset() => getScrollableState().scrollOffset;
set scrollOffset(double value) { void setScrollOffset(double value) {
scrollableState.scrollTo(value); getScrollableState().scrollTo(value);
} }
Completer<Null> fling(double velocity) { Completer<Null> fling(double velocity) {
Completer<Null> completer = new Completer<Null>(); Completer<Null> completer = new Completer<Null>();
scrollableState.fling(velocity).whenComplete(completer.complete); getScrollableState().fling(velocity).whenComplete(completer.complete);
return completer; return completer;
} }
void main() {
testWidgets('ScrollableList snap scrolling', (WidgetTester tester) async {
await tester.pumpWidget(buildFrame()); await tester.pumpWidget(buildFrame());
scrollOffset = 0.0; setScrollOffset(0.0);
await tester.pump(); await tester.pump();
expect(scrollOffset, 0.0); expect(getScrollOffset(), 0.0);
Duration dt = const Duration(seconds: 2); Duration dt = const Duration(seconds: 2);
...@@ -84,51 +81,51 @@ void main() { ...@@ -84,51 +81,51 @@ void main() {
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
await tester.pump(); // Start the scheduler at 0.0 await tester.pump(); // Start the scheduler at 0.0
await tester.pump(dt); await tester.pump(dt);
expect(scrollOffset, closeTo(200.0, 1.0)); expect(getScrollOffset(), closeTo(200.0, 1.0));
expect(completer.isCompleted, isTrue); expect(completer.isCompleted, isTrue);
scrollOffset = 0.0; setScrollOffset(0.0);
await tester.pump(); await tester.pump();
expect(scrollOffset, 0.0); expect(getScrollOffset(), 0.0);
completer = fling(2000.0); completer = fling(2000.0);
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
await tester.pump(); await tester.pump();
await tester.pump(dt); await tester.pump(dt);
expect(scrollOffset, closeTo(400.0, 1.0)); expect(getScrollOffset(), closeTo(400.0, 1.0));
expect(completer.isCompleted, isTrue); expect(completer.isCompleted, isTrue);
scrollOffset = 400.0; setScrollOffset(400.0);
await tester.pump(); await tester.pump();
expect(scrollOffset, 400.0); expect(getScrollOffset(), 400.0);
completer = fling(-800.0); completer = fling(-800.0);
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
await tester.pump(); await tester.pump();
await tester.pump(dt); await tester.pump(dt);
expect(scrollOffset, closeTo(0.0, 1.0)); expect(getScrollOffset(), closeTo(0.0, 1.0));
expect(completer.isCompleted, isTrue); expect(completer.isCompleted, isTrue);
scrollOffset = 800.0; setScrollOffset(800.0);
await tester.pump(); await tester.pump();
expect(scrollOffset, 800.0); expect(getScrollOffset(), 800.0);
completer = fling(-2000.0); completer = fling(-2000.0);
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
await tester.pump(); await tester.pump();
await tester.pump(dt); await tester.pump(dt);
expect(scrollOffset, closeTo(200.0, 1.0)); expect(getScrollOffset(), closeTo(200.0, 1.0));
expect(completer.isCompleted, isTrue); expect(completer.isCompleted, isTrue);
scrollOffset = 800.0; setScrollOffset(800.0);
await tester.pump(); await tester.pump();
expect(scrollOffset, 800.0); expect(getScrollOffset(), 800.0);
completer = fling(-2000.0); completer = fling(-2000.0);
expect(completer.isCompleted, isFalse); expect(completer.isCompleted, isFalse);
await tester.pump(); await tester.pump();
await tester.pump(dt); await tester.pump(dt);
expect(completer.isCompleted, isTrue); expect(completer.isCompleted, isTrue);
expectSync(scrollOffset, closeTo(200.0, 1.0)); expectSync(getScrollOffset(), closeTo(200.0, 1.0));
}); });
} }
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