mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-03 09:29:48 +00:00
0fcfd76afd
Some checks failed
Cache Dependencies / test (push) Has been cancelled
* feat: Integration tests setup and tests for Disclaimer, Welcome and Setup Pin Code pages * feat: Integration test flow from start to restoring a wallet successfully done * test: Dashboard view test and linking to flow * feat: Testing the Exchange flow section, selecting sending and receiving currencies * test: Successfully create an exchange section * feat: Implement flow up to sending section * test: Complete Exchange flow * fix dependency issue * test: Final cleanups * feat: Add CI to run automated integration tests withan android emulator * feat: Adjust Automated integration test CI to run on ubuntu 20.04-a * fix: Move integration test CI into PR test build CI * ci: Add automated test ci which is a streamlined replica of pr test build ci * ci: Re-add step to access branch name * ci: Add KVM * ci: Add filepath to trigger the test run from * ci: Add required key * ci: Add required key * ci: Add missing secret key * ci: Add missing secret key * ci: Add nano secrets to workflow * ci: Switch step to free space on runner * ci: Remove timeout from workflow * ci: Confirm impact that removing copy_monero_deps would have on entire workflow time * ci: Update CI and temporarily remove cache related to emulator * ci: Remove dynamic java version * ci: Temporarily switch CI * ci: Switch to 11.x jdk * ci: Temporarily switch CI * ci: Revert ubuntu version * ci: Add more api levels * ci: Add more target options * ci: Settled on stable emulator matrix options * ci: Add more target options * ci: Modify flow * ci: Streamline api levels to 28 and 29 * ci: One more trial * ci: Switch to flutter drive * ci: Reduce options * ci: Remove haven from test * ci: Check for solana in list * ci: Adjust amounts and currencies for exchange flow * ci: Set write response on failure to true * ci: Split ci to funds and non funds related tests * test: Test for Send flow scenario and minor restructuring for test folders and files * chore: cleanup * ci: Pause CI for now * ci: Pause CI for now * ci: Pause CI for now * test: Restore wallets integration automated tests * Fix: Add keys back to currency amount textfield widget * fix: Switch variable name * fix: remove automation for now * tests: Automated tests for Create wallets flow * tests: Further optimize common flows * tests: Add missing await for call * tests: Confirm Seeds Display Properly WIP * tests: Confirm Seeds Display Correctly Automated Tests * fix: Add missing pubspec params for bitcoin and bitcoin_cash * feat: Automated Tests for Transaction History Flow * fix: Add missing pubspec parameter * feat: Automated Integration Tests for Transaction History flow * test: Updating send page robot and also syncing branch with main * test: Modifying tests to flow with wallet grouping implementation * fix: Issue with transaction history test * fix: Modifications to the PR and add automated confirmation for checking that all wallet types are restored or created correctly * test: Attempting automation for testing * fix: Issue from merge conflicts * test: Remove automation of test in this PR --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
169 lines
5 KiB
Dart
169 lines
5 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
|
|
class CommonTestCases {
|
|
WidgetTester tester;
|
|
CommonTestCases(this.tester);
|
|
|
|
Future<void> isSpecificPage<T>() async {
|
|
await tester.pumpAndSettle();
|
|
hasType<T>();
|
|
}
|
|
|
|
Future<void> tapItemByKey(
|
|
String key, {
|
|
bool shouldPumpAndSettle = true,
|
|
int pumpDuration = 100,
|
|
}) async {
|
|
final widget = find.byKey(ValueKey(key));
|
|
await tester.tap(widget);
|
|
shouldPumpAndSettle
|
|
? await tester.pumpAndSettle(Duration(milliseconds: pumpDuration))
|
|
: await tester.pump();
|
|
}
|
|
|
|
Future<void> tapItemByFinder(Finder finder, {bool shouldPumpAndSettle = true}) async {
|
|
await tester.tap(finder);
|
|
shouldPumpAndSettle ? await tester.pumpAndSettle() : await tester.pump();
|
|
}
|
|
|
|
void hasText(String text, {bool hasWidget = true}) {
|
|
final textWidget = find.text(text);
|
|
expect(textWidget, hasWidget ? findsOneWidget : findsNothing);
|
|
}
|
|
|
|
void hasType<T>() {
|
|
final typeWidget = find.byType(T);
|
|
expect(typeWidget, findsOneWidget);
|
|
}
|
|
|
|
bool isKeyPresent(String key) {
|
|
final typeWidget = find.byKey(ValueKey(key));
|
|
return typeWidget.tryEvaluate();
|
|
}
|
|
|
|
void hasValueKey(String key) {
|
|
final typeWidget = find.byKey(ValueKey(key));
|
|
expect(typeWidget, findsOneWidget);
|
|
}
|
|
|
|
Future<void> swipePage({bool swipeRight = true}) async {
|
|
await tester.drag(find.byType(PageView), Offset(swipeRight ? -300 : 300, 0));
|
|
await tester.pumpAndSettle();
|
|
}
|
|
|
|
Future<void> swipeByPageKey({required String key, bool swipeRight = true}) async {
|
|
await tester.drag(find.byKey(ValueKey(key)), Offset(swipeRight ? -300 : 300, 0));
|
|
await tester.pumpAndSettle();
|
|
}
|
|
|
|
Future<void> goBack() async {
|
|
tester.printToConsole('Routing back to previous screen');
|
|
final NavigatorState navigator = tester.state(find.byType(Navigator));
|
|
navigator.pop();
|
|
await tester.pumpAndSettle();
|
|
}
|
|
|
|
Future<void> dragUntilVisible(String childKey, String parentKey) async {
|
|
await tester.pumpAndSettle();
|
|
|
|
final itemFinder = find.byKey(ValueKey(childKey));
|
|
final listFinder = find.byKey(ValueKey(parentKey));
|
|
|
|
// Check if the widget is already in the widget tree
|
|
if (tester.any(itemFinder)) {
|
|
// Widget is already built and in the tree
|
|
tester.printToConsole('Child is already present');
|
|
return;
|
|
}
|
|
|
|
// We can adjust this as needed
|
|
final maxScrolls = 200;
|
|
|
|
int scrolls = 0;
|
|
bool found = false;
|
|
|
|
// We start by scrolling down
|
|
bool scrollDown = true;
|
|
|
|
// Flag to check if we've already reversed direction
|
|
bool reversedDirection = false;
|
|
|
|
// Find the Scrollable associated with the Parent Ad
|
|
final scrollableFinder = find.descendant(
|
|
of: listFinder,
|
|
matching: find.byType(Scrollable),
|
|
);
|
|
|
|
// Ensure that the Scrollable is found
|
|
expect(
|
|
scrollableFinder,
|
|
findsOneWidget,
|
|
reason: 'Scrollable descendant of the Parent Widget not found.',
|
|
);
|
|
|
|
// Get the initial scroll position
|
|
final scrollableState = tester.state<ScrollableState>(scrollableFinder);
|
|
double previousScrollPosition = scrollableState.position.pixels;
|
|
|
|
while (!found && scrolls < maxScrolls) {
|
|
tester.printToConsole('Scrolling ${scrollDown ? 'down' : 'up'}, attempt $scrolls');
|
|
|
|
// Perform the drag in the current direction
|
|
await tester.drag(
|
|
scrollableFinder,
|
|
scrollDown ? const Offset(0, -100) : const Offset(0, 100),
|
|
);
|
|
await tester.pumpAndSettle();
|
|
scrolls++;
|
|
|
|
// Update the scroll position after the drag
|
|
final currentScrollPosition = scrollableState.position.pixels;
|
|
|
|
if (currentScrollPosition == previousScrollPosition) {
|
|
// Cannot scroll further in this direction
|
|
if (reversedDirection) {
|
|
// We've already tried both directions
|
|
tester.printToConsole('Cannot scroll further in both directions. Widget not found.');
|
|
break;
|
|
} else {
|
|
// Reverse the scroll direction
|
|
scrollDown = !scrollDown;
|
|
reversedDirection = true;
|
|
tester.printToConsole('Reached the end, reversing direction');
|
|
}
|
|
} else {
|
|
// Continue scrolling in the current direction
|
|
previousScrollPosition = currentScrollPosition;
|
|
}
|
|
|
|
// Check if the widget is now in the widget tree
|
|
found = tester.any(itemFinder);
|
|
}
|
|
|
|
if (!found) {
|
|
tester.printToConsole('Widget not found after scrolling in both directions.');
|
|
return;
|
|
}
|
|
}
|
|
|
|
Future<void> enterText(String text, String editableTextKey) async {
|
|
final editableTextWidget = find.byKey(ValueKey((editableTextKey)));
|
|
|
|
await tester.enterText(editableTextWidget, text);
|
|
|
|
await tester.pumpAndSettle();
|
|
}
|
|
|
|
void findWidgetViaDescendant({
|
|
required FinderBase<Element> of,
|
|
required FinderBase<Element> matching,
|
|
}) {
|
|
final textWidget = find.descendant(of: of, matching: matching);
|
|
|
|
expect(textWidget, findsOneWidget);
|
|
}
|
|
|
|
Future<void> defaultSleepTime({int seconds = 2}) async =>
|
|
await Future.delayed(Duration(seconds: seconds));
|
|
}
|