diff --git a/integration_test/e2e_auth_preferences_test.dart b/integration_test/e2e_auth_preferences_test.dart index 9edfe393..5eb81f9d 100644 --- a/integration_test/e2e_auth_preferences_test.dart +++ b/integration_test/e2e_auth_preferences_test.dart @@ -1,9 +1,4 @@ -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'test_utils.dart'; +part of 'test_utils.dart'; Future e2eAuthPreferencesTest(WidgetTester tester) async { await initializeTest(tester); @@ -20,7 +15,35 @@ Future e2eAuthPreferencesTest(WidgetTester tester) async { /// Login Screen await enterText(tester, TextFormField, password); await tapButton(tester, "Unlock wallet"); + } else { + /// Create or Import Wallet from xprv + await tapButton(tester, "Import wallet"); + await tapButton(tester, "Import from Xprv key"); + + /// Wallet Security + await scrollUntilVisible( + tester, widgetByLabel("I will be careful, I promise!")); + await tapButton(tester, LabeledCheckbox); + await tapButton(tester, "Continue"); + + /// Enter node Xprv + await tapButton(tester, Select, index: 0); + await tapButton(tester, "Node"); + await enterText(tester, TextField, nodeXprv); + await tapButton(tester, "Continue"); + + /// Enter Wallet Name + await enterText(tester, TextField, "Test Node"); + await tapButton(tester, "Continue", delay: true); + + /// If the wallet database does not exist we need to enter the password. + if (!walletsExist) { + await enterText(tester, TextFormField, password, index: 0); + await enterText(tester, TextFormField, password, index: 1); + await tapButton(tester, "Continue"); + } } + await tester.pumpAndSettle(); await tapButton(tester, FontAwesomeIcons.gear); // Check if it is desktop diff --git a/integration_test/e2e_export_xprv_test.dart b/integration_test/e2e_export_xprv_test.dart index 5abd9784..887ded7d 100644 --- a/integration_test/e2e_export_xprv_test.dart +++ b/integration_test/e2e_export_xprv_test.dart @@ -1,18 +1,4 @@ -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter/services.dart'; -import 'package:flutter_dotenv/flutter_dotenv.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:my_wit_wallet/widgets/PaddedButton.dart'; -import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; -import 'package:my_wit_wallet/widgets/select.dart'; -import 'test_utils.dart'; - -bool walletsExist = false; -String password = dotenv.env['PASSWORD'] ?? "password"; -String nodeXprv = dotenv.env['NODE_XPRV'] ?? ''; +part of 'test_utils.dart'; Future e2eExportXprvTest(WidgetTester tester) async { await initializeTest(tester); @@ -57,6 +43,15 @@ Future e2eExportXprvTest(WidgetTester tester) async { await enterText(tester, TextField, "Test Wallet"); await tapButton(tester, "Continue"); + /// If the wallet database does not exist we need to enter the password. + if (!walletsExist) { + await enterText(tester, TextFormField, password, index: 0); + await enterText(tester, TextFormField, password, index: 1); + await tapButton(tester, "Continue"); + } + + await tester.pumpAndSettle(); + await tapButton(tester, FontAwesomeIcons.gear); await tapButton(tester, "Wallet"); diff --git a/integration_test/e2e_import_mnemonic_test.dart b/integration_test/e2e_import_mnemonic_test.dart index 1bc72ef2..1e4c8d16 100644 --- a/integration_test/e2e_import_mnemonic_test.dart +++ b/integration_test/e2e_import_mnemonic_test.dart @@ -1,19 +1,4 @@ -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter_dotenv/flutter_dotenv.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:my_wit_wallet/screens/dashboard/view/dashboard_screen.dart'; -import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; -import 'test_utils.dart'; -import 'package:my_wit_wallet/widgets/PaddedButton.dart'; -import 'package:my_wit_wallet/util/storage/database/wallet.dart'; - -bool walletsExist = false; -String password = dotenv.env['PASSWORD'] ?? "password"; -String mnemonic = dotenv.env['MNEMONIC'] ?? - "abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon about"; +part of 'test_utils.dart'; Future e2eImportMnemonicTest(WidgetTester tester) async { await initializeTest(tester); @@ -57,12 +42,18 @@ Future e2eImportMnemonicTest(WidgetTester tester) async { await enterText(tester, TextField, "Test Wallet"); await tapButton(tester, "Continue"); + /// If the wallet database does not exist we need to enter the password. + if (!walletsExist) { + await enterText(tester, TextFormField, password, index: 0); + await enterText(tester, TextFormField, password, index: 1); + await tapButton(tester, "Continue"); + } + await tester.pumpAndSettle(); /// Get the currentWallet loaded in the dashboard final DashboardScreenState dashboardScreenState = tester.state(widgetByType(DashboardScreen)); - dashboardScreenState.currentWallet!.printDebug(); Wallet? currentWallet = dashboardScreenState.currentWallet; /// Verify the imported wallet and the current address diff --git a/integration_test/e2e_import_xprv_from_sheikah_test.dart b/integration_test/e2e_import_xprv_from_sheikah_test.dart index 46b56658..26765ab7 100644 --- a/integration_test/e2e_import_xprv_from_sheikah_test.dart +++ b/integration_test/e2e_import_xprv_from_sheikah_test.dart @@ -1,20 +1,4 @@ -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter_dotenv/flutter_dotenv.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:my_wit_wallet/screens/dashboard/view/dashboard_screen.dart'; -import 'package:my_wit_wallet/util/storage/database/wallet.dart'; -import 'test_utils.dart'; -import 'package:my_wit_wallet/widgets/PaddedButton.dart'; -import 'package:my_wit_wallet/widgets/select.dart'; -import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; - -bool walletsExist = false; -String password = dotenv.env['PASSWORD'] ?? "password"; -String xprv = dotenv.env['XPRV'] ?? - "xprv12qq5w546kss07l3kw5ag44epc79ya78fvqtnq2q775qx3p8trgqsur443m4cj98p3eaz0k7h7ncn58yccp5kkufkc6ylflctfcyzk45z8fup6tq4uavtv7fsmkg43mmuvddfk5fcx087jqy7x0wjw5j2zc82hupl0acmtgtntjmh34zk7ewg7qy2e8qj60pjs5y4szfzydfc0fern29nvzedra4c8pucgtgrpzgfr8d3vp0yjdn2y8qk2fdjeacvs76k9zely0p8vz7fyvn269y0ksu039hj"; +part of 'test_utils.dart'; Future e2eImportXprvFromSheikahTest(WidgetTester tester) async { await initializeTest(tester); @@ -54,8 +38,8 @@ Future e2eImportXprvFromSheikahTest(WidgetTester tester) async { await tapButton(tester, Select, index: 0); await tapButton(tester, "Sheikah"); - /// Enter Mnemonic - await enterText(tester, TextField, xprv, index: 0); + /// Enter Shiekah Compatible Encrypted Xprv + await enterText(tester, TextField, sheikahXprv, index: 0); await enterText(tester, TextField, password, index: 1); await tapButton(tester, "Continue"); @@ -73,7 +57,6 @@ Future e2eImportXprvFromSheikahTest(WidgetTester tester) async { /// Get the currentWallet loaded in the dashboard final DashboardScreenState dashboardScreenState = tester.state(widgetByType(DashboardScreen)); - dashboardScreenState.currentWallet!.printDebug(); Wallet? currentWallet = dashboardScreenState.currentWallet; /// Verify the imported wallet and the current address diff --git a/integration_test/e2e_import_xprv_test.dart b/integration_test/e2e_import_xprv_test.dart index 1ea72b57..d0506519 100644 --- a/integration_test/e2e_import_xprv_test.dart +++ b/integration_test/e2e_import_xprv_test.dart @@ -1,19 +1,4 @@ -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter_dotenv/flutter_dotenv.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:my_wit_wallet/screens/dashboard/view/dashboard_screen.dart'; -import 'package:my_wit_wallet/util/storage/database/wallet.dart'; -import 'test_utils.dart'; -import 'package:my_wit_wallet/widgets/PaddedButton.dart'; -import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; - -bool walletsExist = false; -String password = dotenv.env['PASSWORD'] ?? "password"; -String xprv = dotenv.env['XPRV'] ?? - "xprv1m9datmt8l4qyqa2nf7lxrw76vu3kyy63qndhtpjyezm7rjrlqrqjh23yks7zjwycud9k25g20rjqkl7uyfcvq6e246du73cl8hhcfa2xwm6cun5ma69jrtyyzjzm0nqwurwa8vg5pxhd9wxu2lgrpmwknsl3yk3t4qn5au4mnf33qpnk3gg7e093nkk0kqzhfkecg45jm0qsczellg6hll4nzuldckjvj6xku75gmhjc340jau26t634c98ke3a454mqjsxtvfs53f2464jfyhd605hqs0lu"; +part of 'test_utils.dart'; Future e2eImportXprvTest(WidgetTester tester) async { await initializeTest(tester); @@ -50,7 +35,7 @@ Future e2eImportXprvTest(WidgetTester tester) async { await tapButton(tester, "Continue"); /// Enter Mnemonic - await enterText(tester, TextField, xprv, index: 0); + await enterText(tester, TextField, mwwXprv, index: 0); await enterText(tester, TextField, password, index: 1); await tapButton(tester, "Continue"); @@ -65,10 +50,11 @@ Future e2eImportXprvTest(WidgetTester tester) async { await tapButton(tester, "Continue"); } + await tester.pumpAndSettle(); + /// Get the currentWallet loaded in the dashboard final DashboardScreenState dashboardScreenState = tester.state(widgetByType(DashboardScreen)); - dashboardScreenState.currentWallet!.printDebug(); Wallet? currentWallet = dashboardScreenState.currentWallet; /// Verify the imported wallet and the current address diff --git a/integration_test/e2e_mnemonic_test.dart b/integration_test/e2e_mnemonic_test.dart index c24dd0a8..b1ebae3c 100644 --- a/integration_test/e2e_mnemonic_test.dart +++ b/integration_test/e2e_mnemonic_test.dart @@ -1,10 +1,4 @@ -import 'package:flutter/material.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:my_wit_wallet/screens/create_wallet/generate_mnemonic_card.dart'; -import 'package:my_wit_wallet/widgets/PaddedButton.dart'; -import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; -import 'test_utils.dart'; +part of 'test_utils.dart'; Future e2eCreateMnemonicTest(WidgetTester tester) async { await initializeTest(tester); diff --git a/integration_test/e2e_re_establish_wallet.dart b/integration_test/e2e_re_establish_wallet.dart index 3eac2ed3..a58593e5 100644 --- a/integration_test/e2e_re_establish_wallet.dart +++ b/integration_test/e2e_re_establish_wallet.dart @@ -1,11 +1,4 @@ -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:my_wit_wallet/widgets/PaddedButton.dart'; -import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; -import 'test_utils.dart'; +part of 'test_utils.dart'; Future e2eReEstablishWallets(WidgetTester tester) async { await initializeTest(tester); @@ -22,29 +15,51 @@ Future e2eReEstablishWallets(WidgetTester tester) async { /// Login Screen await enterText(tester, TextFormField, password); await tapButton(tester, "Unlock wallet"); - } + } else { + /// Create or Import Wallet from mnemonic + await tapButton(tester, "Import wallet"); + await tapButton(tester, "Import from secret security phrase"); - await tapButton(tester, FontAwesomeIcons.gear); - await tapButton(tester, 'Lock wallet'); + /// Wallet Security + await scrollUntilVisible( + tester, widgetByLabel("I will be careful, I promise!")); + await tapButton(tester, LabeledCheckbox); + await tapButton(tester, "Continue"); + + /// Enter Mnemonic + await enterText(tester, TextField, mnemonic); + await tapButton(tester, "Continue"); - /// Cancel the Biometrics popup for linux - if (walletsExist && biometricsActive) { - if (Platform.isAndroid) { - await tapButton(tester, "CANCEL"); + /// Enter Wallet Name + await enterText(tester, TextField, "Test Wallet"); + await tapButton(tester, "Continue"); + + /// If the wallet database does not exist we need to enter the password. + if (!walletsExist) { + await enterText(tester, TextFormField, password, index: 0); + await enterText(tester, TextFormField, password, index: 1); + await tapButton(tester, "Continue"); } + await tester.pumpAndSettle(); } - await scrollUntilVisible(tester, find.byType(PaddedButton).at(0), - lastScroll: true); - await tester.pumpAndSettle(); - await tapButton(tester, PaddedButton, index: 0); + await tapButton(tester, FontAwesomeIcons.gear); + await tapButton(tester, 'Lock wallet', delay: true, milliseconds: 1000); await scrollUntilVisible( - tester, widgetByLabel("I will be careful, I promise!")); + tester, + widgetByText("Re-establish wallet"), + lastScroll: true, + ); + await tapButton( + tester, + "Re-establish wallet", + delay: true, + milliseconds: 1000, + ); await tapButton(tester, LabeledCheckbox); await tapButton(tester, "Continue"); await tapButton(tester, "Re-establish"); await tapButton(tester, "Continue", index: 1); - await tapButton(tester, "Back", index: 0); bool isStorageDeleted = isTextOnScreen('Create new wallet'); expect(isStorageDeleted, true); } diff --git a/integration_test/e2e_show_node_stats.dart b/integration_test/e2e_show_node_stats.dart index e977d5ed..cc2d2a40 100644 --- a/integration_test/e2e_show_node_stats.dart +++ b/integration_test/e2e_show_node_stats.dart @@ -1,19 +1,4 @@ -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter_dotenv/flutter_dotenv.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:my_wit_wallet/screens/dashboard/view/dashboard_screen.dart'; -import 'package:my_wit_wallet/util/storage/database/wallet.dart'; -import 'package:my_wit_wallet/widgets/select.dart'; -import 'test_utils.dart'; -import 'package:my_wit_wallet/widgets/PaddedButton.dart'; -import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; - -bool walletsExist = false; -String password = dotenv.env['PASSWORD'] ?? "password"; -String nodeXprv = dotenv.env['NODE_XPRV'] ?? ''; +part of 'test_utils.dart'; Future e2eShowNodeStatsTest(WidgetTester tester) async { await initializeTest(tester); @@ -38,7 +23,34 @@ Future e2eShowNodeStatsTest(WidgetTester tester) async { await tapButton(tester, FontAwesomeIcons.circlePlus); } - /// Create or Import Wallet from xprv + /// Create or Import Wallet from mnemonic + await tapButton(tester, "Import wallet"); + await tapButton(tester, "Import from secret security phrase"); + + /// Wallet Security + await scrollUntilVisible( + tester, widgetByLabel("I will be careful, I promise!")); + await tapButton(tester, LabeledCheckbox); + await tapButton(tester, "Continue"); + + /// Enter Mnemonic + await enterText(tester, TextField, mnemonic); + await tapButton(tester, "Continue"); + + /// Enter Wallet Name + await enterText(tester, TextField, "Test Wallet"); + await tapButton(tester, "Continue"); + + /// If the wallet database does not exist we need to enter the password. + if (!walletsExist) { + await enterText(tester, TextFormField, password, index: 0); + await enterText(tester, TextFormField, password, index: 1); + await tapButton(tester, "Continue"); + } + await tester.pumpAndSettle(); + await tapButton(tester, PaddedButton, index: 0); + await tapButton(tester, FontAwesomeIcons.circlePlus); + await tapButton(tester, "Import wallet"); await tapButton(tester, "Import from Xprv key"); @@ -54,22 +66,23 @@ Future e2eShowNodeStatsTest(WidgetTester tester) async { await enterText(tester, TextField, nodeXprv); await tapButton(tester, "Continue"); - /// Enter Wallet Name - await enterText(tester, TextField, "Test Wallet"); + /// Enter Node Name + await enterText(tester, TextField, "Test Node"); await tapButton(tester, "Continue"); + await tester.pumpAndSettle(); + /// Get the currentWallet loaded in the dashboard final DashboardScreenState dashboardScreenState = tester.state(widgetByType(DashboardScreen)); - await expectLater(dashboardScreenState.currentWallet!.id, 'dae88d1f'); - dashboardScreenState.currentWallet!.printDebug(); + await expectLater(dashboardScreenState.currentWallet!.id, 'ce389a1a'); Wallet? currentWallet = dashboardScreenState.currentWallet; await tester.pumpAndSettle(); /// Verify the imported wallet and the current address expectLater(currentWallet!.masterAccount!.address, - "wit1zl7ty0lwr7atp5fu34azkgewhtfx2fl4wv69cw"); + "wit1vzm7xrguwf5uzjx72l65stgj3npfn292tya50u"); await tapButton(tester, "Stats"); diff --git a/integration_test/e2e_sign_message_test.dart b/integration_test/e2e_sign_message_test.dart index fea1f984..95eb745d 100644 --- a/integration_test/e2e_sign_message_test.dart +++ b/integration_test/e2e_sign_message_test.dart @@ -1,18 +1,4 @@ -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter/services.dart'; -import 'package:flutter_dotenv/flutter_dotenv.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:my_wit_wallet/widgets/PaddedButton.dart'; -import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; -import 'package:my_wit_wallet/widgets/select.dart'; -import 'test_utils.dart'; - -bool walletsExist = false; -String password = dotenv.env['PASSWORD'] ?? "password"; -String nodeXprv = dotenv.env['NODE_XPRV'] ?? ''; +part of 'test_utils.dart'; Future e2eSignMessageTest(WidgetTester tester) async { await initializeTest(tester); @@ -57,6 +43,15 @@ Future e2eSignMessageTest(WidgetTester tester) async { await enterText(tester, TextField, "Test Wallet"); await tapButton(tester, "Continue"); + /// If the wallet database does not exist we need to enter the password. + if (!walletsExist) { + await enterText(tester, TextFormField, password, index: 0); + await enterText(tester, TextFormField, password, index: 1); + await tapButton(tester, "Continue"); + } + + await tester.pumpAndSettle(); + await tapButton(tester, FontAwesomeIcons.gear); if (Platform.isIOS || Platform.isAndroid) { @@ -76,7 +71,7 @@ Future e2eSignMessageTest(WidgetTester tester) async { // Select second address in the list await tapButton(tester, Select, index: 0); - await tapButton(tester, "wit1zl7ty0lwr7atp5fu34azkgewhtfx2fl4wv69cw", + await tapButton(tester, "wit1vzm7xrguwf5uzjx72l65stgj3npfn292tya50u", index: 2); /// Enter Message to sign diff --git a/integration_test/e2e_update_wallet_test.dart b/integration_test/e2e_update_wallet_test.dart index b076d378..d79ac2ae 100644 --- a/integration_test/e2e_update_wallet_test.dart +++ b/integration_test/e2e_update_wallet_test.dart @@ -1,21 +1,4 @@ -import 'dart:io'; - -import 'package:flutter/material.dart'; -import 'package:flutter_dotenv/flutter_dotenv.dart'; -import 'package:flutter_test/flutter_test.dart'; -import 'package:font_awesome_flutter/font_awesome_flutter.dart'; -import 'package:my_wit_wallet/screens/dashboard/view/dashboard_screen.dart'; -import 'package:my_wit_wallet/util/storage/database/wallet.dart'; -import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; -import 'package:my_wit_wallet/widgets/select.dart'; -import 'test_utils.dart'; -import 'package:my_wit_wallet/widgets/PaddedButton.dart'; - -bool walletsExist = false; -String password = dotenv.env['PASSWORD'] ?? "password"; -String mnemonic = dotenv.env['MNEMONIC'] ?? - "abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon about"; -String nodeXprv = dotenv.env['NODE_XPRV'] ?? ''; +part of 'test_utils.dart'; Future e2eUpdateCurrentWalletTest(WidgetTester tester) async { await initializeTest(tester); @@ -57,21 +40,28 @@ Future e2eUpdateCurrentWalletTest(WidgetTester tester) async { await tapButton(tester, "Continue"); /// Enter Wallet Name - await enterText(tester, TextField, "Test Wallet"); - await tapButton(tester, "Continue"); + await enterText(tester, TextField, "Test Node"); + await tapButton(tester, "Continue", delay: true); + + /// If the wallet database does not exist we need to enter the password. + if (!walletsExist) { + await enterText(tester, TextFormField, password, index: 0); + await enterText(tester, TextFormField, password, index: 1); + await tapButton(tester, "Continue"); + } + await tester.pumpAndSettle(); /// Get the currentWallet loaded in the dashboard final DashboardScreenState dashboardScreenState = tester.state(widgetByType(DashboardScreen)); - await expectLater(dashboardScreenState.currentWallet!.id, 'dae88d1f'); - dashboardScreenState.currentWallet!.printDebug(); + await expectLater(dashboardScreenState.currentWallet!.id, 'ce389a1a'); Wallet? currentWallet = dashboardScreenState.currentWallet; await tester.pumpAndSettle(); /// Verify the imported wallet and the current address expectLater(currentWallet!.masterAccount!.address, - "wit1zl7ty0lwr7atp5fu34azkgewhtfx2fl4wv69cw"); + "wit1vzm7xrguwf5uzjx72l65stgj3npfn292tya50u"); /// Dashboard /// Tap on the first PaddedButton on the screen, which is the identicon @@ -102,7 +92,7 @@ Future e2eUpdateCurrentWalletTest(WidgetTester tester) async { /// Get the currentWallet loaded in the dashboard final DashboardScreenState dashboardScreenState2 = tester.state(widgetByType(DashboardScreen)); - dashboardScreenState2.currentWallet!.printDebug(); + // dashboardScreenState2.currentWallet!.printDebug(); Wallet? currentWallet2 = dashboardScreenState2.currentWallet; /// Verify the imported wallet and the current address @@ -126,19 +116,18 @@ Future e2eUpdateCurrentWalletTest(WidgetTester tester) async { await tester.pumpAndSettle(); /// Select Node wallet from the wallets list - await tapButton(tester, "wit1zl7ty0lwr7atp5fu34azkgewhtfx2fl4wv69cw"); + await tapButton(tester, "wit1vzm7xrguwf5uzjx72l65stgj3npfn292tya50u"); await tester.pumpAndSettle(); final DashboardScreenState dashboardScreenState3 = tester.state(widgetByType(DashboardScreen)); - await expectLater(dashboardScreenState3.currentWallet!.id, 'dae88d1f'); - dashboardScreenState3.currentWallet!.printDebug(); + await expectLater(dashboardScreenState3.currentWallet!.id, 'ce389a1a'); Wallet? currentWallet3 = dashboardScreenState3.currentWallet; await tester.pumpAndSettle(); /// Verify the imported wallet and the current address expectLater(currentWallet3!.masterAccount!.address, - "wit1zl7ty0lwr7atp5fu34azkgewhtfx2fl4wv69cw"); + "wit1vzm7xrguwf5uzjx72l65stgj3npfn292tya50u"); } diff --git a/integration_test/main.dart b/integration_test/main.dart index 64f79eaf..e262912d 100644 --- a/integration_test/main.dart +++ b/integration_test/main.dart @@ -1,17 +1,7 @@ import 'package:flutter_test/flutter_test.dart'; -import 'e2e_mnemonic_test.dart'; -import 'e2e_import_mnemonic_test.dart'; -import 'e2e_re_establish_wallet.dart'; -import "e2e_import_xprv_test.dart"; -import "e2e_export_xprv_test.dart"; -import 'e2e_import_xprv_from_sheikah_test.dart'; -import 'e2e_auth_preferences_test.dart'; -import 'e2e_sign_message_test.dart'; -import 'e2e_update_wallet_test.dart'; -import 'e2e_show_node_stats.dart'; import 'package:my_wit_wallet/globals.dart' as globals; - +import 'test_utils.dart'; void main() async { globals.testingActive = true; diff --git a/integration_test/test_utils.dart b/integration_test/test_utils.dart index 69ac44c2..97362248 100644 --- a/integration_test/test_utils.dart +++ b/integration_test/test_utils.dart @@ -1,14 +1,29 @@ import 'dart:io'; import 'package:flutter/material.dart'; +import 'package:flutter/services.dart'; import 'package:flutter_dotenv/flutter_dotenv.dart'; import 'package:flutter_test/flutter_test.dart'; import 'package:font_awesome_flutter/font_awesome_flutter.dart'; +import 'package:my_wit_wallet/screens/create_wallet/generate_mnemonic_card.dart'; +import 'package:my_wit_wallet/screens/dashboard/view/dashboard_screen.dart'; +import 'package:my_wit_wallet/util/storage/database/wallet.dart'; import 'package:my_wit_wallet/widgets/PaddedButton.dart'; +import 'package:my_wit_wallet/widgets/labeled_checkbox.dart'; import 'package:my_wit_wallet/widgets/select.dart'; import 'package:my_wit_wallet/main.dart' as myWitWallet; +part 'e2e_auth_preferences_test.dart'; +part 'e2e_export_xprv_test.dart'; +part 'e2e_import_mnemonic_test.dart'; +part 'e2e_show_node_stats.dart'; +part "e2e_mnemonic_test.dart"; +part 'e2e_re_establish_wallet.dart'; +part "e2e_import_xprv_test.dart"; +part 'e2e_import_xprv_from_sheikah_test.dart'; +part 'e2e_update_wallet_test.dart'; +part 'e2e_sign_message_test.dart'; bool walletsExist = false; int defaultDelay = int.parse(dotenv.env['DELAY'] ?? '100'); diff --git a/lib/main.dart b/lib/main.dart index cdc017a8..7f3a45ed 100644 --- a/lib/main.dart +++ b/lib/main.dart @@ -44,8 +44,14 @@ void main() async { ApiDatabase apiDatabase = Locator.instance(); await apiDatabase.openDatabase(); - if (globals.testingActive) await apiDatabase.lockDatabase(); - + if (globals.testingActive) { + await apiDatabase.lockDatabase(); + if (globals.testingDeleteStorage && globals.firstRun) { + await apiDatabase.deleteAllWallets(); + await apiDatabase.openDatabase(); + globals.firstRun = false; + } + } CryptoIsolate cryptoIsolate = Locator.instance(); await cryptoIsolate.init(); diff --git a/lib/screens/login/view/init_screen.dart b/lib/screens/login/view/init_screen.dart index 59682c1a..b82c8ac7 100644 --- a/lib/screens/login/view/init_screen.dart +++ b/lib/screens/login/view/init_screen.dart @@ -8,7 +8,6 @@ import 'package:my_wit_wallet/widgets/layouts/layout.dart'; import 'package:my_wit_wallet/widgets/carousel.dart'; import 'package:my_wit_wallet/shared/locator.dart'; import 'package:my_wit_wallet/shared/api_database.dart'; -import 'package:my_wit_wallet/globals.dart' as globals; class InitScreen extends StatefulWidget { static final route = '/'; @@ -51,13 +50,6 @@ class InitScreenState extends State with TickerProviderStateMixin { Future loadInitialScreen() async { ApiDatabase database = Locator.instance(); - if (globals.testingActive && - globals.testingDeleteStorage && - globals.firstRun) { - await database.deleteAllWallets(); - await database.openDatabase(); - globals.firstRun = false; - } WalletStorage storage = await database.loadWalletsDatabase(); if (storage.wallets.isNotEmpty) { diff --git a/lib/util/storage/path_provider_interface.dart b/lib/util/storage/path_provider_interface.dart index c7138240..c52cac0b 100644 --- a/lib/util/storage/path_provider_interface.dart +++ b/lib/util/storage/path_provider_interface.dart @@ -7,7 +7,6 @@ import 'dart:io'; import 'package:open_file/open_file.dart'; import 'package:permission_handler/permission_handler.dart'; -import 'package:my_wit_wallet/globals.dart' as globals; enum Platforms { Linux, Macos, Windows, IOS, Android } @@ -50,9 +49,6 @@ class PathProviderInterface { return io.File('$path${io.Platform.pathSeparator}$name.$extension'); } - //Future writeWalletListFile(Map wallets) async { - //} - Future> readJsonFile(String name) async { io.File file = await localFile(name: name, extension: 'json'); final contents = await file.readAsString();