Skip to content

Commit

Permalink
Add test for animated_positioned.0.dart API example. (flutter#146720)
Browse files Browse the repository at this point in the history
This PR contributes to flutter#130459

### Description
- Adds `examples/api/test/widgets/implicit_animations/animated_positioned.0_test.dart` test
  • Loading branch information
ksokolovskyi authored Apr 23, 2024
1 parent e10e9a9 commit b0524b3
Show file tree
Hide file tree
Showing 3 changed files with 111 additions and 6 deletions.
1 change: 0 additions & 1 deletion dev/bots/check_code_samples.dart
Original file line number Diff line number Diff line change
Expand Up @@ -472,7 +472,6 @@ final Set<String> _knownMissingTests = <String>{
'examples/api/test/widgets/focus_scope/focus_scope.0_test.dart',
'examples/api/test/widgets/implicit_animations/animated_fractionally_sized_box.0_test.dart',
'examples/api/test/widgets/implicit_animations/animated_align.0_test.dart',
'examples/api/test/widgets/implicit_animations/animated_positioned.0_test.dart',
'examples/api/test/widgets/implicit_animations/sliver_animated_opacity.0_test.dart',
'examples/api/test/widgets/scroll_view/custom_scroll_view.1_test.dart',
'examples/api/test/widgets/inherited_notifier/inherited_notifier.0_test.dart',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,24 +11,39 @@ void main() => runApp(const AnimatedPositionedExampleApp());
class AnimatedPositionedExampleApp extends StatelessWidget {
const AnimatedPositionedExampleApp({super.key});

static const Duration duration = Duration(seconds: 2);
static const Curve curve = Curves.fastOutSlowIn;

@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(title: const Text('AnimatedPositioned Sample')),
body: const Center(
child: AnimatedPositionedExample(),
child: AnimatedPositionedExample(
duration: duration,
curve: curve,
),
),
),
);
}
}

class AnimatedPositionedExample extends StatefulWidget {
const AnimatedPositionedExample({super.key});
const AnimatedPositionedExample({
required this.duration,
required this.curve,
super.key,
});

final Duration duration;

final Curve curve;

@override
State<AnimatedPositionedExample> createState() => _AnimatedPositionedExampleState();
State<AnimatedPositionedExample> createState() =>
_AnimatedPositionedExampleState();
}

class _AnimatedPositionedExampleState extends State<AnimatedPositionedExample> {
Expand All @@ -45,8 +60,8 @@ class _AnimatedPositionedExampleState extends State<AnimatedPositionedExample> {
width: selected ? 200.0 : 50.0,
height: selected ? 50.0 : 200.0,
top: selected ? 50.0 : 150.0,
duration: const Duration(seconds: 2),
curve: Curves.fastOutSlowIn,
duration: widget.duration,
curve: widget.curve,
child: GestureDetector(
onTap: () {
setState(() {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
// 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 'dart:ui';

import 'package:flutter/material.dart';
import 'package:flutter_api_samples/widgets/implicit_animations/animated_positioned.0.dart'
as example;
import 'package:flutter_test/flutter_test.dart';

void main() {
testWidgets(
'AnimatedPositioned animates on tap',
(WidgetTester tester) async {
await tester.pumpWidget(
const example.AnimatedPositionedExampleApp(),
);

final Finder positionedFinder = find.descendant(
of: find.byType(AnimatedPositioned),
matching: find.byType(Positioned),
);

const double beginWidth = 50.0;
const double endWidth = 200.0;
const double beginHeight = 200.0;
const double endHeight = 50.0;
const double beginTop = 150.0;
const double endTop = 50.0;

Positioned positioned = tester.widget(positionedFinder);
expect(positioned.width, beginWidth);
expect(positioned.height, beginHeight);
expect(positioned.top, beginTop);

// Tap on the 'Tap me' text to start the forward animation.
await tester.tap(find.text('Tap me'));
await tester.pump();

positioned = tester.widget(positionedFinder);
expect(positioned.width, beginWidth);
expect(positioned.height, beginHeight);
expect(positioned.top, beginTop);

// Advance animation to the middle.
await tester.pump(example.AnimatedPositionedExampleApp.duration ~/ 2);

final double t =
example.AnimatedPositionedExampleApp.curve.transform(0.5);

positioned = tester.widget(positionedFinder);
expect(positioned.width, lerpDouble(beginWidth, endWidth, t));
expect(positioned.height, lerpDouble(beginHeight, endHeight, t));
expect(positioned.top, lerpDouble(beginTop, endTop, t));

// Advance animation to the end.
await tester.pump(example.AnimatedPositionedExampleApp.duration ~/ 2);

positioned = tester.widget(positionedFinder);
expect(positioned.width, endWidth);
expect(positioned.height, endHeight);
expect(positioned.top, endTop);

// Tap on the 'Tap me' text again to start the reverse animation.
await tester.tap(find.text('Tap me'));
await tester.pump();

positioned = tester.widget(positionedFinder);
expect(positioned.width, endWidth);
expect(positioned.height, endHeight);
expect(positioned.top, endTop);

// Advance animation to the middle.
await tester.pump(example.AnimatedPositionedExampleApp.duration ~/ 2);

positioned = tester.widget(positionedFinder);
expect(positioned.width, lerpDouble(endWidth, beginWidth, t));
expect(positioned.height, lerpDouble(endHeight, beginHeight, t));
expect(positioned.top, lerpDouble(endTop, beginTop, t));

// Advance animation to the end.
await tester.pump(example.AnimatedPositionedExampleApp.duration ~/ 2);

positioned = tester.widget(positionedFinder);
expect(positioned.width, beginWidth);
expect(positioned.height, beginHeight);
expect(positioned.top, beginTop);
},
);
}

0 comments on commit b0524b3

Please sign in to comment.