mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
80a273edae
* fix: create a new document * fix: the banner don't show after deleteing the page * fix: inserting a divider through the slash menu the cursor should stay active in the next line * fix: the overlay doesn't dismiss after selecting a page * fix: typo * fix: delete the page in document if it has been deleted * chore: l10n * chore: rename events * ci: rm install_diesel in ci * fix: cover color not working * ci: fix tauri build --------- Co-authored-by: nathan <nathan@appflowy.io>
101 lines
2.9 KiB
Dart
101 lines
2.9 KiB
Dart
import 'dart:ui';
|
|
|
|
import 'package:appflowy/generated/locale_keys.g.dart';
|
|
import 'package:appflowy/plugins/document/presentation/banner.dart';
|
|
import 'package:appflowy/user/presentation/skip_log_in_screen.dart';
|
|
import 'package:appflowy/workspace/presentation/home/home_stack.dart';
|
|
import 'package:appflowy/workspace/presentation/home/menu/app/header/add_button.dart';
|
|
import 'package:appflowy/workspace/presentation/home/menu/app/section/item.dart';
|
|
import 'package:easy_localization/easy_localization.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
|
|
import 'base.dart';
|
|
|
|
const String readme = 'Read me';
|
|
|
|
extension AppFlowyLaunch on WidgetTester {
|
|
Future<void> tapGoButton() async {
|
|
final goButton = find.byType(GoButton);
|
|
await tapButton(goButton);
|
|
}
|
|
|
|
Future<void> tapCreateButton() async {
|
|
await tapButtonWithName(LocaleKeys.settings_files_create.tr());
|
|
}
|
|
|
|
void expectToSeeWelcomePage() {
|
|
expect(find.byType(HomeStack), findsOneWidget);
|
|
expect(find.textContaining('Read me'), findsNWidgets(2));
|
|
}
|
|
|
|
Future<void> tapAddButton() async {
|
|
final addButton = find.byType(AddButton);
|
|
await tapButton(addButton);
|
|
}
|
|
|
|
Future<void> tapCreateDocumentButton() async {
|
|
await tapButtonWithName(LocaleKeys.document_menuName.tr());
|
|
}
|
|
|
|
Finder findPageName(String name) {
|
|
return find.byWidgetPredicate(
|
|
(widget) => widget is ViewSectionItem && widget.view.name == name,
|
|
);
|
|
}
|
|
|
|
void expectToSeePageName(String name) {
|
|
final pageName = findPageName(name);
|
|
expect(pageName, findsOneWidget);
|
|
}
|
|
|
|
void expectNotToSeePageName(String name) {
|
|
final pageName = findPageName(name);
|
|
expect(pageName, findsNothing);
|
|
}
|
|
|
|
Future<void> hoverOnPageName(String name) async {
|
|
final pageName = find.byWidgetPredicate(
|
|
(widget) => widget is ViewSectionItem && widget.view.name == name,
|
|
);
|
|
|
|
final gesture = await createGesture(kind: PointerDeviceKind.mouse);
|
|
await gesture.addPointer(location: Offset.zero);
|
|
addTearDown(gesture.removePointer);
|
|
await pump();
|
|
await gesture.moveTo(getCenter(pageName));
|
|
await pumpAndSettle();
|
|
}
|
|
|
|
Future<void> tapPageOptionButton() async {
|
|
final optionButton = find.byType(ViewDisclosureButton);
|
|
await tapButton(optionButton);
|
|
}
|
|
|
|
Future<void> tapDeletePageButton() async {
|
|
await tapPageOptionButton();
|
|
await tapButtonWithName(ViewDisclosureAction.delete.name);
|
|
}
|
|
|
|
void expectToSeeDocumentBanner() {
|
|
expect(find.byType(DocumentBanner), findsOneWidget);
|
|
}
|
|
|
|
void expectNotToSeeDocumentBanner() {
|
|
expect(find.byType(DocumentBanner), findsNothing);
|
|
}
|
|
|
|
Future<void> tapRestoreButton() async {
|
|
final restoreButton = find.textContaining(
|
|
LocaleKeys.deletePagePrompt_restore.tr(),
|
|
);
|
|
await tapButton(restoreButton);
|
|
}
|
|
|
|
Future<void> tapDeletePermanentlyButton() async {
|
|
final restoreButton = find.textContaining(
|
|
LocaleKeys.deletePagePrompt_deletePermanent.tr(),
|
|
);
|
|
await tapButton(restoreButton);
|
|
}
|
|
}
|