Skip to content

Commit

Permalink
Merge pull request flutter#853 from jimbeveridge/pagetest
Browse files Browse the repository at this point in the history
Added rotation test for new PageableList code.
  • Loading branch information
jimbeveridge committed Dec 10, 2015
2 parents 54f2d4c + 8bb09db commit f92cd47
Show file tree
Hide file tree
Showing 2 changed files with 58 additions and 11 deletions.
6 changes: 0 additions & 6 deletions examples/widgets/pageable_list.dart
Original file line number Diff line number Diff line change
Expand Up @@ -41,12 +41,6 @@ class PageableListAppState extends State<PageableListApp> {
ScrollDirection scrollDirection = ScrollDirection.horizontal;
bool itemsWrap = false;

void updatePageSize(Size newSize) {
setState(() {
pageSize = newSize;
});
}

Widget buildCard(BuildContext context, CardModel cardModel, int index) {
Widget card = new Card(
color: cardModel.color,
Expand Down
63 changes: 58 additions & 5 deletions packages/unit/test/widget/pageable_list_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -3,33 +3,40 @@
// found in the LICENSE file.

import 'package:flutter_test/flutter_test.dart';
import 'package:flutter/rendering.dart';
import 'package:flutter/widgets.dart';
import 'package:test/test.dart';

const Size pageSize = const Size(800.0, 600.0);
Size pageSize = new Size(600.0, 300.0);
const List<int> defaultPages = const <int>[0, 1, 2, 3, 4, 5];
final List<GlobalKey> globalKeys = defaultPages.map((_) => new GlobalKey()).toList();
int currentPage = null;
bool itemsWrap = false;

Widget buildPage(BuildContext context, int page, int index) {
return new Container(
key: new ValueKey<int>(page),
key: globalKeys[page],
width: pageSize.width,
height: pageSize.height,
child: new Text(page.toString())
);
}

Widget buildFrame({ List<int> pages: defaultPages }) {
// The test framework forces the frame (and so the PageableList)
// to be 800x600. The pageSize constant reflects this.
return new PageableList<int>(
final list = new PageableList<int>(
items: pages,
itemBuilder: buildPage,
itemsWrap: itemsWrap,
scrollDirection: ScrollDirection.horizontal,
onPageChanged: (int page) { currentPage = page; }
);

// The test framework forces the frame to be 800x600, so we need to create
// an outer container where we can change the size.
return new Center(
child: new Container(
width: pageSize.width, height: pageSize.height, child: list)
);
}

void page(WidgetTester tester, Offset offset) {
Expand Down Expand Up @@ -57,8 +64,24 @@ void main() {
expect(currentPage, isNull);
pageLeft(tester);
expect(currentPage, equals(1));

expect(tester.findText('0'), isNull);
expect(tester.findText('1'), isNotNull);
expect(tester.findText('2'), isNull);
expect(tester.findText('3'), isNull);
expect(tester.findText('4'), isNull);
expect(tester.findText('5'), isNull);

pageRight(tester);
expect(currentPage, equals(0));

expect(tester.findText('0'), isNotNull);
expect(tester.findText('1'), isNull);
expect(tester.findText('2'), isNull);
expect(tester.findText('3'), isNull);
expect(tester.findText('4'), isNull);
expect(tester.findText('5'), isNull);

pageRight(tester);
expect(currentPage, equals(0));
});
Expand Down Expand Up @@ -118,4 +141,34 @@ void main() {
});
});

test('PageableList resize parent', () {
testWidgets((WidgetTester tester) {
tester.pumpWidget(new Container());
currentPage = null;
itemsWrap = true;

tester.pumpWidget(buildFrame());
expect(currentPage, isNull);
pageRight(tester);
expect(currentPage, equals(5));

RenderBox box = globalKeys[5].currentContext.findRenderObject();
expect(box.size.width, equals(pageSize.width));
expect(box.size.height, equals(pageSize.height));

pageSize = new Size(pageSize.height, pageSize.width);
tester.pumpWidget(buildFrame());

expect(tester.findText('0'), isNull);
expect(tester.findText('1'), isNull);
expect(tester.findText('2'), isNull);
expect(tester.findText('3'), isNull);
expect(tester.findText('4'), isNull);
expect(tester.findText('5'), isNotNull);

box = globalKeys[5].currentContext.findRenderObject();
expect(box.size.width, equals(pageSize.width));
expect(box.size.height, equals(pageSize.height));
});
});
}

0 comments on commit f92cd47

Please sign in to comment.