blob: 5984c8b3c1ffe13511e109e07c88ecdde91ac47e [file] [log] [blame]
// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'package:flutter_test/flutter_test.dart';
import 'package:flutter/rendering.dart';
import 'package:flutter/widgets.dart';
import '../rendering/mock_canvas.dart';
Future<Null> test(WidgetTester tester, double offset) {
return tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: new ViewportOffset.fixed(offset),
slivers: const <Widget>[
const SliverList(
delegate: const SliverChildListDelegate(const <Widget>[
const SizedBox(height: 400.0, child: const Text('a')),
const SizedBox(height: 400.0, child: const Text('b')),
const SizedBox(height: 400.0, child: const Text('c')),
const SizedBox(height: 400.0, child: const Text('d')),
const SizedBox(height: 400.0, child: const Text('e')),
]),
),
],
),
),
);
}
void verify(WidgetTester tester, List<Offset> answerKey, String text) {
final List<Offset> testAnswers = tester.renderObjectList<RenderBox>(find.byType(SizedBox)).map<Offset>(
(RenderBox target) => target.localToGlobal(const Offset(0.0, 0.0))
).toList();
expect(testAnswers, equals(answerKey));
final String foundText =
tester.widgetList<Text>(find.byType(Text))
.map<String>((Text widget) => widget.data)
.reduce((String value, String element) => value + element);
expect(foundText, equals(text));
}
void main() {
testWidgets('Viewport+SliverBlock basic test', (WidgetTester tester) async {
await test(tester, 0.0);
expect(tester.renderObject<RenderBox>(find.byType(Viewport)).size, equals(const Size(800.0, 600.0)));
verify(tester, <Offset>[
const Offset(0.0, 0.0),
const Offset(0.0, 400.0),
], 'ab');
await test(tester, 200.0);
verify(tester, <Offset>[
const Offset(0.0, -200.0),
const Offset(0.0, 200.0),
], 'ab');
await test(tester, 600.0);
verify(tester, <Offset>[
const Offset(0.0, -200.0),
const Offset(0.0, 200.0),
], 'bc');
await test(tester, 900.0);
verify(tester, <Offset>[
const Offset(0.0, -100.0),
const Offset(0.0, 300.0),
], 'cd');
await test(tester, 200.0);
verify(tester, <Offset>[
const Offset(0.0, -200.0),
const Offset(0.0, 200.0),
], 'ab');
});
testWidgets('Viewport with GlobalKey reparenting', (WidgetTester tester) async {
final Key key1 = new GlobalKey();
final ViewportOffset offset = new ViewportOffset.zero();
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: offset,
slivers: <Widget>[
new SliverList(
delegate: new SliverChildListDelegate(<Widget>[
const SizedBox(height: 251.0, child: const Text('a')),
const SizedBox(height: 252.0, child: const Text('b')),
new SizedBox(key: key1, height: 253.0, child: const Text('c')),
]),
),
],
),
),
);
verify(tester, <Offset>[
const Offset(0.0, 0.0),
const Offset(0.0, 251.0),
const Offset(0.0, 503.0),
], 'abc');
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: offset,
slivers: <Widget>[
new SliverList(
delegate: new SliverChildListDelegate(<Widget>[
new SizedBox(key: key1, height: 253.0, child: const Text('c')),
const SizedBox(height: 251.0, child: const Text('a')),
const SizedBox(height: 252.0, child: const Text('b')),
]),
),
],
),
),
);
verify(tester, <Offset>[
const Offset(0.0, 0.0),
const Offset(0.0, 253.0),
const Offset(0.0, 504.0),
], 'cab');
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: offset,
slivers: <Widget>[
new SliverList(
delegate: new SliverChildListDelegate(<Widget>[
const SizedBox(height: 251.0, child: const Text('a')),
new SizedBox(key: key1, height: 253.0, child: const Text('c')),
const SizedBox(height: 252.0, child: const Text('b')),
]),
),
],
),
),
);
verify(tester, <Offset>[
const Offset(0.0, 0.0),
const Offset(0.0, 251.0),
const Offset(0.0, 504.0),
], 'acb');
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: offset,
slivers: const <Widget>[
const SliverList(
delegate: const SliverChildListDelegate(const <Widget>[
const SizedBox(height: 251.0, child: const Text('a')),
const SizedBox(height: 252.0, child: const Text('b')),
]),
),
],
),
),
);
verify(tester, <Offset>[
const Offset(0.0, 0.0),
const Offset(0.0, 251.0),
], 'ab');
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: offset,
slivers: <Widget>[
new SliverList(
delegate: new SliverChildListDelegate(<Widget>[
const SizedBox(height: 251.0, child: const Text('a')),
new SizedBox(key: key1, height: 253.0, child: const Text('c')),
const SizedBox(height: 252.0, child: const Text('b')),
]),
),
],
),
),
);
verify(tester, <Offset>[
const Offset(0.0, 0.0),
const Offset(0.0, 251.0),
const Offset(0.0, 504.0),
], 'acb');
});
testWidgets('Viewport overflow clipping of SliverToBoxAdapter', (WidgetTester tester) async {
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: new ViewportOffset.zero(),
slivers: const <Widget>[
const SliverToBoxAdapter(
child: const SizedBox(height: 400.0, child: const Text('a')),
),
],
),
),
);
expect(find.byType(Viewport), isNot(paints..clipRect()));
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: new ViewportOffset.fixed(100.0),
slivers: const <Widget>[
const SliverToBoxAdapter(
child: const SizedBox(height: 400.0, child: const Text('a')),
),
],
),
),
);
expect(find.byType(Viewport), paints..clipRect());
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: new ViewportOffset.fixed(100.0),
slivers: const <Widget>[
const SliverToBoxAdapter(
child: const SizedBox(height: 4000.0, child: const Text('a')),
),
],
),
),
);
expect(find.byType(Viewport), paints..clipRect());
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: new ViewportOffset.zero(),
slivers: const <Widget>[
const SliverToBoxAdapter(
child: const SizedBox(height: 4000.0, child: const Text('a')),
),
],
),
),
);
expect(find.byType(Viewport), paints..clipRect());
});
testWidgets('Viewport overflow clipping of SliverBlock', (WidgetTester tester) async {
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: new ViewportOffset.zero(),
slivers: const <Widget>[
const SliverList(
delegate: const SliverChildListDelegate(const <Widget>[
const SizedBox(height: 400.0, child: const Text('a')),
]),
),
],
),
),
);
expect(find.byType(Viewport), isNot(paints..clipRect()));
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: new ViewportOffset.fixed(100.0),
slivers: const <Widget>[
const SliverList(
delegate: const SliverChildListDelegate(const <Widget>[
const SizedBox(height: 400.0, child: const Text('a')),
]),
),
],
),
),
);
expect(find.byType(Viewport), paints..clipRect());
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: new ViewportOffset.fixed(100.0),
slivers: const <Widget>[
const SliverList(
delegate: const SliverChildListDelegate(const <Widget>[
const SizedBox(height: 4000.0, child: const Text('a')),
]),
),
],
),
),
);
expect(find.byType(Viewport), paints..clipRect());
await tester.pumpWidget(
new Directionality(
textDirection: TextDirection.ltr,
child: new Viewport(
offset: new ViewportOffset.zero(),
slivers: const <Widget>[
const SliverList(
delegate: const SliverChildListDelegate(const <Widget>[
const SizedBox(height: 4000.0, child: const Text('a')),
]),
),
],
),
),
);
expect(find.byType(Viewport), paints..clipRect());
});
}