mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-07 03:19:31 +00:00
4adb81c4dc
Some checks are pending
Cache Dependencies / test (push) Waiting to run
* 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 * Fix: Add keys back to currency amount textfield widget * fix: Switch variable name * fix: remove automation for now * test: Updating send page robot and also syncing branch with main --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
96 lines
2.9 KiB
Dart
96 lines
2.9 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}) async {
|
|
final widget = find.byKey(ValueKey(key));
|
|
await tester.tap(widget);
|
|
shouldPumpAndSettle ? await tester.pumpAndSettle() : 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);
|
|
}
|
|
|
|
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> scrollUntilVisible(String childKey, String parentScrollableKey,
|
|
{double delta = 300}) async {
|
|
final scrollableWidget = find.descendant(
|
|
of: find.byKey(Key(parentScrollableKey)),
|
|
matching: find.byType(Scrollable),
|
|
);
|
|
|
|
final isAlreadyVisibile = isWidgetVisible(find.byKey(ValueKey(childKey)));
|
|
|
|
if (isAlreadyVisibile) return;
|
|
|
|
await tester.scrollUntilVisible(
|
|
find.byKey(ValueKey(childKey)),
|
|
delta,
|
|
scrollable: scrollableWidget,
|
|
);
|
|
}
|
|
|
|
bool isWidgetVisible(Finder finder) {
|
|
try {
|
|
final Element element = finder.evaluate().single;
|
|
final RenderBox renderBox = element.renderObject as RenderBox;
|
|
return renderBox.paintBounds
|
|
.shift(renderBox.localToGlobal(Offset.zero))
|
|
.overlaps(tester.binding.renderViews.first.paintBounds);
|
|
} catch (e) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
Future<void> enterText(String text, String editableTextKey) async {
|
|
final editableTextWidget = find.byKey(ValueKey((editableTextKey)));
|
|
|
|
await tester.enterText(editableTextWidget, text);
|
|
|
|
await tester.pumpAndSettle();
|
|
}
|
|
|
|
Future<void> defaultSleepTime({int seconds = 2}) async =>
|
|
await Future.delayed(Duration(seconds: seconds));
|
|
}
|