| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | import 'package:appflowy/plugins/database_view/widgets/row/row_banner.dart'; | 
					
						
							|  |  |  | import 'package:appflowy_backend/protobuf/flowy-database2/field_entities.pbenum.dart'; | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  | import 'package:appflowy_backend/protobuf/flowy-folder2/view.pb.dart'; | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | import 'package:appflowy_editor/appflowy_editor.dart'; | 
					
						
							|  |  |  | import 'package:flowy_infra_ui/style_widget/text.dart'; | 
					
						
							| 
									
										
										
										
											2023-07-17 15:09:44 +05:30
										 |  |  | import 'package:flutter/material.dart'; | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | import 'package:flutter_test/flutter_test.dart'; | 
					
						
							|  |  |  | import 'package:integration_test/integration_test.dart'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import 'util/database_test_op.dart'; | 
					
						
							| 
									
										
										
										
											2023-06-27 15:17:51 +08:00
										 |  |  | import 'util/emoji.dart'; | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | import 'util/util.dart'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void main() { | 
					
						
							|  |  |  |   IntegrationTestWidgetsFlutterBinding.ensureInitialized(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   group('grid', () { | 
					
						
							| 
									
										
										
										
											2023-06-22 23:40:49 +08:00
										 |  |  |     testWidgets('row details page opens', (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-06-22 23:40:49 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Make sure that the row page is opened
 | 
					
						
							|  |  |  |       tester.assertRowDetailPageOpened(); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |     testWidgets('insert emoji in the row detail page', (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       await tester.hoverRowBanner(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       await tester.openEmojiPicker(); | 
					
						
							|  |  |  |       await tester.switchToEmojiList(); | 
					
						
							|  |  |  |       await tester.tapEmoji('😀'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // After select the emoji, the EmojiButton will show up
 | 
					
						
							|  |  |  |       await tester.tapButton(find.byType(EmojiButton)); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     testWidgets('update emoji in the row detail page', (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  |       await tester.hoverRowBanner(); | 
					
						
							|  |  |  |       await tester.openEmojiPicker(); | 
					
						
							|  |  |  |       await tester.switchToEmojiList(); | 
					
						
							|  |  |  |       await tester.tapEmoji('😀'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Update existing selected emoji
 | 
					
						
							|  |  |  |       await tester.tapButton(find.byType(EmojiButton)); | 
					
						
							|  |  |  |       await tester.switchToEmojiList(); | 
					
						
							|  |  |  |       await tester.tapEmoji('😅'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // The emoji already displayed in the row banner
 | 
					
						
							|  |  |  |       final emojiText = find.byWidgetPredicate( | 
					
						
							| 
									
										
										
										
											2023-06-16 15:32:28 +08:00
										 |  |  |         (widget) => widget is FlowyText && widget.text == '😅', | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |       ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // The number of emoji should be two. One in the row displayed in the grid
 | 
					
						
							|  |  |  |       // one in the row detail page.
 | 
					
						
							|  |  |  |       expect(emojiText, findsNWidgets(2)); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     testWidgets('remove emoji in the row detail page', (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  |       await tester.hoverRowBanner(); | 
					
						
							|  |  |  |       await tester.openEmojiPicker(); | 
					
						
							|  |  |  |       await tester.switchToEmojiList(); | 
					
						
							|  |  |  |       await tester.tapEmoji('😀'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Remove the emoji
 | 
					
						
							|  |  |  |       await tester.tapButton(find.byType(RemoveEmojiButton)); | 
					
						
							|  |  |  |       final emojiText = find.byWidgetPredicate( | 
					
						
							| 
									
										
										
										
											2023-06-16 15:32:28 +08:00
										 |  |  |         (widget) => widget is FlowyText && widget.text == '😀', | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |       ); | 
					
						
							|  |  |  |       expect(emojiText, findsNothing); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     testWidgets('create list of fields in row detail page', (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       for (final fieldType in [ | 
					
						
							|  |  |  |         FieldType.Checklist, | 
					
						
							|  |  |  |         FieldType.DateTime, | 
					
						
							|  |  |  |         FieldType.Number, | 
					
						
							|  |  |  |         FieldType.URL, | 
					
						
							|  |  |  |         FieldType.MultiSelect, | 
					
						
							|  |  |  |         FieldType.LastEditedTime, | 
					
						
							|  |  |  |         FieldType.CreatedTime, | 
					
						
							|  |  |  |         FieldType.Checkbox, | 
					
						
							|  |  |  |       ]) { | 
					
						
							|  |  |  |         await tester.tapRowDetailPageCreatePropertyButton(); | 
					
						
							|  |  |  |         await tester.renameField(fieldType.name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Open the type option menu
 | 
					
						
							|  |  |  |         await tester.tapTypeOptionButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         await tester.selectFieldType(fieldType); | 
					
						
							|  |  |  |         await tester.dismissFieldEditor(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // After update the field type, the cells should be updated
 | 
					
						
							|  |  |  |         await tester.findCellByFieldType(fieldType); | 
					
						
							|  |  |  |         await tester.scrollRowDetailByOffset(const Offset(0, -50)); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-13 19:10:08 +08:00
										 |  |  |     testWidgets('change order of fields and cells', (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							|  |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Assert that the first field in the row details page is the select
 | 
					
						
							| 
									
										
										
										
											2023-10-02 10:52:22 +08:00
										 |  |  |       // option type
 | 
					
						
							| 
									
										
										
										
											2023-09-13 19:10:08 +08:00
										 |  |  |       tester.assertFirstFieldInRowDetailByType(FieldType.SingleSelect); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Reorder first field in list
 | 
					
						
							|  |  |  |       final gesture = await tester.hoverOnFieldInRowDetail(index: 0); | 
					
						
							|  |  |  |       await tester.pumpAndSettle(); | 
					
						
							|  |  |  |       await tester.reorderFieldInRowDetail(offset: 30); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Orders changed, now the checkbox is first
 | 
					
						
							|  |  |  |       tester.assertFirstFieldInRowDetailByType(FieldType.Checkbox); | 
					
						
							|  |  |  |       await gesture.removePointer(); | 
					
						
							|  |  |  |       await tester.pumpAndSettle(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Reorder second field in list
 | 
					
						
							|  |  |  |       await tester.hoverOnFieldInRowDetail(index: 1); | 
					
						
							|  |  |  |       await tester.pumpAndSettle(); | 
					
						
							|  |  |  |       await tester.reorderFieldInRowDetail(offset: -30); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // First field is now back to select option
 | 
					
						
							|  |  |  |       tester.assertFirstFieldInRowDetailByType(FieldType.SingleSelect); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-02 10:52:22 +08:00
										 |  |  |     testWidgets('hide and show hidden fields', (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							|  |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Assert that the show hidden fields button isn't visible
 | 
					
						
							|  |  |  |       tester.assertToggleShowHiddenFieldsVisibility(false); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Hide the first field in the field list
 | 
					
						
							|  |  |  |       await tester.tapGridFieldWithNameInRowDetailPage("Type"); | 
					
						
							|  |  |  |       await tester.tapHidePropertyButtonInFieldEditor(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Assert that the field is now hidden
 | 
					
						
							|  |  |  |       tester.noFieldWithName("Type"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Assert that the show hidden fields button appears
 | 
					
						
							|  |  |  |       tester.assertToggleShowHiddenFieldsVisibility(true); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Click on the show hidden fields button
 | 
					
						
							|  |  |  |       await tester.toggleShowHiddenFields(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Assert that the hidden field is shown again and that the show
 | 
					
						
							|  |  |  |       // hidden fields button is still present
 | 
					
						
							|  |  |  |       tester.findFieldWithName("Type"); | 
					
						
							|  |  |  |       tester.assertToggleShowHiddenFieldsVisibility(true); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Click hide hidden fields
 | 
					
						
							|  |  |  |       await tester.toggleShowHiddenFields(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Assert that the hidden field has vanished
 | 
					
						
							|  |  |  |       tester.noFieldWithName("Type"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Click show hidden fields
 | 
					
						
							|  |  |  |       await tester.toggleShowHiddenFields(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // delete the hidden field
 | 
					
						
							|  |  |  |       await tester.tapGridFieldWithNameInRowDetailPage("Type"); | 
					
						
							|  |  |  |       await tester.tapDeletePropertyInFieldEditor(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Assert that the that the show hidden fields button is gone
 | 
					
						
							|  |  |  |       tester.assertToggleShowHiddenFieldsVisibility(false); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-13 19:10:08 +08:00
										 |  |  |     testWidgets('check document exists in row detail page', (tester) async { | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Each row detail page should have a document
 | 
					
						
							|  |  |  |       await tester.assertDocumentExistInRowDetailPage(); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-13 19:10:08 +08:00
										 |  |  |     testWidgets('update the contents of the document and re-open it', | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |         (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Wait for the document to be loaded
 | 
					
						
							|  |  |  |       await tester.wait(500); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Focus on the editor
 | 
					
						
							| 
									
										
										
										
											2023-10-11 23:12:23 +08:00
										 |  |  |       final textBlock = find.byType(ParagraphBlockComponentWidget); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |       await tester.tapAt(tester.getCenter(textBlock)); | 
					
						
							| 
									
										
										
										
											2023-07-09 10:03:22 +07:00
										 |  |  |       await tester.pumpAndSettle(); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Input some text
 | 
					
						
							| 
									
										
										
										
											2023-07-09 10:03:22 +07:00
										 |  |  |       const inputText = 'Hello World'; | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |       await tester.ime.insertText(inputText); | 
					
						
							|  |  |  |       expect( | 
					
						
							|  |  |  |         find.textContaining(inputText, findRichText: true), | 
					
						
							|  |  |  |         findsOneWidget, | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Tap outside to dismiss the field
 | 
					
						
							|  |  |  |       await tester.tapAt(Offset.zero); | 
					
						
							|  |  |  |       await tester.pumpAndSettle(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Re-open the document
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  |       expect( | 
					
						
							|  |  |  |         find.textContaining(inputText, findRichText: true), | 
					
						
							|  |  |  |         findsOneWidget, | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-17 15:09:44 +05:30
										 |  |  |     testWidgets( | 
					
						
							|  |  |  |         'check if the title wraps properly when a long text is inserted', | 
					
						
							|  |  |  |         (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-07-17 15:09:44 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Wait for the document to be loaded
 | 
					
						
							|  |  |  |       await tester.wait(500); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Focus on the editor
 | 
					
						
							|  |  |  |       final textField = find | 
					
						
							|  |  |  |           .descendant( | 
					
						
							|  |  |  |             of: find.byType(SimpleDialog), | 
					
						
							|  |  |  |             matching: find.byType(TextField), | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |           .first; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Input a long text
 | 
					
						
							|  |  |  |       await tester.enterText(textField, 'Long text' * 25); | 
					
						
							|  |  |  |       await tester.pumpAndSettle(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Tap outside to dismiss the field
 | 
					
						
							|  |  |  |       await tester.tapAt(Offset.zero); | 
					
						
							|  |  |  |       await tester.pumpAndSettle(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Check if there is any overflow in the widget tree
 | 
					
						
							|  |  |  |       expect(tester.takeException(), isNull); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Re-open the document
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Check again if there is any overflow in the widget tree
 | 
					
						
							|  |  |  |       expect(tester.takeException(), isNull); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |     testWidgets('delete row in row detail page', (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-13 19:10:08 +08:00
										 |  |  |       await tester.tapRowDetailPageRowActionButton(); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |       await tester.tapRowDetailPageDeleteRowButton(); | 
					
						
							|  |  |  |       await tester.tapEscButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       await tester.assertNumberOfRowsInGridPage(2); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     testWidgets('duplicate row in row detail page', (tester) async { | 
					
						
							|  |  |  |       await tester.initializeAppFlowy(); | 
					
						
							|  |  |  |       await tester.tapGoButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // Create a new grid
 | 
					
						
							| 
									
										
										
										
											2023-07-31 19:06:01 +07:00
										 |  |  |       await tester.createNewPageWithName(layout: ViewLayoutPB.Grid); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // Hover first row and then open the row page
 | 
					
						
							|  |  |  |       await tester.openFirstRowDetailPage(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-13 19:10:08 +08:00
										 |  |  |       await tester.tapRowDetailPageRowActionButton(); | 
					
						
							| 
									
										
										
										
											2023-06-14 22:16:33 +08:00
										 |  |  |       await tester.tapRowDetailPageDuplicateRowButton(); | 
					
						
							|  |  |  |       await tester.tapEscButton(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       await tester.assertNumberOfRowsInGridPage(4); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | } |