// 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/cupertino.dart'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; import 'package:flutter_api_samples/material/context_menu/editable_text_toolbar_builder.0.dart' as example; import 'package:flutter_test/flutter_test.dart'; void main() { testWidgets( 'showing and hiding the context menu in TextField with custom buttons', (WidgetTester tester) async { await tester.pumpWidget( const example.EditableTextToolbarBuilderExampleApp(), ); expect(BrowserContextMenu.enabled, !kIsWeb); await tester.tap(find.byType(EditableText)); await tester.pump(); expect(find.byType(AdaptiveTextSelectionToolbar), findsNothing); // Long pressing the field shows the default context menu but with custom // buttons. await tester.longPress(find.byType(EditableText)); await tester.pumpAndSettle(); expect(find.byType(AdaptiveTextSelectionToolbar), findsOneWidget); expect(find.byType(CupertinoButton), findsAtLeastNWidgets(1)); // Tap to dismiss. await tester.tapAt(tester.getTopLeft(find.byType(EditableText))); await tester.pumpAndSettle(); expect(find.byType(AdaptiveTextSelectionToolbar), findsNothing); expect(find.byType(CupertinoButton), findsNothing); }, ); }