mirror of
				https://github.com/AppFlowy-IO/AppFlowy.git
				synced 2025-10-25 06:51:51 +00:00 
			
		
		
		
	 37ddce3a29
			
		
	
	
		37ddce3a29
		
			
		
	
	
	
	
		
			
			* chore: update calendar theming * feat: add event popup editor * chore: new event button redesign and add card shadows * chore: unscheduled events button * chore: event title text field * fix: focus node double dispose * chore: show popover when create new event * test: integrate some tests for integration testing purposes * fix: some fixes and more integration tests
		
			
				
	
	
		
			239 lines
		
	
	
		
			8.2 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			239 lines
		
	
	
		
			8.2 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:appflowy_backend/protobuf/flowy-database2/setting_entities.pbenum.dart';
 | |
| import 'package:appflowy_backend/protobuf/flowy-folder2/view.pbenum.dart';
 | |
| import 'package:flutter_test/flutter_test.dart';
 | |
| import 'package:integration_test/integration_test.dart';
 | |
| 
 | |
| import 'util/database_test_op.dart';
 | |
| import 'util/util.dart';
 | |
| 
 | |
| void main() {
 | |
|   IntegrationTestWidgetsFlutterBinding.ensureInitialized();
 | |
| 
 | |
|   group('calendar', () {
 | |
|     testWidgets('update calendar layout', (tester) async {
 | |
|       await tester.initializeAppFlowy();
 | |
|       await tester.tapGoButton();
 | |
| 
 | |
|       await tester.createNewPageWithName(layout: ViewLayoutPB.Calendar);
 | |
| 
 | |
|       // open setting
 | |
|       await tester.tapDatabaseSettingButton();
 | |
|       await tester.tapDatabaseLayoutButton();
 | |
|       await tester.selectDatabaseLayoutType(DatabaseLayoutPB.Board);
 | |
|       await tester.assertCurrentDatabaseLayoutType(DatabaseLayoutPB.Board);
 | |
| 
 | |
|       await tester.tapDatabaseSettingButton();
 | |
|       await tester.tapDatabaseLayoutButton();
 | |
|       await tester.selectDatabaseLayoutType(DatabaseLayoutPB.Grid);
 | |
|       await tester.assertCurrentDatabaseLayoutType(DatabaseLayoutPB.Grid);
 | |
| 
 | |
|       await tester.pumpAndSettle();
 | |
|     });
 | |
| 
 | |
|     testWidgets('calendar start from day setting', (tester) async {
 | |
|       await tester.initializeAppFlowy();
 | |
|       await tester.tapGoButton();
 | |
| 
 | |
|       // Create calendar view
 | |
|       const name = 'calendar';
 | |
|       await tester.createNewPageWithName(
 | |
|         name: name,
 | |
|         layout: ViewLayoutPB.Calendar,
 | |
|       );
 | |
| 
 | |
|       // Open setting
 | |
|       await tester.tapDatabaseSettingButton();
 | |
|       await tester.tapCalendarLayoutSettingButton();
 | |
| 
 | |
|       // select the first day of week is Monday
 | |
|       await tester.tapFirstDayOfWeek();
 | |
|       await tester.tapFirstDayOfWeekStartFromMonday();
 | |
| 
 | |
|       // Open the other page and open the new calendar page again
 | |
|       await tester.openPage(gettingStarted);
 | |
|       await tester.pumpAndSettle(const Duration(milliseconds: 300));
 | |
|       await tester.openPage(name, layout: ViewLayoutPB.Calendar);
 | |
| 
 | |
|       // Open setting again and check the start from Monday is selected
 | |
|       await tester.tapDatabaseSettingButton();
 | |
|       await tester.tapCalendarLayoutSettingButton();
 | |
|       await tester.tapFirstDayOfWeek();
 | |
|       tester.assertFirstDayOfWeekStartFromMonday();
 | |
| 
 | |
|       await tester.pumpAndSettle();
 | |
|     });
 | |
| 
 | |
|     testWidgets('creating and editing calendar events', (tester) async {
 | |
|       await tester.initializeAppFlowy();
 | |
|       await tester.tapGoButton();
 | |
| 
 | |
|       // Create the calendar view
 | |
|       await tester.createNewPageWithName(layout: ViewLayoutPB.Calendar);
 | |
| 
 | |
|       // Scroll until today's date cell is visible
 | |
|       await tester.scrollToToday();
 | |
| 
 | |
|       // Hover over today's calendar cell
 | |
|       await tester.hoverOnTodayCalendarCell();
 | |
| 
 | |
|       // Tap on create new event button
 | |
|       await tester.tapAddCalendarEventButton();
 | |
| 
 | |
|       // Make sure that the event editor popup is shown
 | |
|       tester.assertEventEditorOpen();
 | |
| 
 | |
|       tester.assertNumberOfEventsInCalendar(1);
 | |
| 
 | |
|       // Dismiss the event editor popup
 | |
|       await tester.dismissEventEditor();
 | |
| 
 | |
|       // Double click on today's calendar cell to create a new event
 | |
|       await tester.doubleClickCalendarCell(DateTime.now());
 | |
| 
 | |
|       // Make sure that the event editor popup is shown
 | |
|       tester.assertEventEditorOpen();
 | |
| 
 | |
|       // Make sure that the event is inserted in the cell
 | |
|       tester.assertNumberOfEventsInCalendar(2);
 | |
| 
 | |
|       // Dismiss the event editor popup
 | |
|       await tester.dismissEventEditor();
 | |
| 
 | |
|       // Click on the event
 | |
|       await tester.openCalendarEvent(index: 0);
 | |
|       tester.assertEventEditorOpen();
 | |
| 
 | |
|       // Change the title of the event
 | |
|       await tester.editEventTitle('hello world');
 | |
|       await tester.dismissEventEditor();
 | |
| 
 | |
|       // Make sure that the event is edited
 | |
|       tester.assertNumberOfEventsInCalendar(1, title: 'hello world');
 | |
|       tester.assertNumberOfEventsOnSpecificDay(2, DateTime.now());
 | |
| 
 | |
|       // Click on the event
 | |
|       await tester.openCalendarEvent(index: 1);
 | |
|       tester.assertEventEditorOpen();
 | |
| 
 | |
|       // Click on the open icon
 | |
|       await tester.openEventToRowDetailPage();
 | |
|       tester.assertRowDetailPageOpened();
 | |
| 
 | |
|       // Duplicate the event
 | |
|       await tester.tapRowDetailPageRowActionButton();
 | |
|       await tester.tapRowDetailPageDuplicateRowButton();
 | |
|       await tester.dismissRowDetailPage();
 | |
| 
 | |
|       // Check that there are 2 events
 | |
|       tester.assertNumberOfEventsInCalendar(2, title: 'hello world');
 | |
|       tester.assertNumberOfEventsOnSpecificDay(3, DateTime.now());
 | |
| 
 | |
|       // Delete an event
 | |
|       await tester.openCalendarEvent(index: 1);
 | |
|       await tester.deleteEventFromEventEditor();
 | |
| 
 | |
|       // Check that there is 1 event
 | |
|       tester.assertNumberOfEventsInCalendar(1, title: 'hello world');
 | |
|       tester.assertNumberOfEventsOnSpecificDay(2, DateTime.now());
 | |
| 
 | |
|       // Delete event from row detail page
 | |
|       await tester.openCalendarEvent(index: 1);
 | |
|       await tester.openEventToRowDetailPage();
 | |
|       tester.assertRowDetailPageOpened();
 | |
| 
 | |
|       await tester.tapRowDetailPageRowActionButton();
 | |
|       await tester.tapRowDetailPageDeleteRowButton();
 | |
| 
 | |
|       // Check that there is 0 event
 | |
|       tester.assertNumberOfEventsInCalendar(0, title: 'hello world');
 | |
|       tester.assertNumberOfEventsOnSpecificDay(1, DateTime.now());
 | |
|     });
 | |
| 
 | |
|     testWidgets('rescheduling events', (tester) async {
 | |
|       await tester.initializeAppFlowy();
 | |
|       await tester.tapGoButton();
 | |
| 
 | |
|       // Create the calendar view
 | |
|       await tester.createNewPageWithName(layout: ViewLayoutPB.Calendar);
 | |
| 
 | |
|       // Create a new event on the first of this month
 | |
|       final today = DateTime.now();
 | |
|       final firstOfThisMonth = DateTime(today.year, today.month, 1);
 | |
|       await tester.doubleClickCalendarCell(firstOfThisMonth);
 | |
|       await tester.dismissEventEditor();
 | |
| 
 | |
|       // Drag and drop the event onto the next week, same day
 | |
|       await tester.dragDropRescheduleCalendarEvent(firstOfThisMonth);
 | |
| 
 | |
|       // Make sure that the event has been rescheduled to the new date
 | |
|       final sameDayNextWeek = firstOfThisMonth.add(const Duration(days: 7));
 | |
|       tester.assertNumberOfEventsInCalendar(1);
 | |
|       tester.assertNumberOfEventsOnSpecificDay(1, sameDayNextWeek);
 | |
| 
 | |
|       // Delete the event
 | |
|       await tester.openCalendarEvent(index: 0, date: sameDayNextWeek);
 | |
|       await tester.deleteEventFromEventEditor();
 | |
| 
 | |
|       // Create a new event in today's calendar cell
 | |
|       await tester.scrollToToday();
 | |
|       await tester.doubleClickCalendarCell(today);
 | |
|       await tester.dismissEventEditor();
 | |
| 
 | |
|       // Make sure that the event is today
 | |
|       tester.assertNumberOfEventsOnSpecificDay(1, today);
 | |
| 
 | |
|       // Click on the event
 | |
|       await tester.openCalendarEvent(index: 0);
 | |
| 
 | |
|       // Open the date editor of the event
 | |
|       await tester.tapDateCellInRowDetailPage();
 | |
|       await tester.findDateEditor(findsOneWidget);
 | |
| 
 | |
|       // Edit the event's date. To avoid selecting a day outside of the current month, the new date will be one day closer to the middle of the month.
 | |
|       final newDate = today.day < 15
 | |
|           ? today.add(const Duration(days: 1))
 | |
|           : today.subtract(const Duration(days: 1));
 | |
|       await tester.selectDay(content: newDate.day);
 | |
|       await tester.dismissCellEditor();
 | |
| 
 | |
|       // Dismiss the event editor
 | |
|       await tester.dismissEventEditor();
 | |
| 
 | |
|       // Make sure that the event is edited
 | |
|       tester.assertNumberOfEventsInCalendar(1);
 | |
|       tester.assertNumberOfEventsOnSpecificDay(1, newDate);
 | |
| 
 | |
|       // Click on the unscheduled events button
 | |
|       await tester.openUnscheduledEventsPopup();
 | |
| 
 | |
|       // Assert that nothing shows up
 | |
|       tester.findUnscheduledPopup(findsNothing, 0);
 | |
| 
 | |
|       // Click on the event in the calendar
 | |
|       await tester.openCalendarEvent(index: 0, date: newDate);
 | |
| 
 | |
|       // Open the date editor of the event
 | |
|       await tester.tapDateCellInRowDetailPage();
 | |
|       await tester.findDateEditor(findsOneWidget);
 | |
| 
 | |
|       // Clear the date of the event
 | |
|       await tester.clearDate();
 | |
| 
 | |
|       // Dismiss the event editor
 | |
|       await tester.dismissEventEditor();
 | |
|       tester.assertNumberOfEventsInCalendar(0);
 | |
| 
 | |
|       // Click on the unscheduled events button
 | |
|       await tester.openUnscheduledEventsPopup();
 | |
| 
 | |
|       // Assert that a popup appears and 1 unscheduled event
 | |
|       tester.findUnscheduledPopup(findsOneWidget, 1);
 | |
| 
 | |
|       // Click on the unscheduled event
 | |
|       await tester.clickUnscheduledEvent();
 | |
| 
 | |
|       tester.assertRowDetailPageOpened();
 | |
|     });
 | |
|   });
 | |
| }
 |