mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-25 12:06:05 +00:00
c9a6abeea4
* fix: Confirm widget is still mounted * feat: Modify balance display to include full balance * fix: Modifying balance * chore: Feature cleanup * fix: Add frozen balance into consideration when taking available balance and add field to make full balance display only on bitcoin and litecoin wallets * fix: Adjust balance card to display correct available and unavailable balance, unavailable balance should only be displayed when there is one WIP * fix: Cleanup balance page and balance page view_model * chore: Revert formatting * fix: Remove full balance * fix: Remove full balance * fix: Remove full balance * chore: Rever formating [skip ci] * feat: Finalize display only available and unavailable balance * fix: Modify the way balance is displayed, activate frozen balance with label, remove unavailable/additional balance for bitcoin wallet type * fix: Issues coming from syncing with main * fix: Modify additional balance label * fix: Monero and Wownero balances display bug * fix: Resolve merge conflicts * feat: Activate CPFP for BTC, LTC and BCH, also fix issues with frozen balance display * - minor fix - remove unused functions * Fix conflicts --------- Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com> Co-authored-by: tuxsudo <tuxsudo@tux.pizza>
109 lines
3.6 KiB
Dart
109 lines
3.6 KiB
Dart
import 'package:cake_wallet/generated/i18n.dart';
|
|
import 'package:cake_wallet/src/screens/dashboard/dashboard_page.dart';
|
|
import 'package:cake_wallet/src/screens/dashboard/pages/balance/crypto_balance_widget.dart';
|
|
import 'package:cw_core/wallet_type.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
|
|
import '../components/common_test_cases.dart';
|
|
import 'dashboard_menu_widget_robot.dart';
|
|
|
|
class DashboardPageRobot {
|
|
DashboardPageRobot(this.tester)
|
|
: commonTestCases = CommonTestCases(tester),
|
|
dashboardMenuWidgetRobot = DashboardMenuWidgetRobot(tester);
|
|
|
|
final WidgetTester tester;
|
|
final DashboardMenuWidgetRobot dashboardMenuWidgetRobot;
|
|
late CommonTestCases commonTestCases;
|
|
|
|
Future<void> isDashboardPage() async {
|
|
await commonTestCases.isSpecificPage<DashboardPage>();
|
|
}
|
|
|
|
Future<void> confirmWalletTypeIsDisplayedCorrectly(
|
|
WalletType type, {
|
|
bool isHaven = false,
|
|
}) async {
|
|
final cryptoBalanceWidget =
|
|
tester.widget<CryptoBalanceWidget>(find.byType(CryptoBalanceWidget));
|
|
final hasAccounts = cryptoBalanceWidget.dashboardViewModel.balanceViewModel.hasAccounts;
|
|
|
|
if (hasAccounts) {
|
|
final walletName = cryptoBalanceWidget.dashboardViewModel.name;
|
|
commonTestCases.hasText(walletName);
|
|
} else {
|
|
final walletName = walletTypeToString(type);
|
|
final assetName = isHaven ? '$walletName Assets' : walletName;
|
|
commonTestCases.hasText(assetName);
|
|
}
|
|
await commonTestCases.defaultSleepTime(seconds: 5);
|
|
}
|
|
|
|
void confirmServiceUpdateButtonDisplays() {
|
|
commonTestCases.hasValueKey('dashboard_page_services_update_button_key');
|
|
}
|
|
|
|
void confirmSyncIndicatorButtonDisplays() {
|
|
commonTestCases.hasValueKey('dashboard_page_sync_indicator_button_key');
|
|
}
|
|
|
|
void confirmMenuButtonDisplays() {
|
|
commonTestCases.hasValueKey('dashboard_page_wallet_menu_button_key');
|
|
}
|
|
|
|
Future<void> confirmRightCryptoAssetTitleDisplaysPerPageView(
|
|
WalletType type, {
|
|
bool isHaven = false,
|
|
}) async {
|
|
//Balance Page
|
|
await confirmWalletTypeIsDisplayedCorrectly(type, isHaven: isHaven);
|
|
|
|
// Swipe to Cake features Page
|
|
await swipeDashboardTab(false);
|
|
commonTestCases.hasText('Cake ${S.current.features}');
|
|
|
|
// Swipe back to balance
|
|
await swipeDashboardTab(true);
|
|
|
|
// Swipe to Transactions Page
|
|
await swipeDashboardTab(true);
|
|
commonTestCases.hasText(S.current.transactions);
|
|
|
|
// Swipe back to balance
|
|
await swipeDashboardTab(false);
|
|
await commonTestCases.defaultSleepTime(seconds: 3);
|
|
}
|
|
|
|
Future<void> swipeDashboardTab(bool swipeRight) async {
|
|
await commonTestCases.swipeByPageKey(
|
|
key: 'dashboard_page_view_key',
|
|
swipeRight: swipeRight,
|
|
);
|
|
await commonTestCases.defaultSleepTime();
|
|
}
|
|
|
|
Future<void> openDrawerMenu() async {
|
|
await commonTestCases.tapItemByKey('dashboard_page_wallet_menu_button_key');
|
|
await commonTestCases.defaultSleepTime();
|
|
}
|
|
|
|
Future<void> navigateToBuyPage() async {
|
|
await commonTestCases.tapItemByKey('dashboard_page_${S.current.buy}_action_button_key');
|
|
}
|
|
|
|
Future<void> navigateToSendPage() async {
|
|
await commonTestCases.tapItemByKey('dashboard_page_${S.current.send}_action_button_key');
|
|
}
|
|
|
|
Future<void> navigateToSellPage() async {
|
|
await commonTestCases.tapItemByKey('dashboard_page_${S.current.sell}_action_button_key');
|
|
}
|
|
|
|
Future<void> navigateToReceivePage() async {
|
|
await commonTestCases.tapItemByKey('dashboard_page_${S.current.receive}_action_button_key');
|
|
}
|
|
|
|
Future<void> navigateToExchangePage() async {
|
|
await commonTestCases.tapItemByKey('dashboard_page_${S.current.exchange}_action_button_key');
|
|
}
|
|
}
|