1
0
mirror of https://github.com/flutter/samples.git synced 2025-11-08 22:09:06 +00:00
Files
samples/context_menus/test/custom_menu_page_test.dart
Eric Windmill 2999d738b8 Dart 3.9 / Flutter 3.35 [first LLM release] (#2714)
I got carried away with Gemini and basically rewrote CI and the release
process for the new LLM reality. This work was largely completed by
Gemini.

- Bump all SDK versions to the current beta (3.9.0-0)
- Run `flutter channel beta`
- Wrote `ci_script.dart` to replace the bash scripts
- Converted repository to pub workspace #2499 
- Added llm.md and release.md
- Added redirect for deprecated Samples Index

## Pre-launch Checklist

- [x] I read the [Flutter Style Guide] _recently_, and have followed its
advice.
- [x] I signed the [CLA].
- [x] I read the [Contributors Guide].
- [x] I have added sample code updates to the [changelog].
- [x] I updated/added relevant documentation (doc comments with `///`).
2025-08-14 12:26:24 -07:00

68 lines
2.1 KiB
Dart

import 'package:context_menus/custom_menu_page.dart';
import 'package:context_menus/main.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/gestures.dart';
import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart';
void main() {
testWidgets('Shows default buttons in a custom context menu', (
tester,
) async {
await tester.pumpWidget(const MyApp());
// Navigate to the CustomMenuPage example.
await tester.dragUntilVisible(
find.text(CustomMenuPage.title),
find.byType(ListView),
const Offset(0.0, -200.0),
);
await tester.pumpAndSettle();
await tester.tap(find.text(CustomMenuPage.title));
await tester.pumpAndSettle();
// Right click on the text field to show the context menu.
final TestGesture gesture = await tester.startGesture(
tester.getCenter(find.byType(EditableText)),
kind: PointerDeviceKind.mouse,
buttons: kSecondaryMouseButton,
);
await tester.pump();
await gesture.up();
await gesture.removePointer();
await tester.pumpAndSettle();
// A custom context menu is shown, and the buttons are the default ones.
expect(find.byType(AdaptiveTextSelectionToolbar), findsNothing);
expect(
find.byType(CupertinoAdaptiveTextSelectionToolbar),
findsNothing,
);
switch (defaultTargetPlatform) {
case TargetPlatform.iOS:
expect(
find.byType(CupertinoTextSelectionToolbarButton),
findsNWidgets(2),
);
case TargetPlatform.macOS:
expect(
find.byType(CupertinoDesktopTextSelectionToolbarButton),
findsNWidgets(2),
);
case TargetPlatform.android:
case TargetPlatform.fuchsia:
expect(
find.byType(TextSelectionToolbarTextButton),
findsNWidgets(1),
);
case TargetPlatform.linux:
case TargetPlatform.windows:
expect(
find.byType(DesktopTextSelectionToolbarButton),
findsNWidgets(1),
);
}
});
}