Skip to content

Commit b329894

Browse files
author
Hans Muller
authored
Added byTooltip() to CommonFinders (flutter#6178)
1 parent 4d8f4f4 commit b329894

File tree

5 files changed

+20
-41
lines changed

5 files changed

+20
-41
lines changed

examples/flutter_gallery/test/example_code_display_test.dart

Lines changed: 1 addition & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -6,12 +6,6 @@ import 'package:flutter/material.dart';
66
import 'package:flutter_gallery/gallery/app.dart';
77
import 'package:flutter_test/flutter_test.dart';
88

9-
Finder byTooltip(WidgetTester tester, String message) {
10-
return find.byWidgetPredicate((Widget widget) {
11-
return widget is Tooltip && widget.message == message;
12-
});
13-
}
14-
159
void main() {
1610
TestWidgetsFlutterBinding binding = TestWidgetsFlutterBinding.ensureInitialized();
1711
if (binding is LiveTestWidgetsFlutterBinding)
@@ -44,7 +38,7 @@ void main() {
4438
await tester.pump(); // start animation
4539
await tester.pump(const Duration(seconds: 1)); // end animation
4640

47-
await tester.tap(byTooltip(tester, 'Show example code'));
41+
await tester.tap(find.byTooltip('Show example code'));
4842
await tester.pump(); // start animation
4943
await tester.pump(const Duration(seconds: 1)); // end animation
5044

examples/flutter_gallery/test/pesto_test.dart

Lines changed: 0 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -6,16 +6,6 @@ import 'package:flutter/material.dart';
66
import 'package:flutter_test/flutter_test.dart';
77
import 'package:flutter_gallery/gallery/app.dart';
88

9-
Finder byTooltip(WidgetTester tester, String message) {
10-
return find.byWidgetPredicate((Widget widget) {
11-
return widget is Tooltip && widget.message == message;
12-
});
13-
}
14-
15-
Finder findNavigationMenuButton(WidgetTester tester) {
16-
return byTooltip(tester, 'Open navigation menu');
17-
}
18-
199
void main() {
2010
TestWidgetsFlutterBinding binding = TestWidgetsFlutterBinding.ensureInitialized();
2111
if (binding is LiveTestWidgetsFlutterBinding)

examples/flutter_gallery/test/smoke_test.dart

Lines changed: 2 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -24,17 +24,6 @@ Finder findGalleryItemByRouteName(WidgetTester tester, String routeName) {
2424
});
2525
}
2626

27-
Finder byTooltip(WidgetTester tester, String message) {
28-
return find.byWidgetPredicate((Widget widget) {
29-
return widget is Tooltip && widget.message == message;
30-
});
31-
}
32-
33-
Finder findNavigationMenuButton(WidgetTester tester) =>
34-
byTooltip(tester, 'Open navigation menu');
35-
36-
Finder findBackButton(WidgetTester tester) => byTooltip(tester, 'Back');
37-
3827
// Start a gallery demo and then go back. This function assumes that the
3928
// we're starting on the home route and that the submenu that contains
4029
// the item for a demo that pushes route 'routeName' is already open.
@@ -50,7 +39,7 @@ Future<Null> smokeDemo(WidgetTester tester, String routeName) async {
5039
expect(find.text(kCaption), findsNothing);
5140

5241
// Go back
53-
Finder backButton = findBackButton(tester);
42+
Finder backButton = find.byTooltip('Back');
5443
expect(backButton, findsOneWidget);
5544
await tester.tap(backButton);
5645
await tester.pump(); // Start the pop "back" operation.
@@ -86,7 +75,7 @@ void main() {
8675
tester.binding.debugAssertNoTransientCallbacks('A transient callback was still active after leaving route $routeName');
8776
}
8877

89-
Finder navigationMenuButton = findNavigationMenuButton(tester);
78+
Finder navigationMenuButton = find.byTooltip('Open navigation menu');
9079
expect(navigationMenuButton, findsOneWidget);
9180
await tester.tap(navigationMenuButton);
9281
await tester.pump(); // Start opening drawer.

examples/flutter_gallery/test/update_test.dart

Lines changed: 1 addition & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,6 @@
22
// Use of this source code is governed by a BSD-style license that can be
33
// found in the LICENSE file.
44

5-
import 'package:flutter/material.dart';
65
import 'package:flutter_test/flutter_test.dart';
76
import 'package:flutter_gallery/gallery/app.dart';
87

@@ -11,14 +10,6 @@ Future<String> mockUpdateUrlFetcher() {
1110
return new Future<String>.value('http://www.example.com/');
1211
}
1312

14-
Finder byTooltip(WidgetTester tester, String message) {
15-
return find.byWidgetPredicate((Widget widget) {
16-
return widget is Tooltip && widget.message == message;
17-
});
18-
}
19-
20-
Finder findBackButton(WidgetTester tester) => byTooltip(tester, 'Back');
21-
2213
void main() {
2314
TestWidgetsFlutterBinding binding = TestWidgetsFlutterBinding.ensureInitialized();
2415
if (binding is LiveTestWidgetsFlutterBinding) binding.allowAllFrames = true;
@@ -38,7 +29,7 @@ void main() {
3829
await tester.pump(); // Launch shrine
3930
await tester.pump(const Duration(seconds: 1)); // transition is complete
4031

41-
Finder backButton = findBackButton(tester);
32+
Finder backButton = find.byTooltip('Back');
4233
expect(backButton, findsOneWidget);
4334
await tester.tap(backButton);
4435
await tester.pump(); // Start the pop "back" operation.

packages/flutter_test/lib/src/finders.dart

Lines changed: 16 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
// Use of this source code is governed by a BSD-style license that can be
33
// found in the LICENSE file.
44

5-
import 'package:flutter/widgets.dart';
5+
import 'package:flutter/material.dart';
66

77
import 'all_elements.dart';
88

@@ -124,6 +124,21 @@ class CommonFinders {
124124
return new _WidgetPredicateFinder(predicate, skipOffstage: skipOffstage);
125125
}
126126

127+
/// Finds Tooltip widgets with the given message.
128+
///
129+
/// Example:
130+
///
131+
/// expect(tester, hasWidget(find.byTooltip('Back')));
132+
///
133+
/// If the `skipOffstage` argument is true (the default), then this skips
134+
/// nodes that are [Offstage] or that are from inactive [Route]s.
135+
Finder byTooltip(String message, { bool skipOffstage: true }) {
136+
return byWidgetPredicate(
137+
(Widget widget) => widget is Tooltip && widget.message == message,
138+
skipOffstage: skipOffstage,
139+
);
140+
}
141+
127142
/// Finds widgets using an element predicate.
128143
///
129144
/// Example:

0 commit comments

Comments
 (0)