blob: 1b57f817cff3eeda4e13ff7e78248f6df953cf03 [file] [log] [blame]
// Copyright 2014 The Flutter 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/material.dart';
import 'package:flutter/rendering.dart';
import 'package:flutter_test/flutter_test.dart';
void main() {
testWidgets('!pinned && !floating && !bottom ==> fade opacity', (WidgetTester tester) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
_TestWidget(pinned: false, floating: false, bottom: false, controller: controller),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(200.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 0.0);
});
testWidgets('a11y mode ===> 1.0 opacity', (WidgetTester tester) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
MediaQuery(
data: const MediaQueryData(accessibleNavigation: true),
child: _TestWidget(pinned: false, floating: false, bottom: false, controller: controller),
),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(100.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 1.0);
});
testWidgets('turn on/off a11y mode to change opacity', (WidgetTester tester) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
addTearDown(tester.platformDispatcher.clearAllTestValues);
addTearDown(tester.view.reset);
tester.platformDispatcher
..textScaleFactorTestValue = 123
..platformBrightnessTestValue = Brightness.dark
..accessibilityFeaturesTestValue = const FakeAccessibilityFeatures();
await tester.pumpWidget(
_TestWidget(pinned: false, floating: false, bottom: false, controller: controller),
);
// AccessibleNavigation is off
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
controller.jumpTo(100.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity < 1.0, true);
// Turn on accessibleNavigation
tester.platformDispatcher.accessibilityFeaturesTestValue = const FakeAccessibilityFeatures(
accessibleNavigation: true,
);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 1.0);
// Turn off accessibleNavigation
tester.platformDispatcher.accessibilityFeaturesTestValue = const FakeAccessibilityFeatures();
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity < 1.0, true);
});
testWidgets('!pinned && !floating && bottom ==> fade opacity', (WidgetTester tester) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
_TestWidget(pinned: false, floating: false, bottom: true, controller: controller),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(200.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 0.0);
});
testWidgets('!pinned && floating && !bottom ==> fade opacity', (WidgetTester tester) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
_TestWidget(pinned: false, floating: true, bottom: false, controller: controller),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(200.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 0.0);
});
testWidgets('!pinned && floating && bottom ==> fade opacity', (WidgetTester tester) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
_TestWidget(pinned: false, floating: true, bottom: true, controller: controller),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(200.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 0.0);
});
testWidgets('pinned && !floating && !bottom ==> 1.0 opacity', (WidgetTester tester) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
_TestWidget(pinned: true, floating: false, bottom: false, controller: controller),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(200.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 1.0);
});
testWidgets('pinned && !floating && bottom ==> 1.0 opacity', (WidgetTester tester) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
_TestWidget(pinned: true, floating: false, bottom: true, controller: controller),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(200.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 1.0);
});
testWidgets('pinned && floating && !bottom ==> 1.0 opacity', (WidgetTester tester) async {
// Regression test for https://github.com/flutter/flutter/issues/25000.
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
_TestWidget(pinned: true, floating: true, bottom: false, controller: controller),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(200.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 1.0);
});
testWidgets('pinned && floating && bottom && extraToolbarHeight == 0.0 ==> fade opacity', (
WidgetTester tester,
) async {
// Regression test for https://github.com/flutter/flutter/issues/25993.
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
_TestWidget(pinned: true, floating: true, bottom: true, controller: controller),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(200.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 0.0);
});
testWidgets('pinned && floating && bottom && extraToolbarHeight != 0.0 ==> 1.0 opacity', (
WidgetTester tester,
) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
await tester.pumpWidget(
_TestWidget(
pinned: true,
floating: true,
bottom: true,
collapsedHeight: 100.0,
controller: controller,
),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(200.0);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 1.0);
});
testWidgets('!pinned && !floating && !bottom && extraToolbarHeight != 0.0 ==> fade opacity', (
WidgetTester tester,
) async {
final ScrollController controller = ScrollController();
addTearDown(controller.dispose);
const double collapsedHeight = 100.0;
await tester.pumpWidget(
_TestWidget(
pinned: false,
floating: false,
bottom: false,
controller: controller,
collapsedHeight: collapsedHeight,
),
);
final RenderParagraph render = tester.renderObject(find.text('Hallo Welt!!1'));
expect(render.text.style!.color!.opacity, 1.0);
controller.jumpTo(collapsedHeight);
await tester.pumpAndSettle();
expect(render.text.style!.color!.opacity, 0.0);
});
}
class _TestWidget extends StatelessWidget {
const _TestWidget({
required this.pinned,
required this.floating,
required this.bottom,
this.controller,
this.collapsedHeight,
});
final bool pinned;
final bool floating;
final bool bottom;
final ScrollController? controller;
final double? collapsedHeight;
@override
Widget build(BuildContext context) {
return MaterialApp(
home: CustomScrollView(
controller: controller,
slivers: <Widget>[
SliverAppBar(
pinned: pinned,
floating: floating,
expandedHeight: 120.0,
collapsedHeight: collapsedHeight,
title: const Text('Hallo Welt!!1'),
bottom:
!bottom
? null
: PreferredSize(preferredSize: const Size.fromHeight(35.0), child: Container()),
),
SliverList(
delegate: SliverChildListDelegate(
List<Widget>.generate(20, (int i) {
return SizedBox(height: 100.0, child: Text('Tile $i'));
}),
),
),
],
),
);
}
}