mirror of
https://github.com/flutter/flutter.git
synced 2025-06-03 00:51:18 +00:00

<!-- Thanks for filing a pull request! Reviewers are typically assigned within a week of filing a request. To learn more about code review, see our documentation on Tree Hygiene: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md --> Fix https://github.com/flutter/flutter/issues/162506 | before | after | | --------------- | --------------- | <video src="https://github.com/user-attachments/assets/91c82b7c-3449-4b65-9b7a-547030dd6536"/> | <img src="https://github.com/user-attachments/assets/a32ecb23-3c87-4b95-8687-d7b3d8190863"/> ## Pre-launch Checklist - [x] I read the [Contributor Guide] and followed the process outlined there for submitting PRs. - [x] I read the [Tree Hygiene] wiki page, which explains my responsibilities. - [x] I read and followed the [Flutter Style Guide], including [Features we expect every widget to implement]. - [x] I signed the [CLA]. - [x] I listed at least one issue that this PR fixes in the description above. - [ ] I updated/added relevant documentation (doc comments with `///`). - [x] I added new tests to check the change I am making, or this PR is [test-exempt]. - [x] I followed the [breaking change policy] and added [Data Driven Fixes] where supported. - [x] All existing and new tests are passing. If you need help, consider asking for advice on the #hackers-new channel on [Discord]. <!-- Links --> [Contributor Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#overview [Tree Hygiene]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md [test-exempt]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#tests [Flutter Style Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md [Features we expect every widget to implement]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md#features-we-expect-every-widget-to-implement [CLA]: https://cla.developers.google.com/ [flutter/tests]: https://github.com/flutter/tests [breaking change policy]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#handling-breaking-changes [Discord]: https://github.com/flutter/flutter/blob/main/docs/contributing/Chat.md [Data Driven Fixes]: https://github.com/flutter/flutter/blob/main/docs/contributing/Data-driven-Fixes.md --------- Signed-off-by: huycozy <huy@nevercode.io>
111 lines
4.1 KiB
Dart
111 lines
4.1 KiB
Dart
// 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_api_samples/material/dropdown_menu/dropdown_menu.0.dart' as example;
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
|
|
void main() {
|
|
testWidgets('DropdownMenu', (WidgetTester tester) async {
|
|
await tester.pumpWidget(const example.DropdownMenuExample());
|
|
|
|
expect(find.text('You selected a Blue Smile'), findsNothing);
|
|
|
|
final Finder colorMenu = find.byType(DropdownMenu<example.ColorLabel>);
|
|
final Finder iconMenu = find.byType(DropdownMenu<example.IconLabel>);
|
|
expect(colorMenu, findsOneWidget);
|
|
expect(iconMenu, findsOneWidget);
|
|
|
|
Finder findMenuItem(String label) {
|
|
return find.widgetWithText(MenuItemButton, label).last;
|
|
}
|
|
|
|
await tester.tap(colorMenu);
|
|
await tester.pumpAndSettle();
|
|
expect(findMenuItem('Blue'), findsOneWidget);
|
|
expect(findMenuItem('Pink'), findsOneWidget);
|
|
expect(findMenuItem('Green'), findsOneWidget);
|
|
expect(findMenuItem('Orange'), findsOneWidget);
|
|
expect(findMenuItem('Grey'), findsOneWidget);
|
|
|
|
await tester.tap(findMenuItem('Blue'));
|
|
|
|
// The DropdownMenu's onSelected callback is delayed
|
|
// with SchedulerBinding.instance.addPostFrameCallback
|
|
// to give the focus a chance to return to where it was
|
|
// before the menu appeared. The pumpAndSettle()
|
|
// give the callback a chance to run.
|
|
await tester.pumpAndSettle();
|
|
|
|
await tester.tap(iconMenu);
|
|
await tester.pumpAndSettle();
|
|
expect(findMenuItem('Smile'), findsOneWidget);
|
|
expect(findMenuItem('Cloud'), findsOneWidget);
|
|
expect(findMenuItem('Brush'), findsOneWidget);
|
|
expect(findMenuItem('Heart'), findsOneWidget);
|
|
|
|
await tester.tap(findMenuItem('Smile'));
|
|
await tester.pumpAndSettle();
|
|
|
|
expect(find.text('You selected a Blue Smile'), findsOneWidget);
|
|
});
|
|
|
|
testWidgets('DropdownMenu has focus when tapping on the text field', (WidgetTester tester) async {
|
|
await tester.pumpWidget(const example.DropdownMenuExample());
|
|
|
|
// Make sure the dropdown menus are there.
|
|
final Finder colorMenu = find.byType(DropdownMenu<example.ColorLabel>);
|
|
final Finder iconMenu = find.byType(DropdownMenu<example.IconLabel>);
|
|
expect(colorMenu, findsOneWidget);
|
|
expect(iconMenu, findsOneWidget);
|
|
|
|
// Tap on the color menu and make sure it is focused.
|
|
await tester.tap(colorMenu);
|
|
await tester.pumpAndSettle();
|
|
expect(FocusScope.of(tester.element(colorMenu)).hasFocus, isTrue);
|
|
|
|
// Tap on the icon menu and make sure it is focused.
|
|
await tester.tap(iconMenu);
|
|
await tester.pumpAndSettle();
|
|
expect(FocusScope.of(tester.element(iconMenu)).hasFocus, isTrue);
|
|
});
|
|
|
|
testWidgets('DropdownMenu on small screen', (WidgetTester tester) async {
|
|
await tester.pumpWidget(const example.DropdownMenuExample());
|
|
|
|
final Finder colorMenu = find.byType(DropdownMenu<example.ColorLabel>);
|
|
final Finder iconMenu = find.byType(DropdownMenu<example.IconLabel>);
|
|
expect(colorMenu, findsOneWidget);
|
|
expect(iconMenu, findsOneWidget);
|
|
|
|
Finder findMenuItem(String label) {
|
|
return find.widgetWithText(MenuItemButton, label).last;
|
|
}
|
|
|
|
await tester.tap(colorMenu);
|
|
await tester.pumpAndSettle();
|
|
final Finder menuBlue = findMenuItem('Blue');
|
|
await tester.ensureVisible(menuBlue);
|
|
await tester.tap(menuBlue);
|
|
await tester.pumpAndSettle();
|
|
|
|
await tester.tap(iconMenu);
|
|
await tester.pumpAndSettle();
|
|
final Finder menuSmile = findMenuItem('Smile');
|
|
await tester.ensureVisible(menuSmile);
|
|
await tester.tap(menuSmile);
|
|
await tester.pumpAndSettle();
|
|
|
|
expect(find.text('You selected a Blue Smile'), findsOneWidget);
|
|
|
|
// Resize the screen to small screen and make sure no overflowed error appears.
|
|
tester.binding.window.physicalSizeTestValue = const Size(200, 160);
|
|
tester.binding.window.devicePixelRatioTestValue = 1.0;
|
|
addTearDown(tester.binding.window.clearPhysicalSizeTestValue);
|
|
await tester.pump();
|
|
|
|
expect(tester.takeException(), isNull);
|
|
});
|
|
}
|