mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
efc857d752
* chore: some ui improvements * fix: integration test * feat: language selector on welcome page (#2796) * feat: add language selector on welcome page * feat: add hover effect and refactor layout * test: add basic languge selector testing * chore: increate place holder width * fix: add catch error for setLocale and finish the testing * chore: update comment * feat: refactor the skip login in page and add tests --------- Co-authored-by: Lucas.Xu <lucas.xu@appflowy.io> * feat: row document (#2792) * chore: create orphan view handler * feat: save icon url and cover url in view * feat: implement emoji picker UI * chore: config ui * chore: config ui again * chore: replace RowPB with RowMetaPB to exposing more row information * fix: compile error * feat: show emoji in row * chore: update * test: insert emoji test * test: add update emoji test * test: add remove emoji test * test: add create field tests * test: add create row and delete row integration tests * test: add create row from row menu * test: document in row detail page * test: delete, duplicate row in row detail page * test: check the row count displayed in grid page * test: rename existing field in grid page * test: update field type of exisiting field in grid page * test: delete field test * test: add duplicate field test * test: add hide field test * test: add edit text cell test * test: add insert text to text cell test * test: add edit number cell test * test: add edit multiple number cells * test: add edit checkbox cell test * feat: integrate editor into database row * test: add edit create time and last edit time cell test * test: add edit date cell by selecting a date test * chore: remove unused code * chore: update checklist bg color * test: add update database layout test --------- Co-authored-by: Lucas.Xu <lucas.xu@appflowy.io> * test: fix test * test: add create select option test --------- Co-authored-by: Yijing Huang <hyj891204@gmail.com> Co-authored-by: Lucas.Xu <lucas.xu@appflowy.io> Co-authored-by: Nathan.fooo <86001920+appflowy@users.noreply.github.com> Co-authored-by: nathan <nathan@appflowy.io>
142 lines
3.8 KiB
Dart
142 lines
3.8 KiB
Dart
import 'dart:io';
|
|
|
|
import 'package:appflowy/core/config/kv_keys.dart';
|
|
import 'package:appflowy/startup/entry_point.dart';
|
|
import 'package:appflowy/startup/startup.dart';
|
|
import 'package:appflowy/startup/tasks/prelude.dart';
|
|
import 'package:flowy_infra_ui/flowy_infra_ui.dart';
|
|
import 'package:flutter/gestures.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter/services.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
import 'package:path_provider/path_provider.dart';
|
|
import 'package:shared_preferences/shared_preferences.dart';
|
|
|
|
class TestFolder {
|
|
/// Location / Path
|
|
|
|
/// Set a given AppFlowy data storage location under test environment.
|
|
///
|
|
/// To pass null means clear the location.
|
|
///
|
|
/// The file_picker is a system component and can't be tapped, so using logic instead of tapping.
|
|
///
|
|
static Future<void> setTestLocation(String? name) async {
|
|
final location = await testLocation(name);
|
|
SharedPreferences.setMockInitialValues({
|
|
KVKeys.pathLocation: location.path,
|
|
});
|
|
return;
|
|
}
|
|
|
|
/// Clean the location.
|
|
static Future<void> cleanTestLocation(String? name) async {
|
|
final dir = await testLocation(name);
|
|
await dir.delete(recursive: true);
|
|
return;
|
|
}
|
|
|
|
/// Get current using location.
|
|
static Future<String> currentLocation() async {
|
|
final prefs = await SharedPreferences.getInstance();
|
|
return prefs.getString(KVKeys.pathLocation)!;
|
|
}
|
|
|
|
/// Get default location under development environment.
|
|
static Future<String> defaultDevelopmentLocation() async {
|
|
final dir = await appFlowyDocumentDirectory();
|
|
return dir.path;
|
|
}
|
|
|
|
/// Get default location under test environment.
|
|
static Future<Directory> testLocation(String? name) async {
|
|
final dir = await getApplicationDocumentsDirectory();
|
|
var path = '${dir.path}/flowy_test';
|
|
if (name != null) {
|
|
path += '/$name';
|
|
}
|
|
return Directory(path).create(recursive: true);
|
|
}
|
|
}
|
|
|
|
extension AppFlowyTestBase on WidgetTester {
|
|
Future<void> initializeAppFlowy() async {
|
|
TestDefaultBinaryMessengerBinding.instance.defaultBinaryMessenger
|
|
.setMockMethodCallHandler(const MethodChannel('hotkey_manager'),
|
|
(MethodCall methodCall) async {
|
|
if (methodCall.method == 'unregisterAll') {
|
|
// do nothing
|
|
}
|
|
|
|
return;
|
|
});
|
|
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
await FlowyRunner.run(FlowyApp(), IntegrationMode.integrationTest);
|
|
|
|
await wait(3000);
|
|
await pumpAndSettle(const Duration(seconds: 2));
|
|
}
|
|
|
|
Future<void> tapButton(
|
|
Finder finder, {
|
|
int? pointer,
|
|
int buttons = kPrimaryButton,
|
|
bool warnIfMissed = true,
|
|
int milliseconds = 500,
|
|
}) async {
|
|
await tap(
|
|
finder,
|
|
warnIfMissed: warnIfMissed,
|
|
);
|
|
await pumpAndSettle(Duration(milliseconds: milliseconds));
|
|
return;
|
|
}
|
|
|
|
Future<void> tapButtonWithName(
|
|
String tr, {
|
|
int milliseconds = 500,
|
|
}) async {
|
|
Finder button = find.text(
|
|
tr,
|
|
findRichText: true,
|
|
skipOffstage: false,
|
|
);
|
|
if (button.evaluate().isEmpty) {
|
|
button = find.byWidgetPredicate(
|
|
(widget) => widget is FlowyText && widget.text == tr,
|
|
);
|
|
}
|
|
await tapButton(
|
|
button,
|
|
milliseconds: milliseconds,
|
|
);
|
|
return;
|
|
}
|
|
|
|
Future<void> tapButtonWithTooltip(
|
|
String tr, {
|
|
int milliseconds = 500,
|
|
}) async {
|
|
final button = find.byTooltip(tr);
|
|
await tapButton(
|
|
button,
|
|
milliseconds: milliseconds,
|
|
);
|
|
return;
|
|
}
|
|
|
|
Future<void> wait(int milliseconds) async {
|
|
await pumpAndSettle(Duration(milliseconds: milliseconds));
|
|
return;
|
|
}
|
|
}
|
|
|
|
extension AppFlowyFinderTestBase on CommonFinders {
|
|
Finder findTextInFlowyText(String text) {
|
|
return find.byWidgetPredicate(
|
|
(widget) => widget is FlowyText && widget.text == text,
|
|
);
|
|
}
|
|
}
|